/* * Frontend JS * * @package Bravada */ jQuery( document ).ready( function() { cryoutLpBoxesRatios(); cryoutMobileMenuInit(); cryoutFixedMobileMenu(); cryoutInitNav( '#mobile-menu' ); cryoutMenuAnimate(); cryoutBackToTop(); cryoutSearchFormAnimation(); cryoutSocialTitles(); cryoutBodyClasses(); cryoutTabsWidget(); cryoutPortfolioFilter(); cryoutHeaderParallax(); cryoutLPArrowLink(); cryoutRemoveFocus(); cryoutSliderTitleBreakUp( '.lp-staticslider .staticslider-caption', '.staticslider-caption-title > span' ); cryoutSliderTitleBreakUp( '#header-page-title', '#header-page-title .entry-title' ); cryoutAnimateLazyImages(); /* cryoutBurgerMenu(); */ if ( typeof cryout_theme_settings !== 'undefined' ) { if ( ( ( cryout_theme_settings.fitvids == 2 ) && ( cryout_theme_settings.is_mobile == 1 ) ) || ( cryout_theme_settings.fitvids == 1 ) ) { jQuery( '.entry-content' ).fitVids(); } if ( cryout_theme_settings.autoscroll == 1 ) { cryoutAutoScroll(); } /* Animate articles */ if ( cryout_theme_settings.articleanimation ) { animateScroll( '#content-masonry > article', 'animated-onscroll' ); /* Animate landing page elements */ animateScroll( '.lp-block, .lp-box, .lp-text, .lp-port, .lp-tt, ' + '.lp-section-title, .lp-section-desc', 'animated-onscroll-lp' ); } } /* typeof cryout_theme_settings check */ jQuery( window ).on( 'scroll', function() { if ( jQuery( this ).scrollTop() > 30 ) { jQuery( '#nav-fixed' ).addClass( 'nav-fixed-show' ); } else { jQuery( '#nav-fixed' ).removeClass( 'nav-fixed-show' ); } if ( jQuery( this ).scrollTop() > 100 && ( ! jQuery( '.site-header-top' ).hasClass( 'is-active' ) ) ) { jQuery( '.bravada-fixed-menu .site-header-bottom' ).addClass( 'header-fixed' ); } else { jQuery( '.bravada-fixed-menu .site-header-bottom' ).removeClass( 'header-fixed' ); } } ); } ); /* document.ready */ jQuery( window ).on( 'load', function() { cryoutPreloader(); jQuery( window ).trigger( 'scroll' ); cryoutMasonry(); cryoutPortfolioMasonry(); } ); /* window.load */ /* * Functions **/ /* Animate images with the [loading="lazy"] attribute */ function cryoutAnimateLazyImages() { jQuery( 'body:not(.bravada-lazy-noanimation) #content img[loading="lazy"]' ).on( 'load', function() { jQuery( this ).addClass( 'animate-lazy' ); }).each( function() { if ( this.complete ) { jQuery( this ).trigger( 'load' ); } } ); } /* cryoutAnimateLazyImages() */ /* Site preloader */ function cryoutPreloader() { if ( ! jQuery( '.cryout-preloader' ).length ) return; /* Remove preloader backup animation */ if ( jQuery( '.cryout-preloader' ).length ) jQuery( '.cryout-preloader' ).css( 'animation', 'none' ); jQuery( '.cryout-preloader' ).fadeOut( 700, function() { jQuery( this ).remove(); } ); } /* cryoutPreloader() */ function cryoutLPArrowLink() { if ( ! jQuery( 'body' ).hasClass( 'bravada-landing-page' ) ) return; var newLink = jQuery( '.main section.lp-slider + section' ).attr( 'id' ); if ( undefined !== newLink && newLink.length ) { jQuery( '.meta-arrow' ).attr( 'href', '#' + newLink ); } } /* cryoutLPArrowLink() */ /* Burger menu */ function cryoutBurgerMenu() { if ( ! jQuery( '.hamburger' ).length ) return; var $activeElements = jQuery( '.hamburger, #site-wrapper, .site-header-bottom-fixed, #mobile-menu' ); var fixedHeader = false; /* check to see if header menu was fixed so we know to put it back later */ jQuery( '.hamburger' ).on( 'click', function( e ) { $activeElements.toggleClass( 'is-active' ); jQuery( '.site-header-top' ).prepareTransition().toggleClass( 'is-active' ); if ( jQuery( '.site-header-bottom' ).hasClass( 'header-fixed' ) ) { jQuery( '.site-header-bottom' ).removeClass( 'header-fixed' ); fixedHeader = true; } e.stopPropagation(); } ); } /* cryoutBurgerMenu() */ /* Force LP boxes images ratios */ function cryoutLpBoxesRatios() { for ( var index = 1; index <= cryout_theme_settings.lpboxratios.length; ++index ) { jQuery( '.lp-boxes-' + index + ' .lp-box-image' ).keepRatio( cryout_theme_settings.lpboxratios[index-1] ); } } /* cryoutLpBoxesRatios() */ /* Menu animation */ function cryoutMenuAnimate() { jQuery( '#access > .menu ul li > a:not(:only-child)' ).attr( 'aria-haspopup', 'true' );/* IE10 mobile Fix */ jQuery( '#access li' ).on( 'mouseenter', function() { jQuery( this ).addClass( 'menu-hover' ); } ).on( 'mouseleave', function() { jQuery( this ).removeClass( 'menu-hover' ); } ); jQuery( '#access ul' ).find( 'a' ).on( 'focus', function() { jQuery( this ).parents( '.menu-item, .page_item' ).addClass( 'menu-hover' ); } ); jQuery( '#access ul' ).find( 'a' ).on( 'blur', function() { jQuery( this ).parents( '.menu-item, .page_item' ).removeClass( 'menu-hover' ); } ); } /* cryoutMenuAnimate() */ /* Static Slider Title Letter break */ function cryoutSliderTitleBreakUp( titleContainer, animatedTitle ) { titleContainer = 'body.bravada-animated-title ' + titleContainer; animatedTitle = 'body.bravada-animated-title ' + animatedTitle; /* If title not present on page - exit */ if( ! jQuery( animatedTitle ).length ) return; /* Add class to all containers so the same CSS gets applied */ jQuery( titleContainer ).addClass( 'animated-title' ); /* And for improved performance, if static slider not in view - no animation */ jQuery( window ).on( 'scroll', function() { var el = jQuery( titleContainer ); if ( ! isInViewport( el ) ) { el.removeClass( 'animated-title' ); } else { el.addClass( 'animated-title' ); } } ); var $location = jQuery( animatedTitle ), oldStr = $location.html(), /* new string for processing, complete with HTML tags */ clearStr = $location.text().split( ' ' ).join(''), /* text only string for keys */ newStr = '', firsRunDelay = 1000, /*ms*/ letterDelay = 0, /*ms*/ animatedLetters = [], /* array for the random letters that are going to be animated */ nrOfAnimatedLetters = ( Math.floor( clearStr.length / 4 ) > 2) ? Math.floor( clearStr.length / 4) : 2; nrOfAnimatedLetters = ( nrOfAnimatedLetters > 7 ) ? 7 : nrOfAnimatedLetters; var interval = 3500 + nrOfAnimatedLetters * letterDelay; /* 200 = CSS animation time */ for ( var i = 0; i < oldStr.length; i++ ) { /* If tag starts skip everything until tag ends */ if ( oldStr[i] == '<') { var substring = oldStr.substring( i ); substring = substring.match( /(.*?)(<([^>]+)>)/ig ); substring = substring[0]; newStr += substring; i+= substring.length - 1; /* If entity starts skip everything until entity ends */ } else if ( oldStr[i] == '&' ) { var substring = oldStr.substring( i ); substring = substring.match( /(.*?);/ig ); substring = substring[0]; newStr += '' + substring + '' + substring + ''; i+= substring.length - 1; /* Any plain old single character */ } else if ( oldStr[i] != ' ' ) { newStr += '' + oldStr[i] + '' + oldStr[i] + ''; /* Spaces must be inside words for proper flow on new lines */ } else { newStr += ' '; } } newStr += ''; /* Out with the old, in with the new... string */ $location.html( newStr ); function titleAnimation() { jQuery( animatedTitle + ' .cry-single, ' + animatedTitle + ' .cry-double' ) .removeClass( 'animated-letter' ) .css( 'animation-delay', '0s' ); for ( var i = 0; i < nrOfAnimatedLetters; i++ ) { /* Get a random key from the new array of letters*/ animatedLetters[i] = Math.floor( Math.random() * clearStr.length ); jQuery( animatedTitle + ' .cry-single' ) .eq( animatedLetters[i] ) .addClass( 'animated-letter' ) .css( 'animation-delay', i * letterDelay + 'ms' ); jQuery( animatedTitle + ' .cry-double' ) .eq( animatedLetters[i] ) .addClass( 'animated-letter' ) .css( 'animation-delay', i * letterDelay + 'ms' ); } } /* Run once after delay */ setTimeout( titleAnimation, firsRunDelay ); /* Run forever with set interval */ window.setInterval( titleAnimation, interval); } /* cryoutSliderTitleBreakUp() */ /* Back to top button animation */ function cryoutBackToTop() { jQuery( window ).on( 'scroll', function() { if ( jQuery( this ).scrollTop() > 500 ) { jQuery( '#toTop' ).addClass( 'toTop-show' ); } else { jQuery( '#toTop' ).removeClass( 'toTop-show' ); } } ); jQuery( '#toTop' ).on( 'click', function( event ) { event.preventDefault(); jQuery( 'html, body' ).animate( { scrollTop: 0 }, 500 ); return false; } ); } /* cryoutBackToTop() */ /* Search form animation */ function cryoutSearchFormAnimation() { var searchIcon = jQuery( '#access .menu-search-animated > a' ), searchForm = jQuery( '.menu-search-animated .searchform, .menu-main-search .icon-cancel' ), searchInput = jQuery( '#access .menu-search-animated .s' ); searchIcon.on( 'click', function( event ) { /* never on focus! */ event.preventDefault(); searchForm.fadeIn( 200, function() { searchInput.trigger( 'focus' ); searchInput.css( 'outline', 'none' ); } ); searchInput.addClass( 'is-active' ); event.stopPropagation(); } ); searchForm.on( 'click', function( event ) { event.stopPropagation(); } ); searchInput.on( 'blur', function() { searchInput.removeClass( 'is-active' ); searchForm.fadeOut( 200 ); } ); } /* cryoutSearchFormAnimation() */ /* Mobile Menu */ function cryoutMobileMenuInit() { /* Remove animated class from mobile menu */ jQuery( '#mobile-menu .menu-main-search' ).removeClass( 'menu-search-animated' ); /* First and last elements in the loop */ var firstTab = jQuery( 'nav#mobile-menu #mobile-nav > li:first-child a' ), lastTab = jQuery( '.hamburger' ); /* Toggle menu */ jQuery( '.hamburger' ).on( 'click', function( e ) { e.stopPropagation(); jQuery( 'body' ).toggleClass( 'burgermenu-active noscroll' ); jQuery( 'nav#mobile-menu' ) .prepareTransition() .toggleClass( 'burgermenu-active' ); if ( jQuery( 'body' ).hasClass( 'burgermenu-active' ) ) { firstTab.trigger( 'focus' ).trigger( 'blur' ); } else { lastTab.trigger( 'focus' ).trigger( 'blur' ); } } ); /* Animate menu elements on show */ jQuery( 'nav#mobile-menu #mobile-nav > li, .side-section-element.widget_cryout_socials a' ) .each( function( index ) { var value = 0.03 * index + 's'; jQuery( this ).css( '-webkit-transition-delay', value ); jQuery( this ).css( 'transition-delay', value ); } ); /* Redirect last tab to first input */ lastTab.on( 'keydown', function ( e ) { if ( jQuery( 'body' ).hasClass( 'burgermenu-active' ) ) if ( ( e.which === 9 && ( ! e.shiftKey ) ) ) { e.preventDefault(); firstTab.trigger( 'focus' ); } } ); /* Redirect first shift+tab to last input*/ firstTab.on( 'keydown', function ( e ) { if ( jQuery( 'body' ).hasClass( 'burgermenu-active' ) ) if ( ( e.which === 9 && e.shiftKey ) ) { e.preventDefault(); lastTab.trigger( 'focus' ); } } ); /* Allow escape key to close menu */ jQuery( 'nav#mobile-menu' ).on( 'keyup', function( e ) { if ( jQuery( 'body' ).hasClass( 'burgermenu-active' ) ) if ( e.keyCode === 27 ) { jQuery( 'body' ).removeClass( 'burgermenu-active noscroll' ); jQuery( 'nav#mobile-menu' ).prepareTransition().toggleClass( 'burgermenu-active' ); lastTab.trigger( 'focus' ); } } ); /* Hide main menu overlay when link with anchor is clicked */ jQuery( 'nav#mobile-menu li a' ).on( 'click', function( e ) { var $hash = jQuery( this ).prop( 'hash' ); if ( $hash && jQuery( $hash ).length ) { jQuery( 'body' ).removeClass( 'burgermenu-active noscroll' ); jQuery( 'nav#mobile-menu' ).prepareTransition().toggleClass( 'burgermenu-active' ); } } ); } /* cryoutMobileMenuInit() */ /* Add fixed mobile menu functionality */ function cryoutFixedMobileMenu() { /* Only run if fixed menu is enabled */ if ( cryout_theme_settings.menustyle != 1 ) return; var c, currentScrollTop = 0, currentScrollBottom, navbar = jQuery( '.site-header-bottom' ), body = jQuery( 'body' ); jQuery( window ).on( 'scroll', function () { var a = jQuery( window ).scrollTop(); var b = jQuery( document ).height(); var viewport = jQuery( window ).height(); var navbarHeight = navbar.height(); currentScrollTop = a; currentScrollBottom = b; if ( c < currentScrollTop && a > navbarHeight + navbarHeight ) { /* Scrolling down */ body.removeClass( 'mobile-fixed' ); } else if ( ( currentScrollTop > viewport ) && ( currentScrollTop < currentScrollBottom - viewport * 2 ) && ( c > currentScrollTop ) && ( ! ( a <= navbarHeight ) ) ) { /* Scrolling up */ body.addClass( 'mobile-fixed' ); } c = currentScrollTop; /* Always clear fixed class when returning to the top */ if ( currentScrollTop <= navbarHeight ) { body.removeClass( 'mobile-fixed' ); } } ); } /* cryoutFixedMobileMenu() */ /* Add submenus toggles to the primary navigation */ function cryoutInitNav( selector ) { var container = jQuery( selector ); /* Add dropdown toggle that display child menu items. */ container.find( '.menu-item-has-children > a' ) .after( '' ); container.find( '.page_item_has_children > a' ) .after( '' ); /* Toggle buttons and submenu items with active children menu items. */ container.find( '.current-menu-ancestor > button, .current-page-ancestor > button' ) .addClass( 'toggle-on' ); container.find( '.current-menu-ancestor > .sub-menu, .current-page-ancestor > .sub-menu,' + ' .current-menu-ancestor .children, .current-page-ancestor .children' ) .show( 0 ).addClass( 'toggled-on' ); container.find( '.dropdown-toggle' ).on( 'click', function( e ) { var _this = jQuery( this ); e.preventDefault(); _this.toggleClass( 'toggle-on' ); if ( _this.hasClass( 'toggle-on') ) { _this.next( '.children, .sub-menu' ).show( 0 ).addClass( 'toggled-on' ); _this.prev( 'a' ).addClass( 'toggled-on' ); } else { _this.next( '.children, .sub-menu' ).removeClass( 'toggled-on' ); _this.next( '.children, .sub-menu' ).find( '.children, .sub-menu' ).removeClass( 'toggled-on' ); _this.next( '.children, .sub-menu' ).find( 'a' ).removeClass( 'toggled-on' ); _this.next( '.children, .sub-menu' ).find( '.dropdown-toggle' ).removeClass( 'toggled-on' ); _this.prev( 'a' ).removeClass( 'toggled-on' ); setTimeout( function() { _this.next( '.children, .sub-menu' ).hide( 0 ); _this.next( '.children, .sub-menu' ).find( '.children, .sub-menu' ).hide( 0 ); }, 600 ); } /* _this.parent().find( 'a' ).toggleClass( 'toggled-on' ); */ _this.attr( 'aria-expanded', _this.attr( 'aria-expanded' ) === 'false' ? 'true' : 'false' ); } ); /* Close mobile menu on click/tap */ jQuery( 'body' ).on( 'click', '#mobile-nav a', function() { jQuery( '#nav-cancel i' ).trigger( 'click' ); } ); } /* cryoutInitNav() */ /* LP Boxes Keep aspect ratio*/ jQuery.fn.keepRatio = function( ratio ) { var $this = jQuery( this ); var nh = $this.width() / ratio; $this.css( 'height', nh + 'px' ); jQuery( window ).on( 'resize', function() { var nh = $this.width() / ratio; $this.css( 'height', nh + 'px' ); } ); }; /* keepRatio() */ /* LP Box Mouse direction overlay animation */ jQuery.fn.mousedir = function( el ) { if ( ! jQuery( 'body' ).hasClass( 'bravada-landing-page' ) ) return; var $this = jQuery( this ), $el = jQuery( el ), last_position = {}, $output = 'direction-down'; jQuery( document ).on( 'mousemove', function ( event ) { if ( typeof( last_position.x ) !== 'undefined' ) { var deltaX = last_position.x - event.offsetX, deltaY = last_position.y - event.offsetY; if ( ( Math.abs( deltaX ) > Math.abs( deltaY ) ) && ( deltaX > 0 ) ) { $output = 'direction-left'; } else if ( ( Math.abs( deltaX ) > Math.abs( deltaY ) ) && ( deltaX < 0 ) ) { $output = 'direction-right'; } else if ( ( Math.abs( deltaY ) > Math.abs( deltaX ) ) && ( deltaY > 0 ) ) { $output = 'direction-up'; } else if ( ( Math.abs( deltaY ) > Math.abs( deltaX ) ) && ( deltaY < 0 ) ) { $output = 'direction-down'; } else { $output = 'direction-down'; } } last_position = { x : event.offsetX, y : event.offsetY }; } ); $el.on( 'mouseenter', function() { jQuery( this ).removeClass( 'in-direction-left in-direction-right in-direction-up in-direction-down' + ' out-direction-left out-direction-right out-direction-up out-direction-down' ); jQuery( this ).addClass( 'in-' + $output ); return; } ); $el.on( 'mouseleave', function() { jQuery( this ).removeClass( 'in-direction-left in-direction-right in-direction-up in-direction-down ' + ' out-direction-left out-direction-right out-direction-up out-direction-down' ); jQuery( this ).addClass( 'out-' + $output ); return; } ); }; /* mouseDir() */ /* Check if element is visible in browser window */ function isInViewport( el ) { if ( ! jQuery( el ).length ) return; var adminHeight = ( jQuery( '#wpadminbar' ).length ) ? jQuery( '#wpadminbar' ).height() : 0; var elementTop = jQuery( el ).offset().top; var elementBottom = elementTop + jQuery( el ).outerHeight(); var viewportTop = jQuery( window ).scrollTop(); var viewportBottom = viewportTop + jQuery( window ).height() - adminHeight; return ( elementBottom > viewportTop ) && ( elementTop < viewportBottom ); } /* isInViewport() */ /* Animate on scroll */ function animateScroll( $articles, $class ) { var $articles = jQuery( $articles ); $articles.each( function( i, el ) { jQuery( el ).addClass( $class ); } ); jQuery( window ).on( 'scroll', function() { $articles.each( function( i, el ) { if ( isInViewport( el ) ) { jQuery( el ).removeClass( $class ); } } ); } ); jQuery( window ).trigger( 'scroll' ); } /* animateScroll() */ /* Header image paralax effect and opacity, animate header titles */ function cryoutHeaderParallax() { var cur_op = parseFloat( jQuery( '#header-overlay' ).css( 'opacity' ) ); /* Parallax on scroll */ jQuery( window ).on( 'scroll', function() { var scrolled = jQuery( window ).scrollTop(); jQuery( '#masthead .header-image' ).each( function( index, element ) { /* Skip animations if element is not currently visible */ if ( jQuery( element ).css( 'display' ) === 'none' ) return true; var initY = jQuery( element ).offset().top, height = jQuery( element ).height(), visible = isInViewport( jQuery( element ) ); if ( visible ) { var diff = scrolled - initY; var ratio = Math.round( ( diff / height ) * 100 ); jQuery( element ).css( 'opacity', 1); jQuery( element ).css( 'background-position', 'center ' + (50 + parseInt( ratio )) + '%' ); if ( ( parseInt( ratio ) > 0 ) ) { jQuery( '#header-overlay' ) .css( 'opacity', cur_op + 1.5 * ( parseInt( ratio ) / (100 / ( (1 - cur_op ) * 100 ) ) / 100 ) ); jQuery( '#header-page-title' ) .css( 'opacity', ( 1 - ( parseInt( ratio ) * 1 / 100 ) ) ); } else { jQuery( '#header-overlay' ).css( 'opacity', cur_op ); jQuery( '#header-page-title' ).css( 'opacity', 1 ); } } } ); } ); } /* cryoutHeaderParallax() */ /* Add Social Icons titles */ function cryoutSocialTitles() { jQuery( '.socials a' ).each( function() { jQuery( this ).attr( 'title', jQuery( this ).children().html() ); jQuery( this ).html( '' ); } ); } /* cryoutSocialTitles() */ /* Add body classes */ function cryoutBodyClasses() { /* Detect and apply custom class for Safari */ if ( ( ( navigator.userAgent.indexOf( 'Safari' ) !== -1 ) || ( navigator.userAgent.indexOf( 'iPhone' ) !== -1 ) || ( navigator.userAgent.indexOf( 'iPad' ) !== -1 ) ) && ( navigator.userAgent.indexOf( 'Chrome' ) === -1 ) ) { jQuery( 'body' ).addClass( 'safari' ); } /* Add body class if masonry is used on page */ if ( jQuery( '#content-masonry' ).length > 0 ) { jQuery( 'body' ).addClass( 'bravada-with-masonry' ); } } /* cryoutBodyClasses() */ /* Remove all off-canvas states */ function cryoutRemoveFocus() { jQuery( 'input, textarea, select, a' ).on( 'focus', function() { if (jQuery( this ).data( 'mousedown' ) || jQuery( this ).data( 'mouseup' ) ) { jQuery( this ).css( 'outline', 'none' ); } } ); } /* cryoutRemoveFocus() */ /* Tabs widget */ function cryoutTabsWidget() { var tabsNav = jQuery( '.cryout-wtabs-nav' ), tabsNavLis = tabsNav.children( 'li' ); tabsNav.each( function() { var localthis = jQuery( this ); localthis.next().children( '.cryout-wtab' ).stop( true, true ) .children( 'li' ).hide() .parent().siblings( localthis.find( 'a' ).attr( 'href' ) ) .children( 'li' ).show(); localthis.children( 'li' ).first() .addClass( 'active' ).stop( true, true ).show(); } ); tabsNavLis.on( 'click', function( e ) { var localthis = jQuery( this ), tabs_duration = 200; localthis.siblings().removeClass( 'active' ).end().addClass( 'active' ); localthis.parent().next().children( '.cryout-wtab' ).stop( true, true ) .children( 'li' ).hide() .parent().siblings( localthis.find( 'a' ).attr( 'href' ) ) .children( 'li' ).each( function( index ) { jQuery( this ).fadeIn( tabs_duration * ( index + 1 ) ); } ); e.preventDefault(); } ).children( window.location.hash ? 'a[href="' + window.location.hash + '"]' : 'a:first' ) .trigger( 'click' ); } /* cryoutTabsWidget() */ /* Blog Masonry */ function cryoutMasonry() { if ( ( cryout_theme_settings.masonry == 1 ) && ( cryout_theme_settings.magazine != 1 ) && ( typeof jQuery.fn.masonry !== 'undefined' ) ) { jQuery( '#content-masonry' ).masonry( { itemSelector: 'article', columnWidth: 'article', percentPosition: true, isRTL: cryout_theme_settings.rtl, } ); } } /* cryoutMasonry() */ /* Jetpack Portfolio Masonry */ function cryoutPortfolioMasonry() { if ( ( cryout_theme_settings.masonry == 1 ) && ( typeof jQuery.fn.masonry !== 'undefined' ) ) { jQuery( '#lp-portfolio .jetpack-portfolio-shortcode' ).masonry( { itemSelector: '.portfolio-entry', columnWidth: '.portfolio-entry:not(.hidey)', percentPosition: true, isRTL: cryout_theme_settings.rtl, } ); } } /* cryoutPortfolioMasonry() */ /* Portfolio filtering */ function cryoutPortfolioFilter() { jQuery( 'body' ).on( 'click', '#portfolio-filter > a', function( e ) { e.preventDefault(); jQuery( '#portfolio-filter > a' ).removeClass( 'active' ); jQuery( this ).addClass( 'active' ); var filter = jQuery( this ).attr( 'data-slug' ); jQuery( '#portfolio-masonry .portfolio-entry' ).each( function( i, elm ) { if ( filter == 'all' ) { jQuery( elm ).removeClass( 'hidey' ).fadeIn( 'fast' ); } else { if ( ! jQuery( elm ).hasClass( 'type-' + filter ) ) { jQuery( elm ).addClass( 'hidey' ).fadeOut( 'fast' ); } else { jQuery( elm ).removeClass( 'hidey' ).fadeIn( 'fast' ); } } } ).promise().done( function() { cryoutPortfolioMasonry(); /*jQuery('.jetpack-portfolio-shortcode').masonry();*/ } ); return false; } ); } /* cryoutPortfolioFilter() */ /** * prepareTransition jQuery Plugin */ ;( function( $ ){ $.fn.prepareTransition = function() { return this.each( function() { var el = $( this ); /* Remove the transition class upon completion */ el.one( 'TransitionEnd webkitTransitionEnd transitionend oTransitionEnd', function() { el.removeClass( 'is-transitioning' ); } ); /* Check the various CSS properties to see if a duration has been set */ var cl = ["transition-duration", "-moz-transition-duration", "-webkit-transition-duration", "-o-transition-duration"]; var duration = 0; $.each( cl, function( idx, itm ) { duration || ( duration = parseFloat( el.css( itm ) ) ); } ); /* if I have a duration then add the class */ if ( duration != 0 ) { el.addClass( 'is-transitioning' ); el[0].offsetWidth; /* check offsetWidth to force the style rendering */ } } ); }; }( jQuery ) ); /** * Scroll to anchors */ function cryoutAutoScroll(document, history, location) { document = window.document; history = window.history; location = window.location; var HISTORY_SUPPORT = !! ( history && history.pushState ); var anchorScrolls = { ANCHOR_REGEX: /^#[^ ]+$/, OFFSET_HEIGHT_PX: jQuery( '.bravada-fixed-menu #site-header-main' ).height(), /* Establish events, and fix initial scroll position if a hash is provided. */ init: function() { this.scrollToCurrent(); jQuery( window ).on( 'hashchange', jQuery.proxy( this, 'scrollToCurrent' ) ); jQuery( 'body' ).on( 'click', '.main a, nav ul li a, .meta-arrow', jQuery.proxy( this, 'delegateAnchors' ) ); }, /* Return the offset amount to deduct from the normal scroll position. Modify as appropriate to allow for dynamic calculations. */ getFixedOffset: function() { return ( this.OFFSET_HEIGHT_PX ) ? this.OFFSET_HEIGHT_PX : 0; }, /* If the provided href is an anchor which resolves to an element on the page, scroll to it. */ scrollIfAnchor: function( href, pushToHistory ) { var match, anchorOffset; if ( ! this.ANCHOR_REGEX.test( href ) ) { return false; } match = document.getElementById(href.slice(1)); if ( match && ( ! isInViewport( match ) ) && jQuery( match ).offset().top ) { anchorOffset = jQuery( match ).offset().top - this.getFixedOffset(); jQuery( 'html, body' ).animate( { scrollTop: anchorOffset} ); /* Add the state to history as-per normal anchor links */ if ( HISTORY_SUPPORT && pushToHistory ) { history.pushState( {}, document.title, location.pathname + href ); } } return !!match; }, /* Attempt to scroll to the current location's hash */ scrollToCurrent: function(e) { if (this.scrollIfAnchor(window.location.hash) && e) { e.preventDefault(); } }, /* If the click event's target was an anchor, fix the scroll position */ delegateAnchors: function( e ) { var elem = e.target.closest( 'a' ); if ( this.scrollIfAnchor( elem.getAttribute( 'href' ), true ) ) { e.preventDefault(); } } }; jQuery( document ).ready( jQuery.proxy( anchorScrolls, 'init' ) ); } /* FitVids 1.1*/ ;(function( $ ){ 'use strict'; $.fn.fitVids = function( options ) { var settings = { customSelector: null, ignore: null }; if(!document.getElementById('fit-vids-style')) { /* appendStyles: https://github.com/toddmotto/fluidvids/blob/master/dist/fluidvids.js */ var head = document.head || document.getElementsByTagName('head')[0]; var css = '.fluid-width-video-wrapper{width:100%;position:relative;padding:0;}.fluid-width-video-wrapper iframe,.fluid-width-video-wrapper object,.fluid-width-video-wrapper embed {position:absolute;top:0;left:0;width:100%;height:100%;}'; var div = document.createElement("div"); div.innerHTML = '

x

'; head.appendChild(div.childNodes[1]); } if ( options ) { $.extend( settings, options ); } return this.each(function(){ var selectors = [ 'iframe[src*="player.vimeo.com"]', 'iframe[src*="youtube.com"]', 'iframe[src*="youtube-nocookie.com"]', 'iframe[src*="kickstarter.com"][src*="video.html"]', 'object', 'embed' ]; if (settings.customSelector) { selectors.push(settings.customSelector); } var ignoreList = '.fitvidsignore, .wp-block-embed__wrapper'; if(settings.ignore) { ignoreList = ignoreList + ', ' + settings.ignore; } var $allVideos = $(this).find(selectors.join(',')); $allVideos = $allVideos.not('object object'); /* SwfObj conflict patch */ $allVideos = $allVideos.not(ignoreList); /* Disable FitVids on this video. */ $allVideos.each(function(){ var $this = $(this); if($this.parents(ignoreList).length > 0) { return; /* Disable FitVids on this video. */ } if (this.tagName.toLowerCase() === 'embed' && $this.parent('object').length || $this.parent('.fluid-width-video-wrapper').length) { return; } if ((!$this.css('height') && !$this.css('width')) && (isNaN($this.attr('height')) || isNaN($this.attr('width')))) { $this.attr('height', 9); $this.attr('width', 16); } var height = ( this.tagName.toLowerCase() === 'object' || ($this.attr('height') && !isNaN(parseInt($this.attr('height'), 10))) ) ? parseInt($this.attr('height'), 10) : $this.height(), width = !isNaN(parseInt($this.attr('width'), 10)) ? parseInt($this.attr('width'), 10) : $this.width(), aspectRatio = height / width; if(!$this.attr('name')){ var videoName = 'fitvid' + $.fn.fitVids._count; $this.attr('name', videoName); $.fn.fitVids._count++; } $this.wrap('
').parent('.fluid-width-video-wrapper').css('padding-top', (aspectRatio * 100)+'%'); $this.removeAttr('height').removeAttr('width'); } ); } ); }; /* Internal counter for unique video names. */ $.fn.fitVids._count = 0; /* Works with either jQuery or Zepto */ })( window.jQuery || window.Zepto ); /* IE .closest() fix */ if ( window.Element && ( ! Element.prototype.closest ) ) { Element.prototype.closest = function( s ) { var matches = ( this.document || this.ownerDocument ).querySelectorAll( s ), i, el = this; do { i = matches.length; while (--i >= 0 && matches.item( i ) !== el) {} } while ( (i < 0) && ( el = el.parentElement ) ); return el; }; } /* FIN */