Appt Icon Pin Icon Phone Icon
APPOINTMENTS

Thank you for visiting the office of Dan Howard. We are committed to providing individualized, quality dental care that meets your oral health needs. Please leave us a review about your experience in our office. We are constantly striving to improve our service to you, and we value your thoughts. If you have any questions about dental care in Morrill, Nebraska, and the surrounding areas, or to make an appointment with our dentist, please call us today at 308-247-3381.

The requested content cannot be loaded.
Please try again later.

',closeBtn:'',next:'',prev:''},openEffect:"fade",openSpeed:250,openEasing:"swing",openOpacity:!0,openMethod:"zoomIn",closeEffect:"fade",closeSpeed:250,closeEasing:"swing",closeOpacity:!0,closeMethod:"zoomOut",nextEffect:"elastic",nextSpeed:250,nextEasing:"swing",nextMethod:"changeIn",prevEffect:"elastic",prevSpeed:250,prevEasing:"swing",prevMethod:"changeOut",helpers:{overlay:!0,title:!0},onCancel:f.noop,beforeLoad:f.noop,afterLoad:f.noop,beforeShow:f.noop,afterShow:f.noop,beforeChange:f.noop,beforeClose:f.noop,afterClose:f.noop},group:{},opts:{},previous:null,coming:null,current:null,isActive:!1,isOpen:!1,isOpened:!1,wrap:null,skin:null,outer:null,inner:null,player:{timer:null,isActive:!1},ajaxLoad:null,imgPreload:null,transitions:{},helpers:{},open:function(a,d){if(a&&(f.isPlainObject(d)||(d={}),!1!==b.close(!0)))return f.isArray(a)||(a=t(a)?f(a).get():[a]),f.each(a,function(e,c){var k={},g,h,j,m,l;"object"===f.type(c)&&(c.nodeType&&(c=f(c)),t(c)?(k={href:c.data("fancybox-href")||c.attr("href"),title:c.data("fancybox-title")||c.attr("title"),isDom:!0,element:c},f.metadata&&f.extend(!0,k,c.metadata())):k=c);g=d.href||k.href||(q(c)?c:null);h=d.title!==v?d.title:k.title||"";m=(j=d.content||k.content)?"html":d.type||k.type;!m&&k.isDom&&(m=c.data("fancybox-type"),m||(m=(m=c.prop("class").match(/fancybox\.(\w+)/))?m[1]:null));q(g)&&(m||(b.isImage(g)?m="image":b.isSWF(g)?m="swf":"#"===g.charAt(0)?m="inline":q(c)&&(m="html",j=c)),"ajax"===m&&(l=g.split(/\s+/,2),g=l.shift(),l=l.shift()));j||("inline"===m?g?j=f(q(g)?g.replace(/.*(?=#[^\s]+$)/,""):g):k.isDom&&(j=c):"html"===m?j=g:!m&&(!g&&k.isDom)&&(m="inline",j=c));f.extend(k,{href:g,type:m,content:j,title:h,selector:l});a[e]=k}),b.opts=f.extend(!0,{},b.defaults,d),d.keys!==v&&(b.opts.keys=d.keys?f.extend({},b.defaults.keys,d.keys):!1),b.group=a,b._start(b.opts.index)},cancel:function(){var a=b.coming;a&&!1!==b.trigger("onCancel")&&(b.hideLoading(),b.ajaxLoad&&b.ajaxLoad.abort(),b.ajaxLoad=null,b.imgPreload&&(b.imgPreload.onload=b.imgPreload.onerror=null),a.wrap&&a.wrap.stop(!0,!0).trigger("onReset").remove(),b.coming=null,b.current||b._afterZoomOut(a))},close:function(a){b.cancel();!1!==b.trigger("beforeClose")&&(b.unbindEvents(),b.isActive&&(!b.isOpen||!0===a?(f(".fancybox-wrap").stop(!0).trigger("onReset").remove(),b._afterZoomOut()):(b.isOpen=b.isOpened=!1,b.isClosing=!0,f(".fancybox-item, .fancybox-nav").remove(),b.wrap.stop(!0,!0).removeClass("fancybox-opened"),b.transitions[b.current.closeMethod]())))},play:function(a){var d=function(){clearTimeout(b.player.timer)},e=function(){d();b.current&&b.player.isActive&&(b.player.timer=setTimeout(b.next,b.current.playSpeed))},c=function(){d();p.unbind(".player");b.player.isActive=!1;b.trigger("onPlayEnd")};if(!0===a||!b.player.isActive&&!1!==a){if(b.current&&(b.current.loop||b.current.index=c.index?"next":"prev"],b.router=e||"jumpto",c.loop&&(0>a&&(a=c.group.length+a%c.group.length),a%=c.group.length),c.group[a]!==v&&(b.cancel(),b._start(a)))},reposition:function(a,d){var e=b.current,c=e?e.wrap:null,k;c&&(k=b._getPosition(d),a&&"scroll"===a.type?(delete k.position,c.stop(!0,!0).animate(k,200)):(c.css(k),e.pos=f.extend({},e.dim,k)))},update:function(a){var d=a&&a.type,e=!d||"orientationchange"===d;e&&(clearTimeout(B),B=null);b.isOpen&&!B&&(B=setTimeout(function(){var c=b.current;c&&!b.isClosing&&(b.wrap.removeClass("fancybox-tmp"),(e||"load"===d||"resize"===d&&c.autoResize)&&b._setDimension(),"scroll"===d&&c.canShrink||b.reposition(a),b.trigger("onUpdate"),B=null)},e&&!s?0:300))},toggle:function(a){b.isOpen&&(b.current.fitToView="boolean"===f.type(a)?a:!b.current.fitToView,s&&(b.wrap.removeAttr("style").addClass("fancybox-tmp"),b.trigger("onUpdate")),b.update())},hideLoading:function(){p.unbind(".loading");f("#fancybox-loading").remove()},showLoading:function(){var a,d;b.hideLoading();a=f('
').click(b.cancel).appendTo("body");p.bind("keydown.loading",function(a){if(27===(a.which||a.keyCode))a.preventDefault(),b.cancel()});b.defaults.fixed||(d=b.getViewport(),a.css({position:"absolute",top:0.5*d.h+d.y,left:0.5*d.w+d.x}))},getViewport:function(){var a=b.current&&b.current.locked||!1,d={x:n.scrollLeft(),y:n.scrollTop()};a?(d.w=a[0].clientWidth,d.h=a[0].clientHeight):(d.w=s&&r.innerWidth?r.innerWidth:n.width(),d.h=s&&r.innerHeight?r.innerHeight:n.height());return d},unbindEvents:function(){b.wrap&&t(b.wrap)&&b.wrap.unbind(".fb");p.unbind(".fb");n.unbind(".fb")},bindEvents:function(){var a=b.current,d;a&&(n.bind("orientationchange.fb"+(s?"":" resize.fb")+(a.autoCenter&&!a.locked?" scroll.fb":""),b.update),(d=a.keys)&&p.bind("keydown.fb",function(e){var c=e.which||e.keyCode,k=e.target||e.srcElement;if(27===c&&b.coming)return!1;!e.ctrlKey&&(!e.altKey&&!e.shiftKey&&!e.metaKey&&(!k||!k.type&&!f(k).is("[contenteditable]")))&&f.each(d,function(d,k){if(1h[0].clientWidth||h[0].clientHeight&&h[0].scrollHeight>h[0].clientHeight),h=f(h).parent();if(0!==c&&!j&&1g||0>k)b.next(0>g?"up":"right");d.preventDefault()}}))},trigger:function(a,d){var e,c=d||b.coming||b.current;if(c){f.isFunction(c[a])&&(e=c[a].apply(c,Array.prototype.slice.call(arguments,1)));if(!1===e)return!1;c.helpers&&f.each(c.helpers,function(d,e){if(e&&b.helpers[d]&&f.isFunction(b.helpers[d][a]))b.helpers[d][a](f.extend(!0,{},b.helpers[d].defaults,e),c)});p.trigger(a)}},isImage:function(a){return q(a)&&a.match(/(^data:image\/.*,)|(\.(jp(e|g|eg)|gif|png|bmp|webp|svg)((\?|#).*)?$)/i)},isSWF:function(a){return q(a)&&a.match(/\.(swf)((\?|#).*)?$/i)},_start:function(a){var d={},e,c;a=l(a);e=b.group[a]||null;if(!e)return!1;d=f.extend(!0,{},b.opts,e);e=d.margin;c=d.padding;"number"===f.type(e)&&(d.margin=[e,e,e,e]);"number"===f.type(c)&&(d.padding=[c,c,c,c]);d.modal&&f.extend(!0,d,{closeBtn:!1,closeClick:!1,nextClick:!1,arrows:!1,mouseWheel:!1,keys:null,helpers:{overlay:{closeClick:!1}}});d.autoSize&&(d.autoWidth=d.autoHeight=!0);"auto"===d.width&&(d.autoWidth=!0);"auto"===d.height&&(d.autoHeight=!0);d.group=b.group;d.index=a;b.coming=d;if(!1===b.trigger("beforeLoad"))b.coming=null;else{c=d.type;e=d.href;if(!c)return b.coming=null,b.current&&b.router&&"jumpto"!==b.router?(b.current.index=a,b[b.router](b.direction)):!1;b.isActive=!0;if("image"===c||"swf"===c)d.autoHeight=d.autoWidth=!1,d.scrolling="visible";"image"===c&&(d.aspectRatio=!0);"iframe"===c&&s&&(d.scrolling="scroll");d.wrap=f(d.tpl.wrap).addClass("fancybox-"+(s?"mobile":"desktop")+" fancybox-type-"+c+" fancybox-tmp "+d.wrapCSS).appendTo(d.parent||"body");f.extend(d,{skin:f(".fancybox-skin",d.wrap),outer:f(".fancybox-outer",d.wrap),inner:f(".fancybox-inner",d.wrap)});f.each(["Top","Right","Bottom","Left"],function(a,b){d.skin.css("padding"+b,w(d.padding[a]))});b.trigger("onReady");if("inline"===c||"html"===c){if(!d.content||!d.content.length)return b._error("content")}else if(!e)return b._error("href");"image"===c?b._loadImage():"ajax"===c?b._loadAjax():"iframe"===c?b._loadIframe():b._afterLoad()}},_error:function(a){f.extend(b.coming,{type:"html",autoWidth:!0,autoHeight:!0,minWidth:0,minHeight:0,scrolling:"no",hasError:a,content:b.coming.tpl.error});b._afterLoad()},_loadImage:function(){var a=b.imgPreload=new Image;a.onload=function(){this.onload=this.onerror=null;b.coming.width=this.width/b.opts.pixelRatio;b.coming.height=this.height/b.opts.pixelRatio;b._afterLoad()};a.onerror=function(){this.onload=this.onerror=null;b._error("image")};a.src=b.coming.href;!0!==a.complete&&b.showLoading()},_loadAjax:function(){var a=b.coming;b.showLoading();b.ajaxLoad=f.ajax(f.extend({},a.ajax,{url:a.href,error:function(a,e){b.coming&&"abort"!==e?b._error("ajax",a):b.hideLoading()},success:function(d,e){"success"===e&&(a.content=d,b._afterLoad())}}))},_loadIframe:function(){var a=b.coming,d=f(a.tpl.iframe.replace(/\{rnd\}/g,(new Date).getTime())).attr("scrolling",s?"auto":a.iframe.scrolling).attr("src",a.href);f(a.wrap).bind("onReset",function(){try{f(this).find("iframe").hide().attr("src","//about:blank").end().empty()}catch(a){}});a.iframe.preload&&(b.showLoading(),d.one("load",function(){f(this).data("ready",1);s||f(this).bind("load.fb",b.update);f(this).parents(".fancybox-wrap").width("100%").removeClass("fancybox-tmp").show();b._afterLoad()}));a.content=d.appendTo(a.inner);a.iframe.preload||b._afterLoad()},_preloadImages:function(){var a=b.group,d=b.current,e=a.length,c=d.preload?Math.min(d.preload,e-1):0,f,g;for(g=1;g<=c;g+=1)f=a[(d.index+g)%e],"image"===f.type&&f.href&&((new Image).src=f.href)},_afterLoad:function(){var a=b.coming,d=b.current,e,c,k,g,h;b.hideLoading();if(a&&!1!==b.isActive)if(!1===b.trigger("afterLoad",a,d))a.wrap.stop(!0).trigger("onReset").remove(),b.coming=null;else{d&&(b.trigger("beforeChange",d),d.wrap.stop(!0).removeClass("fancybox-opened").find(".fancybox-item, .fancybox-nav").remove());b.unbindEvents();e=a.content;c=a.type;k=a.scrolling;f.extend(b,{wrap:a.wrap,skin:a.skin,outer:a.outer,inner:a.inner,current:a,previous:d});g=a.href;switch(c){case "inline":case "ajax":case "html":a.selector?e=f("
").html(e).find(a.selector):t(e)&&(e.data("fancybox-placeholder")||e.data("fancybox-placeholder",f('
').insertAfter(e).hide()),e=e.show().detach(),a.wrap.bind("onReset",function(){f(this).find(e).length&&e.hide().replaceAll(e.data("fancybox-placeholder")).data("fancybox-placeholder",!1)}));break;case "image":e=a.tpl.image.replace("{href}",g);break;case "swf":e='',h="",f.each(a.swf,function(a,b){e+='';h+=" "+a+'="'+b+'"'}),e+='"}(!t(e)||!e.parent().is(a.inner))&&a.inner.append(e);b.trigger("beforeShow");a.inner.css("overflow","yes"===k?"scroll":"no"===k?"hidden":k);b._setDimension();b.reposition();b.isOpen=!1;b.coming=null;b.bindEvents();if(b.isOpened){if(d.prevMethod)b.transitions[d.prevMethod]()}else f(".fancybox-wrap").not(a.wrap).stop(!0).trigger("onReset").remove();b.transitions[b.isOpened?a.nextMethod:a.openMethod]();b._preloadImages()}},_setDimension:function(){var a=b.getViewport(),d=0,e=!1,c=!1,e=b.wrap,k=b.skin,g=b.inner,h=b.current,c=h.width,j=h.height,m=h.minWidth,u=h.minHeight,n=h.maxWidth,p=h.maxHeight,s=h.scrolling,q=h.scrollOutside?h.scrollbarWidth:0,x=h.margin,y=l(x[1]+x[3]),r=l(x[0]+x[2]),v,z,t,C,A,F,B,D,H;e.add(k).add(g).width("auto").height("auto").removeClass("fancybox-tmp");x=l(k.outerWidth(!0)-k.width());v=l(k.outerHeight(!0)-k.height());z=y+x;t=r+v;C=E(c)?(a.w-z)*l(c)/100:c;A=E(j)?(a.h-t)*l(j)/100:j;if("iframe"===h.type){if(H=h.content,h.autoHeight&&1===H.data("ready"))try{H[0].contentWindow.document.location&&(g.width(C).height(9999),F=H.contents().find("body"),q&&F.css("overflow-x","hidden"),A=F.outerHeight(!0))}catch(G){}}else if(h.autoWidth||h.autoHeight)g.addClass("fancybox-tmp"),h.autoWidth||g.width(C),h.autoHeight||g.height(A),h.autoWidth&&(C=g.width()),h.autoHeight&&(A=g.height()),g.removeClass("fancybox-tmp");c=l(C);j=l(A);D=C/A;m=l(E(m)?l(m,"w")-z:m);n=l(E(n)?l(n,"w")-z:n);u=l(E(u)?l(u,"h")-t:u);p=l(E(p)?l(p,"h")-t:p);F=n;B=p;h.fitToView&&(n=Math.min(a.w-z,n),p=Math.min(a.h-t,p));z=a.w-y;r=a.h-r;h.aspectRatio?(c>n&&(c=n,j=l(c/D)),j>p&&(j=p,c=l(j*D)),cz||y>r)&&(c>m&&j>u)&&!(19n&&(c=n,j=l(c/D)),g.width(c).height(j),e.width(c+x),a=e.width(),y=e.height();else c=Math.max(m,Math.min(c,c-(a-z))),j=Math.max(u,Math.min(j,j-(y-r)));q&&("auto"===s&&jz||y>r)&&c>m&&j>u;c=h.aspectRatio?cu&&j
').appendTo(b.coming?b.coming.parent:a.parent);this.fixed=!1;a.fixed&&b.defaults.fixed&&(this.overlay.addClass("fancybox-overlay-fixed"),this.fixed=!0)},open:function(a){var d=this;a=f.extend({},this.defaults,a);this.overlay?this.overlay.unbind(".overlay").width("auto").height("auto"):this.create(a);this.fixed||(n.bind("resize.overlay",f.proxy(this.update,this)),this.update());a.closeClick&&this.overlay.bind("click.overlay",function(a){if(f(a.target).hasClass("fancybox-overlay"))return b.isActive?b.close():d.close(),!1});this.overlay.css(a.css).show()},close:function(){var a,b;n.unbind("resize.overlay");this.el.hasClass("fancybox-lock")&&(f(".fancybox-margin").removeClass("fancybox-margin"),a=n.scrollTop(),b=n.scrollLeft(),this.el.removeClass("fancybox-lock"),n.scrollTop(a).scrollLeft(b));f(".fancybox-overlay").remove().hide();f.extend(this,{overlay:null,fixed:!1})},update:function(){var a="100%",b;this.overlay.width(a).height("100%");I?(b=Math.max(G.documentElement.offsetWidth,G.body.offsetWidth),p.width()>b&&(a=p.width())):p.width()>n.width()&&(a=p.width());this.overlay.width(a).height(p.height())},onReady:function(a,b){var e=this.overlay;f(".fancybox-overlay").stop(!0,!0);e||this.create(a);a.locked&&(this.fixed&&b.fixed)&&(e||(this.margin=p.height()>n.height()?f("html").css("margin-right").replace("px",""):!1),b.locked=this.overlay.append(b.wrap),b.fixed=!1);!0===a.showEarly&&this.beforeShow.apply(this,arguments)},beforeShow:function(a,b){var e,c;b.locked&&(!1!==this.margin&&(f("*").filter(function(){return"fixed"===f(this).css("position")&&!f(this).hasClass("fancybox-overlay")&&!f(this).hasClass("fancybox-wrap")}).addClass("fancybox-margin"),this.el.addClass("fancybox-margin")),e=n.scrollTop(),c=n.scrollLeft(),this.el.addClass("fancybox-lock"),n.scrollTop(e).scrollLeft(c));this.open(a)},onUpdate:function(){this.fixed||this.update()},afterClose:function(a){this.overlay&&!b.coming&&this.overlay.fadeOut(a.speedOut,f.proxy(this.close,this))}};b.helpers.title={defaults:{type:"float",position:"bottom"},beforeShow:function(a){var d=b.current,e=d.title,c=a.type;f.isFunction(e)&&(e=e.call(d.element,d));if(q(e)&&""!==f.trim(e)){d=f('
'+e+"
");switch(c){case "inside":c=b.skin;break;case "outside":c=b.wrap;break;case "over":c=b.inner;break;default:c=b.skin,d.appendTo("body"),I&&d.width(d.width()),d.wrapInner(''),b.current.margin[2]+=Math.abs(l(d.css("margin-bottom")))}d["top"===a.position?"prependTo":"appendTo"](c)}}};f.fn.fancybox=function(a){var d,e=f(this),c=this.selector||"",k=function(g){var h=f(this).blur(),j=d,k,l;!g.ctrlKey&&(!g.altKey&&!g.shiftKey&&!g.metaKey)&&!h.is(".fancybox-wrap")&&(k=a.groupAttr||"data-fancybox-group",l=h.attr(k),l||(k="rel",l=h.get(0)[k]),l&&(""!==l&&"nofollow"!==l)&&(h=c.length?f(c):e,h=h.filter("["+k+'="'+l+'"]'),j=h.index(this)),a.index=j,!1!==b.open(h,a)&&g.preventDefault())};a=a||{};d=a.index||0;!c||!1===a.live?e.unbind("click.fb-start").bind("click.fb-start",k):p.undelegate(c,"click.fb-start").delegate(c+":not('.fancybox-item, .fancybox-nav')","click.fb-start",k);this.filter("[data-fancybox-start=1]").trigger("click");return this};p.ready(function(){var a,d;f.scrollbarWidth===v&&(f.scrollbarWidth=function(){var a=f('
').appendTo("body"),b=a.children(),b=b.innerWidth()-b.height(99).innerWidth();a.remove();return b});if(f.support.fixedPosition===v){a=f.support;d=f('
').appendTo("body");var e=20===d[0].offsetTop||15===d[0].offsetTop;d.remove();a.fixedPosition=e}f.extend(b.defaults,{scrollbarWidth:f.scrollbarWidth(),fixed:f.support.fixedPosition,parent:f("body")});a=f(r).width();J.addClass("fancybox-lock-test");d=f(r).width();J.removeClass("fancybox-lock-test");f("").appendTo("head")})})(window,document,jQuery);(function(d){function e(a){var b=a||window.event,c=[].slice.call(arguments,1),f=0,e=0,g=0,a=d.event.fix(b);a.type="mousewheel";b.wheelDelta&&(f=b.wheelDelta/120);b.detail&&(f=-b.detail/3);g=f;b.axis!==void 0&&b.axis===b.HORIZONTAL_AXIS&&(g=0,e=-1*f);b.wheelDeltaY!==void 0&&(g=b.wheelDeltaY/120);b.wheelDeltaX!==void 0&&(e=-1*b.wheelDeltaX/120);c.unshift(a,f,e,g);return(d.event.dispatch||d.event.handle).apply(this,c)}var c=["DOMMouseScroll","mousewheel"];if(d.event.fixHooks)for(var h=c.length;h;)d.event.fixHooks[c[--h]]=d.event.mouseHooks;d.event.special.mousewheel={setup:function(){if(this.addEventListener)for(var a=c.length;a;)this.addEventListener(c[--a],e,false);else this.onmousewheel=e},teardown:function(){if(this.removeEventListener)for(var a=c.length;a;)this.removeEventListener(c[--a],e,false);else this.onmousewheel=null}};d.fn.extend({mousewheel:function(a){return a?this.bind("mousewheel",a):this.trigger("mousewheel")},unmousewheel:function(a){return this.unbind("mousewheel",a)}})})(jQuery);(function ($) { "use strict"; var F = $.fancybox, format = function( url, rez, params ) { params = params || ''; if ( $.type( params ) === "object" ) { params = $.param(params, true); } $.each(rez, function(key, value) { url = url.replace( '$' + key, value || '' ); }); if (params.length) { url += ( url.indexOf('?') > 0 ? '&' : '?' ) + params; } return url; }; F.helpers.media = { defaults : { youtube : { matcher : /(youtube\.com|youtu\.be|youtube-nocookie\.com)\/(watch\?v=|v\/|u\/|embed\/?)?(videoseries\?list=(.*)|[\w-]{11}|\?listType=(.*)&list=(.*)).*/i, params : { autoplay : 1, autohide : 1, fs : 1, rel : 0, hd : 1, wmode : 'opaque', enablejsapi : 1 }, type : 'iframe', url : '//www.youtube.com/embed/$3' }, vimeo : { matcher : /(?:vimeo(?:pro)?.com)\/(?:[^\d]+)?(\d+)(?:.*)/, params : { autoplay : 1, hd : 1, show_title : 1, show_byline : 1, show_portrait : 0, fullscreen : 1 }, type : 'iframe', url : '//player.vimeo.com/video/$1' }, metacafe : { matcher : /metacafe.com\/(?:watch|fplayer)\/([\w\-]{1,10})/, params : { autoPlay : 'yes' }, type : 'swf', url : function( rez, params, obj ) { obj.swf.flashVars = 'playerVars=' + $.param( params, true ); return '//www.metacafe.com/fplayer/' + rez[1] + '/.swf'; } }, dailymotion : { matcher : /dailymotion.com\/video\/(.*)\/?(.*)/, params : { additionalInfos : 0, autoStart : 1 }, type : 'swf', url : '//www.dailymotion.com/swf/video/$1' }, twitvid : { matcher : /twitvid\.com\/([a-zA-Z0-9_\-\?\=]+)/i, params : { autoplay : 0 }, type : 'iframe', url : '//www.twitvid.com/embed.php?guid=$1' }, twitpic : { matcher : /twitpic\.com\/(?!(?:place|photos|events)\/)([a-zA-Z0-9\?\=\-]+)/i, type : 'image', url : '//twitpic.com/show/full/$1/' }, instagram : { matcher : /(instagr\.am|instagram\.com)\/p\/([a-zA-Z0-9_\-]+)\/?/i, type : 'image', url : '//$1/p/$2/media/?size=l' }, google_maps : { matcher : /maps\.google\.([a-z]{2,3}(\.[a-z]{2})?)\/(\?ll=|maps\?)(.*)/i, type : 'iframe', url : function( rez ) { return '//maps.google.' + rez[1] + '/' + rez[3] + '' + rez[4] + '&output=' + (rez[4].indexOf('layer=c') > 0 ? 'svembed' : 'embed'); } } }, beforeLoad : function(opts, obj) { var url = obj.href || '', type = false, what, item, rez, params; for (what in opts) { if (opts.hasOwnProperty(what)) { item = opts[ what ]; rez = url.match( item.matcher ); if (rez) { type = item.type; params = $.extend(true, {}, item.params, obj[ what ] || ($.isPlainObject(opts[ what ]) ? opts[ what ].params : null)); url = $.type( item.url ) === "function" ? item.url.call( this, rez, params, obj ) : format( item.url, rez, params ); break; } } } if (type) { obj.href = url; obj.type = type; obj.autoHeight = false; } } };}(jQuery));(function(k){if(k.base)return!1;var g=function(){this.version="1.7.1";this.errors=[]};g.prototype={constructor:g,augment:function(a){if(a&&"object"===typeof a){var c=this.constructor.prototype,b;for(b in a)a.hasOwnProperty(b)&&(c[b]=a[b])}return this}};g.prototype.extend=g.prototype;var b=k._b=k.base=new g;b.augment({parseQueryString:function(a){a=a||k.location.search;var c={};a.replace(/([^?=&]+)(=([^&]*))?/g,function(a,b,f,h){c[b]=h});return!1===this.isEmpty(c)?c:!1},isEmpty:function(a){if(a&&"object"===typeof a)for(var c in a)if(a.hasOwnProperty(c))return!1;return!0},listToArray:function(a){return Array.prototype.slice.call(a)},curry:function(a){var c=this;return function(){return a.apply(c,c.listToArray(arguments))}},overrideMethod:function(a,c,b,e){return(a[c]=b).apply(a,this.listToArray(e))},camelCase:function(a){return"string"===typeof a?a.replace(/(-|\s|_)+\w{1}/g,function(a){return a[1].toUpperCase()}):!1},uncamelCase:function(a,c){return"string"===typeof a?(c=c||"-",a.replace(/([A-Z]{1,})/g,function(a){return c+a.toLowerCase()}).toLowerCase()):!1},_createEvent:function(){return this.overrideMethod(this,"_createEvent","CustomEvent"in window?function(a,c,b,e,f){return"HTMLEvents"===b?new Event(c):"MouseEvents"===b?new MouseEvent(c,e):new CustomEvent(c,f)}:"createEventObject"in document?function(a,c,b,e,f){a=document.createEventObject();a.eventType=c;return a}:function(a,c,b,e,f){var d=document.createEvent(b);"HTMLEvents"===b?a.initEvent(c,e.bubbles,e.cancelable):"MouseEvents"===b?d.initMouseEvent(c,e.canBubble,e.cancelable,e.view,e.detail,e.screenX,e.screenY,e.clientX,e.clientY,e.ctrlKey,e.altKey,e.shiftKey,e.metaKey,e.button,e.relatedTarget):"CustomEvent"===b&&d.initCustomEvent(c,e.bubbles,e.cancelable,f);return d},arguments)},createEvent:function(a,c,d,e){if(c&&"object"===typeof c){var f={pointerX:0,pointerY:0,button:0,view:window,detail:1,screenX:0,screenY:0,clientX:0,clientY:0,ctrlKey:!1,altKey:!1,shiftKey:!1,metaKey:!1,bubbles:!0,cancelable:!0,relatedTarget:null};d&&"object"===typeof d&&(f=b.extendObject(f,d));d={HTMLEvents:/^(?:load|unload|abort|error|select|change|submit|reset|focus|blur|resize|scroll)$/,MouseEvents:/^(?:click|dblclick|mouse(?:down|up|over|move|out))$/};var h="CustomEvent",l;for(l in d)if(d.hasOwnProperty(l)&&a.match(d[l])){h=l;break}return this._createEvent(c,a,h,f,e)}return!1},_trigger:function(){return this.overrideMethod(this,"_trigger","createEvent"in document?function(a,c){a.dispatchEvent(c)}:function(a,c){a.fireEvent("on"+c.type,c)},arguments)},trigger:function(a,c,b){c&&"object"===typeof c&&(a="string"===typeof a?this.createEvent(a,c,null,b):a,this._trigger(c,a));return this},mouseWheelEventType:null,getMouseWheelEventType:function(){var a;(a=this.mouseWheelEventType)||(a="wheel","onmousewheel"in k?a="mousewheel":"DOMMouseScroll"in k&&(a="DOMMouseScroll"),a=this.mouseWheelEventType=a);return a},onMouseWheel:function(a,c,b,e){"undefined"===typeof c&&(c=window);var f=this,d=this.getMouseWheelEventType();jQuery(c).on(d,function(c){c=c||window.event;var d=Math.max(-1,Math.min(1,-c.deltaY||c.wheelDelta||-c.detail));"function"===typeof a&&a(d,c);"undefined"!==typeof b&&1==b&&f.preventDefault(c)},e);return this},offMouseWheel:function(a){"undefined"===typeof a&&(a=window);var c=this.getMouseWheelEventType();jQuery(a).off(c)},preventDefault:function(a){a=a||window.event;"function"===typeof a.preventDefault?a.preventDefault():a.returnValue=!1;return this},stopPropagation:function(a){a=a||window.event;"function"===typeof a.stopPropagation?a.stopPropagation():a.cancelBubble=!0;return this},getValue:function(a,c,b){return this.getProperty(a,c,b)},getProperty:function(a,c,b){return a&&"object"===typeof a&&a[c]?a[c]:"undefined"!==typeof b?b:""},getType:function(a){var c=typeof a;"object"===c&&!0===this.isArray(a)&&(c="array");return c},_isArray:function(){return this.overrideMethod(this,"_isArray","function"===typeof Array.isArray?function(a){return Array.isArray(a)}:function(a){return a instanceof Array?!0:!1},arguments)},isArray:function(a){return this._isArray(a)},_inArray:function(){return this.overrideMethod(this,"_inArray","function"===typeof Array.prototype.indexOf?function(a,c,b){return a.indexOf(c,b)}:function(a,c,b){var d=a.length;for(b=isNaN(b)?0:b;b)/i.test(f)?b.innerHTML=f:b.textContent=f);else if("data-"===h.substring(0,5))e.data(h,f);else{var l=typeof f;if("undefined"!==l&&""!=f){var g=h;switch(g){case "class":g="className";break;case "for":g="htmlFor";break;case "readonly":g="readOnly";break;case "maxlength":g="maxLength";break;case "cellspacing":g="cellSpacing";break;case "rowspan":g="rowSpan";break;case "colspan":g="colSpan";break;case "tabindex":g="tabIndex";break;case "cellpadding":g="cellPadding";break;case "usemap":g="useMap";break;case "frameborder":g="frameBorder";break;case "contenteditable":g="contentEditable"}"function"===l?(l=g,"undefined"!==typeof l&&"on"===l.substring(0,2)&&(l=l.substring(2)),g=l,e.on(g,f)):b[g]=f}}}!0===d?this.prepend(c,b):this.append(c,b);return b},createDocFragment:function(){return document.createDocumentFragment()},createTextNode:function(b,a){var c=document.createTextNode(b);a&&this.append(a,c);return c},addElement:function(b,a,c,d,e,f){return this.create(b,{id:a,className:c,innerHTML:d},e,f)},addButton:function(b,a,c,d,e,f,h){a={id:a,className:c,innerHTML:d};"button"===b&&(a.type="button");"function"===typeof e&&(a.onclick=e);return this.create(b,a,f,h)},addCheckbox:function(b,a,c,d,e,f){b={id:b,className:a,type:"checkbox"};"undefined"!==typeof f&&1==f&&(b.onclick=base.stopPropagation);"function"===typeof c&&(b.onchange=c);1==d&&(b.checked=!0);return this.create("input",b,e)},addRadio:function(b,a,c,d,e,f,h,l){b={id:b,name:a,className:c,value:d,type:"radio"};"undefined"!==typeof l&&1==l&&(b.onclick=base.stopPropagation);"function"===typeof e&&(b.onchange=e);1==f&&(b.checked=!0);return this.create("input",b,h)},addInput:function(b,a,c,d,e,f,h,l){b={id:a,className:c,value:d,type:b};b.onfocus=g;"function"===typeof e&&(e=base.createCallBack(null,e,[this.value]),b.onkeyup=e);f&&(b.placeholder=f);return this.create("input",b,h,l)},addTextarea:function(b,a,c,d,e,f){b={id:b,className:a,value:c};b.onfocus=g;"function"===typeof d&&(b.onblur=d,b.onkeyup=d);return this.create("textarea",b,e,f)},addSelect:function(b,a,c,d,e,f){var h={id:b,className:a,value:c};"function"===typeof d&&(h.onchange=function(){d.call(null,this.value);e=h=null});return this.create("select",h,e,f)},setupSelectOptions:function(b,a,c){if(null!==b&&("object"!==typeof b&&(b=document.getElementById(b)),a&&a.length))for(var d=0,e=a.length;d= 0) { this.objects.splice(indexNumber, 1); } } } } }, stopTimer: function(animation) { if(animation) { var timer = animation.timer; window.clearTimeout(timer); } }, checkAnimating: function(obj) { var animationArray = []; for(var i = 0, maxLength = this.objects.length; i < maxLength; i++) { var animation = this.objects[i]; if(animation.object === obj) { animationArray.push(animation); } } return (animationArray.length >= 1)? animationArray : false; }, stopPreviousAnimations: function(obj) { this.removeObject(obj, 1); }, reset: function() { this.objects = []; } }, setupSelectingObject: function(object) { return (typeof object === 'string')? document.getElementById(object) : object; }, hide: function(object, animationClass, duration) { var obj = this.setupSelectingObject(object); jQuery(obj).addClass(animationClass); var callBack = base.createCallBack(null, removeClassAndHide, [obj, animationClass]); var timer = window.setTimeout(callBack, duration); this.animating.add(obj, animationClass, timer); }, show: function(object, animationClass, duration) { var obj = this.setupSelectingObject(object); jQuery(obj).addClass(animationClass); obj.style.display = 'block'; var callBack = base.createCallBack(null, removeAnimationClass, [obj, animationClass]); var timer = window.setTimeout(callBack, duration); this.animating.add(obj, animationClass, timer); }, set: function(object, animationClass, duration) { var obj = this.setupSelectingObject(object); jQuery(obj).addClass(animationClass); var callBack = base.createCallBack(null, removeAnimationClass, [obj, animationClass]); var timer = window.setTimeout(callBack, duration); this.animating.add(obj, animationClass, timer); } };(function(bpApp){ "use strict"; var Navigation = function(scrollContainer, container) { this.init(); this.scrollContainer = scrollContainer; this.container = container; }; base.Component.extend( { constructor: Navigation, setup: function() { this.setupCurrentPage(); this.setupNav(); this.groups.selectPrimaryGroup(); }, setupGroups: function(optionsArray) { var self = this; this.groups = { lastSelectedGroup: null, options: [], createPanel: function() { var buttonBack = self.addButton('button', self.id + '_button_back', 'bttn back', '', '', 'main-nav-container'); }, addGroup: function(level, parent) { var container = self.scrollContainer, style = (level === 0)? 'primary' : 'sub-menu', number = (this.options.length); var groupPanel = self.addElement('div', self.id + '_nav_' + number + level, 'group-nav-container', '', self.scrollContainer); var navContainer = self.addElement('nav', self.id + '_nav_container', 'main-nav-container', '', groupPanel); var ul = self.addElement('ul', self.id + '_nav_ul_' + number + level, 'dropdown-menu ' + style, '', navContainer); var group = { level: level, parent: parent, element: groupPanel, list: ul, options: [], selected: false }; this.options.push(group); return group; }, reset: function() { this.lastSelectedGroup = null; this.options = []; this.optionNumber = 0; }, createGroup: function(optionsArray, level, parent) { level = level || 0; var group = this.addGroup(level, parent); var selected = false; if(typeof optionsArray !== 'undefined') { for(var i = 0, maxLength = optionsArray.length; i < maxLength; i++) { var element = optionsArray[i]; if(element) { var childOptions = element.querySelectorAll('.' + jQuery(element).data('id') + ' > ul > li'); var option = { element: element, number: this.optionNumber++, selected: 'no', pages: childOptions.length }; var childSelected = false; if(childOptions.length) { var data = this.createGroup(childOptions, (level + 1), group); childSelected = data.selected; group.options = childOptions; } option.child = (data)? data.group : null; var li = this.addOption(option, group.list, childSelected); if(selected !== true && option.selected === 'yes') { selected = true; } } } } return { group: group, selected: selected }; }, setup: function(optionsArray) { this.createPanel(); this.createGroup(optionsArray); }, createCallBack: function(group) { return base.createCallBack(this, this.selectGroup, [group]); }, selectGroup: function(group) { if(group && typeof group === 'object') { if(group.selected === false) { group.selected = true; this.selectGroupPanel(group); this.updateBackButton(group); this.lastSelectedGroup = group; } } }, selectPrimaryGroup: function() { var groups = this.options; if(groups.length) { this.selectGroup(groups[0]); } }, getAnimationClass: function(lastNum, currentNum) { var animation = { selecting: 'pullRightIn', removing: 'pullLeft' }; if(lastNum === null) { animation.removing = 'no-change'; animation.selecting = 'no-change'; } else if(currentNum > lastNum) { animation.removing = 'pullLeft'; animation.selecting = 'pullRightIn'; } else if(currentNum < lastNum) { animation.removing = 'pullRight'; animation.selecting = 'pullLeftIn'; } return animation; }, selectGroupPanel: function(group) { var groups = this.options; var groupNumber = group.level; var lastOption = this.lastSelectedGroup, lastGroupNumber = (lastOption && typeof lastOption !== 'undefined')? lastOption.level: null, animations = this.getAnimationClass(lastGroupNumber, groupNumber); for(var i = 0, maxLength = groups.length; i < maxLength; i++) { var option = groups[i], panel = option.element; if(panel && group.element) { if(panel === group.element) { panel.style.zIndex = 5; var animationClass = animations.selecting; bpApp.animate.show(panel, animationClass, 800); } else { if(option === lastOption) { panel.style.zIndex = 4; var animationClass = animations.removing; bpApp.animate.hide(panel, animationClass, 1000); } else { panel.style.zIndex = 2; bpApp.animate.hide(panel, 'none', 0); } option.selected = false; } } } }, updateBackButton: function(group) { var button = document.getElementById(self.id + '_button_back'); if(group && typeof group.parent !== 'undefined') { button.onclick = base.createCallBack(this, this.selectGroup, [group.parent]); button.style.visibility = 'visible'; } else { button.style.visibility = 'hidden'; } }, optionNumber: 0, addOption: function(option, container, childSelected) { container.appendChild(option.element); option.selected = (childSelected === true)? 'yes' : self.checkSelection(option); return this.addNavOption(option, container); }, addNavOption: function(option, container) { var element = option.element; if(option.selected === 'yes') { jQuery(element).addClass('selected'); } if(option.pages && option.child) { var a = element.querySelector('a'); if(a) { var callBack = this.createCallBack(option.child); a.onclick = function(e) { e.preventDefault(); callBack(); }; } } return option; } }; this.groups.setup(optionsArray); }, setupNav: function() { var currentPage = this.getCurrentPage(); var options = document.querySelectorAll('#' + this.scrollContainer + ' nav > ul > li'); this.setupGroups(options); }, checkSelection: function(option) { var currentPage = this.currentPage; currentPage = currentPage.split('&')[0]; var url = (typeof option.url === 'string')? option.url.replace('/', '') : null; if(url) { if(currentPage === url) { return 'yes'; } else if(!currentPage && url == '') { return 'yes'; } else if(currentPage === 'blog-post' && url === 'blog') { return 'yes'; } else { return 'no'; } } }, getCurrentPage: function() { var path = window.location.pathname; var pattern = /\//g; var pageSlashCount = path.match(pattern); if(pageSlashCount.length > 1) { var start = path.indexOf("/") + 1; var length = path.indexOf("/", 2) + 1; var end = length - start; var tmpLocation = path.substring(start, end); } else { var tmpLocation = path.substring(path.lastIndexOf("/") + 1); } return tmpLocation.replace("/", ""); }, setupCurrentPage: function() { this.currentPage = this.getCurrentPage(); }, getOptionStyle: function(tmpOption) { var optionStyle = (tmpOption.selected === 'yes')? 'nav-option selected' : 'nav-option'; return optionStyle; }, resetContainer: function() { var container = document.getElementById(this.container); if(container) { container.innerHTML = ''; } } }); bpApp.navigation = Navigation; })(bpApp); (function(bpApp){ "use strict"; var SlideController = function(container, onNumber, defaultPathUrl) { this.init(); this.animationMode = 'fade'; this.defaultPathUrl = (defaultPathUrl)? defaultPathUrl : '/slideshow/'; this.lastSelectedOption = null; this.onNumber = typeof onNumber !== 'undefined' ? onNumber: 0; this.optionsArray = []; this.timer = null; this.container = container; }; base.Component.extend( { constructor: SlideController, addKeyboardSupport: function() { var self = this; jQuery(document).on('keydown', function(e){ self.keyPress(e); }); }, keyPress: function(e) { var keyCode = e.keyCode; switch(keyCode) { case 37: this.selectPreviousOption(); break; case 39: this.selectNextOption(); break; } }, addOption: function(element) { var options = this.optionsArray; var number = options.length; var option = { optionNumber: number, element: element, crumbId: this.id + '_crumb_number_' + number, selected: 'no', setup: false }; options.push(option); this.createCrumb(option); return option; }, resetContainer: function() { var container = document.getElementById(this.container); container.innerHTML = ''; }, setup: function() { this.setupControlPanel(); this.setupOptions(); this.addKeyboardSupport(); }, setupControlPanel: function() { var self = this; var container = this.container; var containerEle = typeof container !== 'object'? document.getElementById(container) : container; var button = this.addButton('a', '', 'arrow arrow_left', '', function(){ self.selectPreviousOption(); }, containerEle); button = this.addButton('a', '', 'arrow arrow_right', '', function(){ self.selectNextOption(); }, containerEle); var numberContainer = this.addElement('div', this.id + '_crumb_container', 'number_crumb_container', '', containerEle); this.addElement('div', this.id + '_slide_tab', 'slideTab', '', numberContainer); containerEle.onmouseover = base.createCallBack(this, this.stopTimer); containerEle.onmouseout = base.createCallBack(this, this.startTimer); }, selectPrimaryOption: function() { if(typeof this.onNumber !== 'undefined') { this.selectOptionByNumber(this.onNumber); } else { this.selectNewPanel(); } }, setupOptions: function() { var container = typeof this.container === 'object'? this.container : document.getElementById(this.container); if(!container) { return false; } var optionsArray = container.querySelectorAll('.splash_container'); var maxLength = optionsArray.length; if(maxLength > 0) { for(var i = 0; i < maxLength; i++) { var tmpOption = this.addOption(optionsArray[i]); } } this.selectPrimaryOption(); }, loadSlideSrc: function(option) { if(option.setup === false) { option.setup = true; var path = this.defaultPathUrl || '', element = jQuery(option.element), src = element.data('bg-src'); if(src) { element.css('background-image', 'url(' + path + src + ')'); } else { src = element.data('src'); if(src) { var img = element.find('.image_container > img'); img.attr('src', path + src); } } } }, getAnimation: function() { var animations = ['pullLeftIn', 'pullRightIn']; var animationNumber = Math.round(Math.random() * (animations.length - 1)); return animations[animationNumber]; }, createCrumb: function(tmpOption) { var self = this; var crumbContainer = this.id + '_crumb_container'; var optionClass = this.getCrumbClass(tmpOption); var option = this.addButton('div', tmpOption.crumbId, optionClass, tmpOption.crumbContent, function(){ self.selectOption(tmpOption); }, crumbContainer); }, getCrumbClass: function(tmpOption) { return (tmpOption.selected === 'yes')? 'option selected' : 'option'; }, selectNewPanel: function() { if(this.onNumber < (this.optionsArray.length - 1) && this.onNumber != null) { this.onNumber++; } else { this.onNumber = 0; } this.selectOptionByNumber(this.onNumber); }, getPanelClass: function(lastNum, currentNum) { var animation = { selecting: 'same', removing: '' }; var mode = this.animationMode || 'fade'; if(mode === 'left_right') { if(currentNum > lastNum) { animation.removing = 'pullLeft'; animation.selecting = 'pullRightIn'; } else if(currentNum < lastNum) { animation.removing = 'pullRight'; animation.selecting = 'pullLeftIn'; } } else { animation.removing = 'fadeOut'; animation.selecting = 'fadeIn'; } return animation; }, getPanelAnimations: function() { var selection = this.getSelectedOption(); var panelNumber = selection.optionNumber; var lastPanelNumber = (typeof this.lastSelectedOption !== 'undefined')? jQuery.inArray(this.lastSelectedOption, this.optionsArray): 0; return this.getPanelClass(lastPanelNumber, panelNumber); }, selectPanel: function(tmpOption) { var animations = this.getPanelAnimations(); var options = this.optionsArray; for(var i = 0, maxLength = options.length; i < maxLength; i++) { var option = options[i], panel = option.element; if(panel) { var panelStyle = panel.style; if(tmpOption.element === panel) { this.loadSlideSrc(option); panelStyle.zIndex = 2; panelStyle.position = (this.setAsBg === true)? 'absolute' : 'relative'; bpApp.animate.show(panel, animations.selecting, 1000); } else { var lastSelected = this.lastSelectedOption; if(lastSelected && lastSelected.element === panel) { panelStyle.zIndex = 1; panelStyle.position = 'absolute'; panelStyle.top = '0px'; bpApp.animate.hide(panel, animations.removing, 1000); } } } var crumbId = option.crumbId; if(typeof crumbId !== 'undefined') { var crumbClass = this.getCrumbClass(option), crumb = document.getElementById(crumbId); if(crumb) { crumb.className = crumbClass; } } } }, getNextOption: function() { var lastSelectedOption = (this.lastSelectedOption !== null)? this.lastSelectedOption.optionNumber : 0; var nextOptionNumber = ++lastSelectedOption; var index = (nextOptionNumber < this.optionsArray.length)? nextOptionNumber : 0; return this.optionsArray[index]; }, selectNextOption: function() { var nextOption = this.getNextOption(); if(nextOption) { this.selectOption(nextOption); } }, getPreviousOption: function() { var lastSelectedOption = (this.lastSelectedOption !== null)? this.lastSelectedOption.optionNumber : 0; var previousOptionNumber = --lastSelectedOption; var index = (previousOptionNumber >= 0)? previousOptionNumber : (this.optionsArray.length - 1); return this.optionsArray[index]; }, selectPreviousOption: function() { var previousOption = this.getPreviousOption(); if(previousOption) { this.selectOption(previousOption); } }, setLastSelectedOption: function(option) { this.lastSelectedOption = option; }, unselectOption: function(tmpOption) { for(var j = 0, maxLength = this.optionsArray.length; j < maxLength; j++) { var option = this.optionsArray[j]; if(option !== tmpOption) { if(option.selected === 'yes') { option.selected = 'no'; } } } }, moveSlideTab: function(e) { var offset = jQuery(e).position(); var slideTab = jQuery('#' + this.id + '_slide_tab').css('left', offset.left + 'px'); }, selectOption: function(tmpOption) { this.stopTimer(); var object = tmpOption.element; var slideTab = document.getElementById(tmpOption.crumbId); if(slideTab) { this.moveSlideTab(slideTab); } if(tmpOption.selected === 'no') { tmpOption.selected = 'yes'; this.onNumber = jQuery.inArray(tmpOption, this.optionsArray); } else { tmpOption.selected = 'no'; } this.unselectOption(tmpOption); this.selectPanel(tmpOption); this.setLastSelectedOption(tmpOption); this.startTimer(); }, selectOptionByNumber: function(index) { var option = this.optionsArray[index]; if(option) { this.selectOption(option); } }, getSelectedOption: function() { for(var j = 0, maxLength = this.optionsArray.length; j < maxLength; j++) { var option = this.optionsArray[j]; if(option.selected === 'yes') { return option; } } return false; }, duration: 7000, startTimer: function() { var self = this; this.stopTimer(); this.timer = window.setTimeout(function(){ self.selectNewPanel(); }, this.duration); }, stopTimer: function() { window.clearTimeout(this.timer); } }); var SlideShow = function(container, defaultPathUrl, setAsBg, onNumber) { this.init(); this.defaultPathUrl = (defaultPathUrl)? defaultPathUrl : '/slideshow/'; this.setAsBg = (setAsBg)? setAsBg : false; this.animationMode = 'fade'; this.lastSelectedOption = null; this.onNumber = typeof onNumber !== 'undefined' ? onNumber: null; this.optionsArray = []; this.timer = null; this.container = container; }; SlideController.extend( { constructor: SlideShow, addOption: function(option) { var number = this.optionsArray.length; option.optionNumber = number; option.crumbId = this.id + '_crumb_number_' + number; option.selected = 'no'; this.optionsArray.push(option); this.createCrumb(option); option.element = this.createOptionPanel(option,this.container); }, setupOptions: function(optionsArray) { var maxLength = optionsArray.length; if(maxLength > 0) { var tmpNumber = 0; for(var i = 0; i < maxLength; i++) { var tmpOption = optionsArray[i]; this.addOption(tmpOption); } } this.selectPrimaryOption(); }, setup: function(optionsArray) { this.resetContainer(); this.setupControlPanel(); this.setupOptions(optionsArray); this.addKeyboardSupport(); }, createOptionPanel: function(tmpOption, container) { if(tmpOption && tmpOption.url) { container = this.addLink('a','','','',tmpOption.url,container); } var spotlightContainer = this.addElement('div', '', 'splash_container', '', container); spotlightContainer.onmouseover = base.createCallBack(this, this.stopTimer); spotlightContainer.onmouseout = base.createCallBack(this, this.startTimer); spotlightContainer.style.display = 'none'; var imageURL = tmpOption.image; if(this.setAsBg == true) { if(imageURL) { spotlightContainer.style.backgroundImage = 'url(' + wpThemeUrl + this.defaultPathUrl + imageURL + ')'; } } else { if(imageURL) { var imageContainer = this.addElement('div','','image_container','',spotlightContainer); var image = this.addImage('','',wpThemeUrl + this.defaultPathUrl + imageURL,tmpOption.alt,imageContainer); } } var articleContainer = this.addElement('article', '', 'content_container ' + tmpOption.className, '', spotlightContainer); var animation = this.getAnimation(); var sectionContainer = this.addElement('section', '', 'spotlight dark ' + animation, '', articleContainer); var h2 = this.addElement('h2', '', 'title_text blue', tmpOption.title, sectionContainer); var text = this.addElement('div', '', 'light', tmpOption.content, sectionContainer); return spotlightContainer; } }); var OfficeSlideController = function(container, onNumber) { this.init(); this.animationMode = 'fade'; this.lastSelectedOption = null; this.onNumber = typeof onNumber !== 'undefined' ? onNumber: 0; this.optionsArray = []; this.timer = null; this.container = container; }; SlideController.extend( { constructor: OfficeSlideController, getPanelClass: function(lastNum, currentNum) { var animation = { selecting: 'same', removing: '' }; var mode = this.animationMode || 'fade'; if(mode === 'left_right') { if(currentNum > lastNum) { animation.removing = 'pullLeft'; animation.selecting = 'pullRightIn'; } else if(currentNum < lastNum) { animation.removing = 'pullRight'; animation.selecting = 'pullLeftIn'; } } else { animation.removing = 'fadeOut'; animation.selecting = 'slideDown'; } return animation; }, getAnimation: function() { var animations = ['pullLeftIn', 'pullRightIn']; var animationNumber = Math.round(Math.random() * (animations.length - 1)); return animations[animationNumber]; } }); bpApp.slideController = SlideController; bpApp.slideShow = SlideShow; window.spotlightPanel = SlideShow; bpApp.officeSlideController = OfficeSlideController; })(bpApp); (function(bpApp){ "use strict"; var LazyAnimator = function(attrName, cacheElements) { this.attrName = (typeof attrName === 'string')? attrName : 'data-animate'; this.cacheElements = cacheElements === true? true : false; this.elements = []; this.setup(); }; base.Class.extend( { constructor: LazyAnimator, setup: function() { this.setupEvents(); this.update(); return this; }, update: function() { this.elements = this.getElements(); this.checkScroll(); return this; }, removeElement: function(element) { var index = jQuery.inArray(element, this.elements); if(index > -1) { this.elements.splice(index, 1); } return this; }, getElements: function() { return jQuery('[' + this.attrName + ']:not(.animated)'); }, checkScroll: function() { var optionsArray = (this.cacheElements === true)? this.elements : this.getElements(); if(optionsArray.length) { var viewPortTop = jQuery(document).scrollTop(); var viewPortBottom = jQuery(window).height() + viewPortTop; var self = this; optionsArray.each(function(index, ele) { ele = jQuery(this); if(ele) { var optionDelay = ele.data('delay'); var delay = optionDelay !== null? optionDelay : 20; var position = ele.offset(); var optionTop = position.top + delay; var optionBottom = position.top + ele.height(); if(optionTop < viewPortBottom && optionTop >= viewPortTop) { self.animate(ele); } else if(optionBottom >= viewPortTop && optionBottom <= viewPortBottom) { self.animate(ele); } } }); } return this; }, animate: function(ele) { var animation = ele.attr(this.attrName); animation = animation || 'pullUp'; ele.addClass(animation); ele.addClass('animated'); this.removeElement(ele); return this; }, setupEvents: function() { var ele = jQuery(window); var self = this; var callBack = function() { self.checkScroll(); }; this.addEvents = function() { ele.on('scroll', callBack); }; this.removeEvents = function() { ele.off('scroll', callBack); }; this.addEvents(); return this; } }); bpApp.lazyAnimator = LazyAnimator; })(bpApp); (function(bpApp){ "use strict"; var ScrollHeader = function(header, miniHeaderClass, distance) { this.header = (typeof header === 'string')? document.getElementById(header) : header; this.$header = jQuery(this.header); this.miniClassName = miniHeaderClass; this.headerMinified = false; this.distance = (typeof distance !== 'undefined')? distance : 300; this.$document = jQuery(document); this.$window = jQuery(window); this.setup(); }; base.Class.extend( { constructor: ScrollHeader, setup: function() { var header = this.header; if(!header) { return false; } this.checkScroll(); this.addScroll(); }, addScroll: function() { var child = this; var tmpFunction = function(){ child.checkScroll(); }; var win = this.$window; win.on('scroll', tmpFunction); win.on('resize', tmpFunction); }, checkScroll: function() { var wind = this.$window; var scrollTop = wind.scrollTop(), documentHeight = (this.$document.height() - wind.height()); if(scrollTop >= this.distance) { if(this.headerMinified === false) { this.$header.addClass(this.miniClassName); this.headerMinified = true; } } else { if(this.headerMinified === true) { this.headerMinified = false; this.$header.removeClass(this.miniClassName); } } }, scrollToTop: function() { window.scrollTo(window.scrollX, 0); } }); bpApp.scrollHeader = ScrollHeader; })(bpApp); "use strict"; var Modal = function(container){ this.init(); this.container = container; }; base.Component.extend( { constructor: Modal, getLayout: function() { return this.cache('panel', { id: this.id, className: 'modal ' + this.modalClassName, header: this.addHeader(), body: this.addBody(), footer: this.addFooter() }); }, modalClassName: '', addHeader: function() { var id = this.id; return this.cache('titleContainer', { node: 'header', id: id + '_title_container', className: 'title-container', titleButtonGroup: { id: id + '_title_button_group', className: 'title-button-group', close: { node: 'button', className: 'title-bttn close', innerHTML: '', click: base.bind(this, this.decline) } }, titleLabel: { node: 'h4', id: id + '_title', className: 'title dark', textContent: this.getTitle() } }); }, addBody: function() { return this.cache('bodyContainer', { className: 'body-container', body: this.addBodyContent() }); }, addContentPanel: function(title, childeren) { return { title: { node: 'h2', className: 'left dark', textContent: title }, panel: { className: 'content-panel', children: childeren } }; }, addBodyContent: function() { return { panel: this.addContentPanel('Title', [ ]) }; }, addFooter: function() { var id = this.id; return { node: 'footer', id: id + '_button_container', className: 'button-container', buttons: this.addFooterButtons() }; }, addFooterButton: function(id, className, label, callBack) { var buttonAttr = { className: 'bttn ' + className, textContent: label, onclick: callBack }; if(id) { buttonAttr.id = this.id + id; } return buttonAttr; }, addFooterButtons: function() { return [ this.addFooterButton('_button_1', 'bttn-red', 'Cancel', base.bind(this, this.decline)), this.addFooterButton('_button_2', 'bttn-green', 'Save', base.bind(this, this.accept)) ]; }, getTitle: function() { return 'Edit Panel'; }, remove: function() { var panel = this.panel; if(panel) { this.removeElement(panel); } panel = document.getElementById(this.id + '_shadow'); if(panel) { this.removeElement(panel); } }, setup: function() { this.render(); this.setupHeaderOptions(); }, setupHeaderOptions: function() { }, checkToClose: function() { this.decline(); }, createShadow: function() { var self = this; this.addButton('div', this.id + '_shadow', 'modal-shadow fadeIn', '', function(){self.checkToClose();}, self.container); }, returnCallBack: function(data) { var callBack = this.callbackFunction; if(typeof callBack === 'function') { callBack(data); } }, removeAndCallBack: function(data) { this.returnCallBack(data); window.setTimeout(base.bind(this, this.display), 200); }, accept: function() { this.removeAndCallBack(); }, decline: function() { this.display(); }, display: function() { this.toggleDisplay(); if(this.toggleMode === 'block') { } }, toggleMode: null, toggleDisplay: function() { var obj = this.panel, display = obj.style.display; if(display === '' || display === 'none') { obj.style.display = 'block'; this.toggleMode = 'block'; this.createShadow(); } else { obj.style.display = 'none'; this.toggleMode = 'none'; this.remove(); } } });"use strict"; var ModalFormPanel = function(container){ Modal.call(this); this.container = container || document.body; }; Modal.extend( { constructor: ModalFormPanel, addBody: function() { return this.cache('bodyContainer', { className: 'body-container', form: this.cache('form', this.addMainForm( this.addBodyContent() )) }); }, addMainForm: function(body) { return { node: 'form', id: this.id + '_form', method: 'POST', autocomplete: 'off', novalidate: true, body: body }; }, addBodyContent: function() { }, setupValidation: function() { BpFormValidator.monitor(jQuery(this.form)); }, addToggle: function() { var id = this.id + '_check'; return { className: 'data-toggle-panel', field: this.addInput('checkbox', 'Current Patient', '', '', 'toggle', id), label: { node: 'label', className: 'toggle-bttn', htmlFor: id } }; }, addRow: function(className, cols) { return { className: 'row ' + className, children: cols }; }, addInput: function(type, name, placeholder, value, className, id) { var layout = { node: 'input', type: type, name: name, autocomplete: 'off', value: value, className: className }; if(placeholder != '') { layout.placeholder = placeholder; } if(id != '') { layout.id = id; } return layout; }, addTextarea: function(name, placeholder, className) { return { node: 'textarea', name: name, autocomplete: 'off', placeholder: placeholder, className: className }; }, setup: function() { this.render(); this.setupHeaderOptions(); this.setupToggleEvent(); this.setupValidation(); }, setupToggleEvent: function() { var $element = jQuery(this.form).find("input.toggle"); $element.val("No"); $element.on('change', function() { if($element.is(':checked')) { $element.val('Yes'); } else { $element.val("No"); } }); }, addCol: function(colSpan, label, inputAttr) { var layout = { className: 'col-xs-' + colSpan }; if(label != '') { layout.lable = { node: 'label', textContent: label }; } layout.input = inputAttr; return layout; }, decline: function() { var form = this.form; if(form) { form.reset(); var $form = jQuery(form); $form.removeClass('form_failure'); $form.find('input, select, textarea').each(function() { var $element = jQuery(this); $element.removeClass('success_val'); $element.removeClass('error_val'); }); } this.display(); }});"use strict"; var ModalAppointmentRequest = function(container){ ModalFormPanel.call(this); }; ModalFormPanel.extend( { constructor: ModalAppointmentRequest, modalClassName: 'appointment-request', addBodyContent: function() { var self = this; var date = new Date().toISOString().slice(0, 10); return { children: [ this.addRow('', [ this.addCol('6', '', this.addInput('text', 'Name', 'Name:', '', 'name val field_text') ), this.addCol('6', '', this.addInput('text', 'Phone', 'Phone:', '', 'telephone val field_phone') ) ]), this.addRow('', [ this.addCol('12', '', this.addInput('text', 'Email', 'Email:', '', 'email val field_email') ) ]), this.addRow('', [ this.addCol('6', 'Preferred Date', this.addInput('date', 'Preferred Date', '', date, '') ), this.addCol('6', 'Preferred Time', this.addInput('text', 'time', '', '09:00:00', '') ) ]), this.addRow('', [ this.addCol('12', '', this.addTextarea('Message', 'Message:', '', 'val message') ) ]), this.addRow('radiobtns', [ { className: 'col-xs-12', toggle: this.addToggle(), text: { node: 'p', className: 'current_patient', textContent: 'Are you a current patient?' } } ]), this.addRow('text-right', [ { className: 'col-xs-12', link: { node: 'button', className: 'send_button transition', textContent: 'Submit', click: function(e) { e.preventDefault(); var form = self.form; jQuery(form).submit(); } } } ]), this.addInput('text', 'URL', '', '', 'honey'), this.addInput('hidden', 'the_reason', '', 'appoint_request', 'the_reason', 'the_reason'), this.addInput('hidden', 'bpi_form_id', '', 'appoint_request'), this.addInput('hidden', 'bpi_form_name', '', 'Appointment Request'), this.addInput('hidden', 'exclude_fields', '', 'the_reason,bpi_form_id,bpi_form_name'), { innerHTML: '
Your request has been sent -- we will be in contact with you shortly.
Please make sure ALL fields are filled out correctly.
' } ] }; }, addFooter: function() { return {}; }, getTitle: function() { return 'Request An Appointment'; } });(function(bpApp){ "use strict"; var VideoPanel = function(video, callbackFunction, container) { this.init(); this.video = video; this.callbackFunction = callbackFunction; this.container = container; }; base.Component.extend( { constructor: VideoPanel, remove: function() { var panel = document.getElementById(this.id); if(panel) { panel.parentNode.removeChild(panel); } panel = document.getElementById(this.id + '_shadow'); if(panel) { panel.parentNode.removeChild(panel); } }, render: function() { var panel = this.addElement('div', this.id, 'panel video-panel slideIn', '', this.container); var title = this.addElement('div', this.id + '_title_container', 'title-container', '', this.id); var titleLabel = this.addElement('h1', '', 'title title-text left dark', this.video.title, title); var container = this.addElement('div', '', 'body-container', '', this.id); var self = this; window.setTimeout(function(){ self.addIframe(self.id + '_iframe', '', self.video.source, container); }, 500); var buttons = this.addElement('div', this.id + '_button_container', 'button-container', '', this.id); var button1 = this.addElement('button', this.id + '_button_1', 'bttn bttn-decline', 'Close', function(){ self.decline(); }, buttons); }, setup: function() { this.render(); }, decline: function() { this.display(); }, display: function() { this.toggleDisplay(); }, createShadow: function() { var self = this; var backdrop = this.addButton('div', this.id + '_shadow','panel-shadow video-shadow fadeIn','', function(){ self.decline(); }, document.body); this.addButton('button', '', 'bttn top close', '', '', backdrop); }, toggleMode: null, toggleDisplay: function() { var obj = document.getElementById(this.id); var display = obj.style.display; if(!display || display === 'none') { obj.style.display = 'block'; this.toggleMode = 'block'; this.createShadow(); } else { obj.style.display = 'none'; this.toggleMode = 'none'; this.remove(); } } }); bpApp.videoPanel = VideoPanel; })(bpApp); "use strict"; var bpMain = { setupAppDefault: function() { this.Navigation.setup(); this.Videos.setup(); this.Services.setup(); this.Modals.setup(); this.setupFancyBox(); this.setupAutoScroll(); this.setupPeekThrough(); }, setupFancyBox: function() { jQuery(".pics").fancybox({ openEffect:'elastic', closeEffect:'elastic', helpers: { overlay : { locked: false } } }); jQuery(".videos").click(function() { jQuery.fancybox({ openEffect:'elastic', closeEffect:'elastic', helpers: { overlay : { locked: false } }, 'padding' : 0, 'autoScale' : false, 'transitionIn' : 'none', 'transitionOut' : 'none', 'title' : this.title, 'width' : 680, 'height' : 495, 'href' : this.href.replace(new RegExp("watch\?v=", "i"), 'v/'), 'type' : 'swf', 'swf' : { 'wmode' : 'transparent', 'allowfullscreen' : 'true' } }); return false; }); }, exceptions: ['myModal'], addException: function(exception) { this.exceptions.push(exception); }, setupAutoScroll: function() { var exceptions = this.exceptions; var pattern = /^\//; jQuery('a[href*="#"]:not([href="#"])').click(function() { if (location.pathname.replace(pattern,'') === this.pathname.replace(pattern,'') && location.hostname === this.hostname) { var hash = this.hash.slice(1), index = jQuery.inArray(hash, exceptions); if(index === -1) { var target = jQuery(this.hash); target = target.length ? target : jQuery('[id=' + hash +']'); if (target.length) { jQuery('html,body').animate({ scrollTop: target.offset().top }, 800); return false; } } } }); }, mapsSetup: false, setupGoogleMaps: function(attrName) { attrName = attrName || 'data-map-src'; jQuery('iframe[' + attrName + ']').each(function(index, element) { element = jQuery(element); var src = element.attr(attrName); if(src) { element.addClass('fadeIn'); element.attr('src', src); } }); }, setupCoolMap: function() { var self = this; jQuery('.map-overlay').click(function() { if(self.mapsSetup !== true) { self.setupGoogleMaps(); self.mapsSetup = true; } jQuery(this).fadeOut(); }); jQuery('.map-area').mouseleave(function() { jQuery('.map-overlay').fadeIn(); }); }, setupPeekThrough: function() { var $elements = jQuery('section[data-type="background"]'); if($elements[0]) { var $win = jQuery(window); $win.scroll(function() { var winScrollTop = $win.scrollTop(); $elements.each(function() { var $bgobj = jQuery(this); var yPos = -(winScrollTop / $bgobj.data('speed')); var coords = '50% '+ yPos + 'px'; $bgobj.css({ backgroundPosition: coords }); }); }); } }}; bpMain.Services = { setup: function() { var IframeLoader = function(id) { this.id = id; this.element = null; this.document = null; }; IframeLoader.prototype = { constructor: IframeLoader, setup: function() { this.element = document.getElementById(this.id); if(this.element) { this.addEvents(); } }, getDocument: function() { var ifrm = this.element; if(this.document === null && ifrm) { this.document = ifrm.contentDocument? ifrm.contentDocument : ifrm.contentWindow.document; } return this.document; }, setHeight: function() { var getHeight = function(doc) { var body = doc.body, html = doc.documentElement; var height = Math.max( body.scrollHeight, body.offsetHeight, html.clientHeight, html.scrollHeight, html.offsetHeight ); return height; }; var ifrm = this.element; var doc = this.getDocument(); if(doc) { ifrm.style.visibility = 'hidden'; ifrm.style.height = getHeight(doc) + "px"; ifrm.style.visibility = 'visible'; } window.setTimeout(function() { ifrm.style.height = getHeight(doc) + "px"; }, 120); }, resetHeight: function() { var ifrm = this.element; ifrm.style.height = 'auto'; }, addEvents: function() { var self = this; jQuery(this.element).on('load', function() { self.setHeight(); }); jQuery(window).on('resize', function() { self.resetHeight(); self.setHeight(); }); } }; var iframeLoader = new IframeLoader('servicesIframe'); iframeLoader.setup(); }}; bpMain.Navigation = { setup: function() { this.setupMinifyNavigation(); this.setupNavEvents(); }, setupMinifyNavigation: function() { var scroller = new bpApp.scrollHeader('navarea', 'sticky', 400); }, setupNavEvents: function() { var self = this; var button = jQuery('#main-nav-toggle'); button.on('click', function(){ self.toggleNav(); }); }, navHidden: true, toggleNav: function() { var header = jQuery('.top-banner-row'), button = jQuery('#main-nav-toggle'), nav = jQuery('#main-nav-container'), footBar = jQuery('.bottom-bar'), address = jQuery('.bottom-bar.inner'); if(this.navHidden === true) { this.navHidden = false; header.addClass('opened nav-d'); nav.addClass('open'); button.addClass('nav-close'); footBar.addClass('nav-d'); if(jQuery(window).width() < 767) { address.css({'bottom': '60px', 'position': 'fixed'}); } else { address.css('position', 'fixed'); } appNav.groups.selectPrimaryGroup(); } else { this.navHidden = true; header.removeClass('opened nav-d'); nav.removeClass('open'); button.removeClass('nav-close'); footBar.removeClass('nav-d'); address.css({'position': 'relative', 'bottom': '0px'}); } }}; bpMain.Modals = { setup: function() { this.setupModals(); }, setupModals: function() { var attrName = 'data-modal'; var self = this; var elements = jQuery('[' + attrName + ']').each(function(index, element) { element = jQuery(element); var modalName = element.attr(attrName); if(modalName) { element.on('click', function() { var modalClass = window[modalName]; if(modalClass) { var modal = new modalClass(); modal.setup(); modal.display(); } }); } }); }}; bpMain.Videos = { setup: function(attrName) { attrName = attrName || 'data-video-src'; var self = this; var elements = jQuery('[' + attrName + ']').each(function(index, element) { element = jQuery(element); var src = element.attr('data-video-src'); if(src) { var title = element.attr('data-title'); element.on('click', function() { self.view(title, src); }); } }); }, createBackgroundVideo: function(container, src) { return new bpApp.BackgroundVideo(container, src); }, view: function(title, src) { var vid = { title: title, source: src }; var panel = new bpApp.videoPanel(vid, '', document.body); panel.setup(); panel.display(); }}; bpMain.SlideShow = { setup: function(type) { type = type || 'modern'; switch(type) { case 'controller': this.setupSlideController(); break; case 'modern': this.setupSlideshow1(); break; case 'inner': this.setupSlideshow2(); break; case 'reviews': this.setupSlideshow3(); break; case 'nivo': this.setupNivoSlider(); break; } }, setupSlideController: function(container) { container = container || 'slides'; var spotlight = new bpApp.slideController(container, 0, '/wp-content/themes/alpha'); spotlight.duration = 7000; spotlight.setup(); }, createSlideShow: function(container, path, bg, optionsArray, duration) { duration = duration || 7000; var startNumber = Math.round(Math.random() * (optionsArray.length - 1)); var slideShow = new bpApp.slideShow(container, path, bg, startNumber); slideShow.duration = duration; slideShow.setup(optionsArray); return slideShow; }, createSlideOption: function(image, alt, title, content, className, url, crumbContent) { return { title: title, content: content, className: className, image: image, alt: alt, url: url, crumbContent: crumbContent }; }, setupSlideshow1: function() { var optionsArray = [ this.createSlideOption('wide1.jpg'), this.createSlideOption('wide3.jpg'), this.createSlideOption('wide5.jpg'), this.createSlideOption('wide7.jpg'), this.createSlideOption('wide11.jpg'), this.createSlideOption('tall1.jpg'), this.createSlideOption('tall2.jpg'), this.createSlideOption('tall3.jpg') ]; this.createSlideShow('internal_slides', '/images/', true, optionsArray); }, setupSlideshow2: function() { var optionsArray = [ this.createSlideOption('internal1.jpg'), this.createSlideOption('internal2.jpg'), this.createSlideOption('internal3.jpg') ]; this.createSlideShow('slides', '/images/slideshow/', true, optionsArray); }, setupSlideshow3: function() { var optionsArray = [ this.createSlideOption('', '', '', '“Thank you Dr. Howard and staff!! You make coming to the dentist almost a pleasure! I love the Christian music you play while I\'m waiting to be called back. My husband and I are treated like we\'re the only ones in the office and are made to feel valued. Thank you!”
-Lisa Snell
' ), this.createSlideOption('', '', '', '“Always professional, considerate, & kind. Top shelf from Dr Dan throughout !”
-Rich Flores
' ) ]; this.createSlideShow('reviews', '', false, optionsArray); }}; var appNav = new bpApp.navigation('nav-scroll-container', 'main-nav-container'); appNav.setup(); jQuery(function() { if(wpPageID === '2') { bpMain.SlideShow.setup('reviews'); } else { } if(wpPageID === '145') { bpMain.SlideShow.setup('modern'); } bpMain.SlideShow.setup('controller'); bpMain.setupCoolMap(); var lazyAnimator = new bpApp.lazyAnimator(); bpMain.setupAppDefault(); });