/*!

* Material Design for Bootstrap 4
* Version: MDB Blog 4.8.2
*
*
* Copyright: Material Design for Bootstrap
* https://mdbootstrap.com/
*
* Read the license: https://mdbootstrap.com/license/
*
*
* Documentation: https://mdbootstrap.com/
*
* Getting started: https://mdbootstrap.com/getting-started/
*
* Tutorials: https://mdbootstrap.com/bootstrap-tutorial/
*
* Templates: https://mdbootstrap.com/templates/
*
* Support: https://mdbootstrap.com/forums/forum/support/
*
* Contact: office@mdbootstrap.com
*
* Attribution: Animate CSS, Twitter Bootstrap, Materialize CSS, Normalize CSS, Waves JS, WOW JS, Toastr, Chart.js
*
*/

/*

jquery-easing.js global.js velocity.min.js wow.js scrolling-nav.js waves.js card-reveal.js character-counter.js smooth-scroll.js dropdown.js rotating-cards.js buttons.js sidenav.js collapsible.js panel-popuot.js forms.js jquery.jsticky.js scrollbar.js animations.js treeview.js

*/

/*

* jQuery Easing v1.3 - http://gsgd.co.uk/sandbox/jquery/easing/
*
* Uses the built in easing capabilities added In jQuery 1.1
* to offer multiple easing options
*
* TERMS OF USE - jQuery Easing
*
* Open source under the BSD License.
*
* Copyright © 2008 George McGinley Smith
* All rights reserved.
*
* Redistribution and use in source and binary forms, with or without modification,
* are permitted provided that the following conditions are met:
*
* Redistributions of source code must retain the above copyright notice, this list of
* conditions and the following disclaimer.
* Redistributions in binary form must reproduce the above copyright notice, this list
* of conditions and the following disclaimer in the documentation and/or other materials
* provided with the distribution.
*
* Neither the name of the author nor the names of contributors may be used to endorse
* or promote products derived from this software without specific prior written permission.
*
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY
* EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
* MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
*  COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
*  EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE
*  GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
* AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
*  NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED
* OF THE POSSIBILITY OF SUCH DAMAGE.
*

*/

// t: current time, b: begInnIng value, c: change In value, d: duration jQuery.easing = jQuery.easing;

jQuery.extend( jQuery.easing, {

def: 'easeOutQuad',
swing: function (x, t, b, c, d) {
    //alert(jQuery.easing.default);
    return jQuery.easing[jQuery.easing.def](x, t, b, c, d);
},
easeInQuad: function (x, t, b, c, d) {
    return c*(t/=d)*t + b;
},
easeOutQuad: function (x, t, b, c, d) {
    return -c *(t/=d)*(t-2) + b;
},
easeInOutQuad: function (x, t, b, c, d) {
    if ((t/=d/2) < 1) return c/2*t*t + b;
    return -c/2 * ((--t)*(t-2) - 1) + b;
},
easeInCubic: function (x, t, b, c, d) {
    return c*(t/=d)*t*t + b;
},
easeOutCubic: function (x, t, b, c, d) {
    return c*((t=t/d-1)*t*t + 1) + b;
},
easeInOutCubic: function (x, t, b, c, d) {
    if ((t/=d/2) < 1) return c/2*t*t*t + b;
    return c/2*((t-=2)*t*t + 2) + b;
},
easeInQuart: function (x, t, b, c, d) {
    return c*(t/=d)*t*t*t + b;
},
easeOutQuart: function (x, t, b, c, d) {
    return -c * ((t=t/d-1)*t*t*t - 1) + b;
},
easeInOutQuart: function (x, t, b, c, d) {
    if ((t/=d/2) < 1) return c/2*t*t*t*t + b;
    return -c/2 * ((t-=2)*t*t*t - 2) + b;
},
easeInQuint: function (x, t, b, c, d) {
    return c*(t/=d)*t*t*t*t + b;
},
easeOutQuint: function (x, t, b, c, d) {
    return c*((t=t/d-1)*t*t*t*t + 1) + b;
},
easeInOutQuint: function (x, t, b, c, d) {
    if ((t/=d/2) < 1) return c/2*t*t*t*t*t + b;
    return c/2*((t-=2)*t*t*t*t + 2) + b;
},
easeInSine: function (x, t, b, c, d) {
    return -c * Math.cos(t/d * (Math.PI/2)) + c + b;
},
easeOutSine: function (x, t, b, c, d) {
    return c * Math.sin(t/d * (Math.PI/2)) + b;
},
easeInOutSine: function (x, t, b, c, d) {
    return -c/2 * (Math.cos(Math.PI*t/d) - 1) + b;
},
easeInExpo: function (x, t, b, c, d) {
    return (t==0) ? b : c * Math.pow(2, 10 * (t/d - 1)) + b;
},
easeOutExpo: function (x, t, b, c, d) {
    return (t==d) ? b+c : c * (-Math.pow(2, -10 * t/d) + 1) + b;
},
easeInOutExpo: function (x, t, b, c, d) {
    if (t==0) return b;
    if (t==d) return b+c;
    if ((t/=d/2) < 1) return c/2 * Math.pow(2, 10 * (t - 1)) + b;
    return c/2 * (-Math.pow(2, -10 * --t) + 2) + b;
},
easeInCirc: function (x, t, b, c, d) {
    return -c * (Math.sqrt(1 - (t/=d)*t) - 1) + b;
},
easeOutCirc: function (x, t, b, c, d) {
    return c * Math.sqrt(1 - (t=t/d-1)*t) + b;
},
easeInOutCirc: function (x, t, b, c, d) {
    if ((t/=d/2) < 1) return -c/2 * (Math.sqrt(1 - t*t) - 1) + b;
    return c/2 * (Math.sqrt(1 - (t-=2)*t) + 1) + b;
},
easeInElastic: function (x, t, b, c, d) {
    var s=1.70158;var p=0;var a=c;
    if (t==0) return b;  if ((t/=d)==1) return b+c;  if (!p) p=d*.3;
    if (a < Math.abs(c)) { a=c; var s=p/4; }
    else var s = p/(2*Math.PI) * Math.asin (c/a);
    return -(a*Math.pow(2,10*(t-=1)) * Math.sin( (t*d-s)*(2*Math.PI)/p )) + b;
},
easeOutElastic: function (x, t, b, c, d) {
    var s=1.70158;var p=0;var a=c;
    if (t==0) return b;  if ((t/=d)==1) return b+c;  if (!p) p=d*.3;
    if (a < Math.abs(c)) { a=c; var s=p/4; }
    else var s = p/(2*Math.PI) * Math.asin (c/a);
    return a*Math.pow(2,-10*t) * Math.sin( (t*d-s)*(2*Math.PI)/p ) + c + b;
},
easeInOutElastic: function (x, t, b, c, d) {
    var s=1.70158;var p=0;var a=c;
    if (t==0) return b;  if ((t/=d/2)==2) return b+c;  if (!p) p=d*(.3*1.5);
    if (a < Math.abs(c)) { a=c; var s=p/4; }
    else var s = p/(2*Math.PI) * Math.asin (c/a);
    if (t < 1) return -.5*(a*Math.pow(2,10*(t-=1)) * Math.sin( (t*d-s)*(2*Math.PI)/p )) + b;
    return a*Math.pow(2,-10*(t-=1)) * Math.sin( (t*d-s)*(2*Math.PI)/p )*.5 + c + b;
},
easeInBack: function (x, t, b, c, d, s) {
    if (s == undefined) s = 1.70158;
    return c*(t/=d)*t*((s+1)*t - s) + b;
},
easeOutBack: function (x, t, b, c, d, s) {
    if (s == undefined) s = 1.70158;
    return c*((t=t/d-1)*t*((s+1)*t + s) + 1) + b;
},
easeInOutBack: function (x, t, b, c, d, s) {
    if (s == undefined) s = 1.70158;
    if ((t/=d/2) < 1) return c/2*(t*t*(((s*=(1.525))+1)*t - s)) + b;
    return c/2*((t-=2)*t*(((s*=(1.525))+1)*t + s) + 2) + b;
},
easeInBounce: function (x, t, b, c, d) {
    return c - jQuery.easing.easeOutBounce (x, d-t, 0, c, d) + b;
},
easeOutBounce: function (x, t, b, c, d) {
    if ((t/=d) < (1/2.75)) {
        return c*(7.5625*t*t) + b;
    } else if (t < (2/2.75)) {
        return c*(7.5625*(t-=(1.5/2.75))*t + .75) + b;
    } else if (t < (2.5/2.75)) {
        return c*(7.5625*(t-=(2.25/2.75))*t + .9375) + b;
    } else {
        return c*(7.5625*(t-=(2.625/2.75))*t + .984375) + b;
    }
},
easeInOutBounce: function (x, t, b, c, d) {
    if (t < d/2) return jQuery.easing.easeInBounce (x, t*2, 0, c, d) * .5 + b;
    return jQuery.easing.easeOutBounce (x, t*2-d, 0, c, d) * .5 + c*.5 + b;
}

});

/*

*
* TERMS OF USE - EASING EQUATIONS
*
* Open source under the BSD License.
*
* Copyright © 2001 Robert Penner
* All rights reserved.
*
* Redistribution and use in source and binary forms, with or without modification,
* are permitted provided that the following conditions are met:
*
* Redistributions of source code must retain the above copyright notice, this list of
* conditions and the following disclaimer.
* Redistributions in binary form must reproduce the above copyright notice, this list
* of conditions and the following disclaimer in the documentation and/or other materials
* provided with the distribution.
*
* Neither the name of the author nor the names of contributors may be used to endorse
* or promote products derived from this software without specific prior written permission.
*
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY
* EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
* MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
*  COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
*  EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE
*  GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
* AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
*  NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED
* OF THE POSSIBILITY OF SUCH DAMAGE.
*
*/

'use strict';

var WOW;

(function ($) {

WOW = function WOW() {

  return {

    init: function init() {

      var animationName = [];

      var once = 1;

      function mdbWow() {

        var windowHeight = window.innerHeight;
        var scroll = window.scrollY;

        $('.wow').each(function () {

          if ($(this).css('visibility') == 'visible') {
            return;
          }

          if (windowHeight + scroll - 100 > getOffset(this) && scroll < getOffset(this) || windowHeight + scroll - 100 > getOffset(this) + $(this).height() && scroll < getOffset(this) + $(this).height() || windowHeight + scroll == $(document).height() && getOffset(this) + 100 > $(document).height()) {

            var index = $(this).index('.wow');

            var delay = $(this).attr('data-wow-delay');

            if (delay) {

              delay = $(this).attr('data-wow-delay').slice(0, -1

              );
              var self = this;

              var timeout = parseFloat(delay) * 1000;

              $(self).addClass('animated');
              $(self).css({
                'visibility': 'visible'
              });
              $(self).css({
                'animation-delay': delay
              });
              $(self).css({
                'animation-name': animationName[index]
              });

              var removeTime = $(this).css('animation-duration').slice(0, -1) * 1000;

              if ($(this).attr('data-wow-delay')) {

                removeTime += $(this).attr('data-wow-delay').slice(0, -1) * 1000;
              }

              var self = this;

              setTimeout(function () {

                $(self).removeClass('animated');
              }, removeTime);
            } else {

              $(this).addClass('animated');
              $(this).css({
                'visibility': 'visible'
              });
              $(this).css({
                'animation-name': animationName[index]
              });

              var removeTime = $(this).css('animation-duration').slice(0, -1) * 1000;

              var self = this;

              setTimeout(function () {

                $(self).removeClass('animated');
              }, removeTime);
            }
          }
        });
      }

      function appear() {

        $('.wow').each(function () {

          var index = $(this).index('.wow');

          var delay = $(this).attr('data-wow-delay');

          if (delay) {

            delay = $(this).attr('data-wow-delay').slice(0, -1);

            var timeout = parseFloat(delay) * 1000;

            $(this).addClass('animated');
            $(this).css({
              'visibility': 'visible'
            });
            $(this).css({
              'animation-delay': delay + 's'
            });
            $(this).css({
              'animation-name': animationName[index]
            });
          } else {

            $(this).addClass('animated');
            $(this).css({
              'visibility': 'visible'
            });
            $(this).css({
              'animation-name': animationName[index]
            });
          }
        });
      }

      function hide() {

        var windowHeight = window.innerHeight;
        var scroll = window.scrollY;

        $('.wow.animated').each(function () {

          if (windowHeight + scroll - 100 > getOffset(this) && scroll > getOffset(this) + 100 || windowHeight + scroll - 100 < getOffset(this) && scroll < getOffset(this) + 100 || getOffset(this) + $(this).height > $(document).height() - 100) {

            $(this).removeClass('animated');
            $(this).css({
              'animation-name': 'none'
            });
            $(this).css({
              'visibility': 'hidden'
            });
          } else {

            var removeTime = $(this).css('animation-duration').slice(0, -1) * 1000;

            if ($(this).attr('data-wow-delay')) {

              removeTime += $(this).attr('data-wow-delay').slice(0, -1) * 1000;
            }

            var self = this;

            setTimeout(function () {

              $(self).removeClass('animated');
            }, removeTime);
          }
        });

        mdbWow();

        once--;
      }

      function getOffset(elem) {

        var box = elem.getBoundingClientRect();

        var body = document.body;
        var docEl = document.documentElement;

        var scrollTop = window.pageYOffset || docEl.scrollTop || body.scrollTop;

        var clientTop = docEl.clientTop || body.clientTop || 0;

        var top = box.top + scrollTop - clientTop;

        return Math.round(top);
      }

      $('.wow').each(function () {

        $(this).css({
          'visibility': 'hidden'
        });
        animationName[$(this).index('.wow')] = $(this).css('animation-name');
        $(this).css({
          'animation-name': 'none'
        });
      });

      $(window).scroll(function () {

        if (once) {

          hide();
        } else {

          mdbWow();
        }
      });

      appear();
    }
  };
};

})(jQuery);

“use strict”;

(function ($) {

var SCROLLING_NAVBAR_OFFSET_TOP = 50;
$(window).on('scroll', function () {
  var $navbar = $('.navbar');

  if ($navbar.length) {
    if ($navbar.offset().top > SCROLLING_NAVBAR_OFFSET_TOP) {
      $('.scrolling-navbar').addClass('top-nav-collapse');
    } else {
      $('.scrolling-navbar').removeClass('top-nav-collapse');
    }
  }
});

})(jQuery); /*!

* Waves v0.7.6
* http://fian.my.id/Waves
*
* Copyright 2014-2018 Alfiana E. Sibuea and other contributors
* Released under the MIT license
* https://github.com/fians/Waves/blob/master/LICENSE
*/

;(function(window, factory) {

'use strict';

// AMD. Register as an anonymous module.  Wrap in function so we have access
// to root via `this`.
if (typeof define === 'function' && define.amd) {
    define([], function() {
        window.Waves = factory.call(window);
        return window.Waves;
    });
}

// Node. Does not work with strict CommonJS, but only CommonJS-like
// environments that support module.exports, like Node.
else if (typeof exports === 'object') {
    module.exports = factory.call(window);
}

// Browser globals.
else {
    window.Waves = factory.call(window);
}

})(typeof global === 'object' ? global : this, function() {

'use strict';

var Waves            = Waves || {};
var $$               = document.querySelectorAll.bind(document);
var toString         = Object.prototype.toString;
var isTouchAvailable = 'ontouchstart' in window;

// Find exact position of element
function isWindow(obj) {
    return obj !== null && obj === obj.window;
}

function getWindow(elem) {
    return isWindow(elem) ? elem : elem.nodeType === 9 && elem.defaultView;
}

function isObject(value) {
    var type = typeof value;
    return type === 'function' || type === 'object' && !!value;
}

function isDOMNode(obj) {
    return isObject(obj) && obj.nodeType > 0;
}

function getWavesElements(nodes) {
    var stringRepr = toString.call(nodes);

    if (stringRepr === '[object String]') {
        return $$(nodes);
    } else if (isObject(nodes) && /^\[object (Array|HTMLCollection|NodeList|Object)\]$/.test(stringRepr) && nodes.hasOwnProperty('length')) {
        return nodes;
    } else if (isDOMNode(nodes)) {
        return [nodes];
    }

    return [];
}

function offset(elem) {
    var docElem, win,
        box = { top: 0, left: 0 },
        doc = elem && elem.ownerDocument;

    docElem = doc.documentElement;

    if (typeof elem.getBoundingClientRect !== typeof undefined) {
        box = elem.getBoundingClientRect();
    }
    win = getWindow(doc);
    return {
        top: box.top + win.pageYOffset - docElem.clientTop,
        left: box.left + win.pageXOffset - docElem.clientLeft
    };
}

function convertStyle(styleObj) {
    var style = '';

    for (var prop in styleObj) {
        if (styleObj.hasOwnProperty(prop)) {
            style += (prop + ':' + styleObj[prop] + ';');
        }
    }

    return style;
}

var Effect = {

    // Effect duration
    duration: 750,

    // Effect delay (check for scroll before showing effect)
    delay: 200,

    show: function(e, element, velocity) {

        // Disable right click
        if (e.button === 2) {
            return false;
        }

        element = element || this;

        // Create ripple
        var ripple = document.createElement('div');
        ripple.className = 'waves-ripple waves-rippling';
        element.appendChild(ripple);

        // Get click coordinate and element width
        var pos       = offset(element);
        var relativeY = 0;
        var relativeX = 0;
        // Support for touch devices
        if('touches' in e && e.touches.length) {
            relativeY   = (e.touches[0].pageY - pos.top);
            relativeX   = (e.touches[0].pageX - pos.left);
        }
        //Normal case
        else {
            relativeY   = (e.pageY - pos.top);
            relativeX   = (e.pageX - pos.left);
        }
        // Support for synthetic events
        relativeX = relativeX >= 0 ? relativeX : 0;
        relativeY = relativeY >= 0 ? relativeY : 0;

        var scale     = 'scale(' + ((element.clientWidth / 100) * 3) + ')';
        var translate = 'translate(0,0)';

        if (velocity) {
            translate = 'translate(' + (velocity.x) + 'px, ' + (velocity.y) + 'px)';
        }

        // Attach data to element
        ripple.setAttribute('data-hold', Date.now());
        ripple.setAttribute('data-x', relativeX);
        ripple.setAttribute('data-y', relativeY);
        ripple.setAttribute('data-scale', scale);
        ripple.setAttribute('data-translate', translate);

        // Set ripple position
        var rippleStyle = {
            top: relativeY + 'px',
            left: relativeX + 'px'
        };

        ripple.classList.add('waves-notransition');
        ripple.setAttribute('style', convertStyle(rippleStyle));
        ripple.classList.remove('waves-notransition');

        // Scale the ripple
        rippleStyle['-webkit-transform'] = scale + ' ' + translate;
        rippleStyle['-moz-transform'] = scale + ' ' + translate;
        rippleStyle['-ms-transform'] = scale + ' ' + translate;
        rippleStyle['-o-transform'] = scale + ' ' + translate;
        rippleStyle.transform = scale + ' ' + translate;
        rippleStyle.opacity = '1';

        var duration = e.type === 'mousemove' ? 2500 : Effect.duration;
        rippleStyle['-webkit-transition-duration'] = duration + 'ms';
        rippleStyle['-moz-transition-duration']    = duration + 'ms';
        rippleStyle['-o-transition-duration']      = duration + 'ms';
        rippleStyle['transition-duration']         = duration + 'ms';

        ripple.setAttribute('style', convertStyle(rippleStyle));
    },

    hide: function(e, element) {
        element = element || this;

        var ripples = element.getElementsByClassName('waves-rippling');

        for (var i = 0, len = ripples.length; i < len; i++) {
            removeRipple(e, element, ripples[i]);
        }

        if (isTouchAvailable) {
            element.removeEventListener('touchend', Effect.hide);
            element.removeEventListener('touchcancel', Effect.hide);
        }

        element.removeEventListener('mouseup', Effect.hide);
        element.removeEventListener('mouseleave', Effect.hide);
    }
};

/**
 * Collection of wrapper for HTML element that only have single tag
 * like <input> and <img>
 */
var TagWrapper = {

    // Wrap <input> tag so it can perform the effect
    input: function(element) {

        var parent = element.parentNode;

        // If input already have parent just pass through
        if (parent.tagName.toLowerCase() === 'span' && parent.classList.contains('waves-effect')) {
            return;
        }

        // Put element class and style to the specified parent
        var wrapper       = document.createElement('span');
        wrapper.className = 'waves-input-wrapper';
        // element.className = 'waves-button-input';

        // Put element as child
        parent.replaceChild(wrapper, element);
        wrapper.appendChild(element);

    },

    // Wrap <img> tag so it can perform the effect
    img: function(element) {

        var parent = element.parentNode;

        // If input already have parent just pass through
        if (parent.tagName.toLowerCase() === 'i' && parent.classList.contains('waves-effect')) {
            return;
        }

        // Put element as child
        var wrapper  = document.createElement('i');
        parent.replaceChild(wrapper, element);
        wrapper.appendChild(element);

    }
};

/**
 * Hide the effect and remove the ripple. Must be
 * a separate function to pass the JSLint...
 */
function removeRipple(e, el, ripple) {

    // Check if the ripple still exist
    if (!ripple) {
        return;
    }

    ripple.classList.remove('waves-rippling');

    var relativeX = ripple.getAttribute('data-x');
    var relativeY = ripple.getAttribute('data-y');
    var scale     = ripple.getAttribute('data-scale');
    var translate = ripple.getAttribute('data-translate');

    // Get delay beetween mousedown and mouse leave
    var diff = Date.now() - Number(ripple.getAttribute('data-hold'));
    var delay = 350 - diff;

    if (delay < 0) {
        delay = 0;
    }

    if (e.type === 'mousemove') {
        delay = 150;
    }

    // Fade out ripple after delay
    var duration = e.type === 'mousemove' ? 2500 : Effect.duration;

    setTimeout(function() {

        var style = {
            top: relativeY + 'px',
            left: relativeX + 'px',
            opacity: '0',

            // Duration
            '-webkit-transition-duration': duration + 'ms',
            '-moz-transition-duration': duration + 'ms',
            '-o-transition-duration': duration + 'ms',
            'transition-duration': duration + 'ms',
            '-webkit-transform': scale + ' ' + translate,
            '-moz-transform': scale + ' ' + translate,
            '-ms-transform': scale + ' ' + translate,
            '-o-transform': scale + ' ' + translate,
            'transform': scale + ' ' + translate
        };

        ripple.setAttribute('style', convertStyle(style));

        setTimeout(function() {
            try {
                el.removeChild(ripple);
            } catch (e) {
                return false;
            }
        }, duration);

    }, delay);
}

/**
 * Disable mousedown event for 500ms during and after touch
 */
var TouchHandler = {

    /* uses an integer rather than bool so there's no issues with
     * needing to clear timeouts if another touch event occurred
     * within the 500ms. Cannot mouseup between touchstart and
     * touchend, nor in the 500ms after touchend. */
    touches: 0,

    allowEvent: function(e) {

        var allow = true;

        if (/^(mousedown|mousemove)$/.test(e.type) && TouchHandler.touches) {
            allow = false;
        }

        return allow;
    },
    registerEvent: function(e) {
        var eType = e.type;

        if (eType === 'touchstart') {

            TouchHandler.touches += 1; // push

        } else if (/^(touchend|touchcancel)$/.test(eType)) {

            setTimeout(function() {
                if (TouchHandler.touches) {
                    TouchHandler.touches -= 1; // pop after 500ms
                }
            }, 500);

        }
    }
};

/**
 * Delegated click handler for .waves-effect element.
 * returns null when .waves-effect element not in "click tree"
 */
function getWavesEffectElement(e) {

    if (TouchHandler.allowEvent(e) === false) {
        return null;
    }

    var element = null;
    var target = e.target || e.srcElement;

    while (target.parentElement) {
        if ( (!(target instanceof SVGElement)) && target.classList.contains('waves-effect')) {
            element = target;
            break;
        }
        target = target.parentElement;
    }

    return element;
}

/**
 * Bubble the click and show effect if .waves-effect elem was found
 */
function showEffect(e) {

    // Disable effect if element has "disabled" property on it
    // In some cases, the event is not triggered by the current element
    // if (e.target.getAttribute('disabled') !== null) {
    //     return;
    // }

    var element = getWavesEffectElement(e);

    if (element !== null) {

        // Make it sure the element has either disabled property, disabled attribute or 'disabled' class
        if (element.disabled || element.getAttribute('disabled') || element.classList.contains('disabled')) {
            return;
        }

        TouchHandler.registerEvent(e);

        if (e.type === 'touchstart' && Effect.delay) {

            var hidden = false;

            var timer = setTimeout(function () {
                timer = null;
                Effect.show(e, element);
            }, Effect.delay);

            var hideEffect = function(hideEvent) {

                // if touch hasn't moved, and effect not yet started: start effect now
                if (timer) {
                    clearTimeout(timer);
                    timer = null;
                    Effect.show(e, element);
                }
                if (!hidden) {
                    hidden = true;
                    Effect.hide(hideEvent, element);
                }

                removeListeners();
            };

            var touchMove = function(moveEvent) {
                if (timer) {
                    clearTimeout(timer);
                    timer = null;
                }
                hideEffect(moveEvent);

                removeListeners();
            };

            element.addEventListener('touchmove', touchMove, false);
            element.addEventListener('touchend', hideEffect, false);
            element.addEventListener('touchcancel', hideEffect, false);

            var removeListeners = function() {
                element.removeEventListener('touchmove', touchMove);
                element.removeEventListener('touchend', hideEffect);
                element.removeEventListener('touchcancel', hideEffect);
            };
        } else {

            Effect.show(e, element);

            if (isTouchAvailable) {
                element.addEventListener('touchend', Effect.hide, false);
                element.addEventListener('touchcancel', Effect.hide, false);
            }

            element.addEventListener('mouseup', Effect.hide, false);
            element.addEventListener('mouseleave', Effect.hide, false);
        }
    }
}

Waves.init = function(options) {
    var body = document.body;

    options = options || {};

    if ('duration' in options) {
        Effect.duration = options.duration;
    }

    if ('delay' in options) {
        Effect.delay = options.delay;
    }

    if (isTouchAvailable) {
        body.addEventListener('touchstart', showEffect, false);
        body.addEventListener('touchcancel', TouchHandler.registerEvent, false);
        body.addEventListener('touchend', TouchHandler.registerEvent, false);
    }

    body.addEventListener('mousedown', showEffect, false);
};

/**
 * Attach Waves to dynamically loaded inputs, or add .waves-effect and other
 * waves classes to a set of elements. Set drag to true if the ripple mouseover
 * or skimming effect should be applied to the elements.
 */
Waves.attach = function(elements, classes) {

    elements = getWavesElements(elements);

    if (toString.call(classes) === '[object Array]') {
        classes = classes.join(' ');
    }

    classes = classes ? ' ' + classes : '';

    var element, tagName;

    for (var i = 0, len = elements.length; i < len; i++) {

        element = elements[i];
        tagName = element.tagName.toLowerCase();

        if (['input', 'img'].indexOf(tagName) !== -1) {
            TagWrapper[tagName](element);
            element = element.parentElement;
        }

        if (element.className.indexOf('waves-effect') === -1) {
            element.className += ' waves-effect' + classes;
        }
    }
};

/**
 * Cause a ripple to appear in an element via code.
 */
Waves.ripple = function(elements, options) {
    elements = getWavesElements(elements);
    var elementsLen = elements.length;

    options          = options || {};
    options.wait     = options.wait || 0;
    options.position = options.position || null; // default = centre of element

    if (elementsLen) {
        var element, pos, off, centre = {}, i = 0;
        var mousedown = {
            type: 'mousedown',
            button: 1
        };
        var hideRipple = function(mouseup, element) {
            return function() {
                Effect.hide(mouseup, element);
            };
        };

        for (; i < elementsLen; i++) {
            element = elements[i];
            pos = options.position || {
                x: element.clientWidth / 2,
                y: element.clientHeight / 2
            };

            off      = offset(element);
            centre.x = off.left + pos.x;
            centre.y = off.top + pos.y;

            mousedown.pageX = centre.x;
            mousedown.pageY = centre.y;

            Effect.show(mousedown, element);

            if (options.wait >= 0 && options.wait !== null) {
                var mouseup = {
                    type: 'mouseup',
                    button: 1
                };

                setTimeout(hideRipple(mouseup, element), options.wait);
            }
        }
    }
};

/**
 * Remove all ripples from an element.
 */
Waves.calm = function(elements) {
    elements = getWavesElements(elements);
    var mouseup = {
        type: 'mouseup',
        button: 1
    };

    for (var i = 0, len = elements.length; i < len; i++) {
        Effect.hide(mouseup, elements[i]);
    }
};

/**
 * Deprecated API fallback
 */
Waves.displayEffect = function(options) {
    console.error('Waves.displayEffect() has been deprecated and will be removed in future version. Please use Waves.init() to initialize Waves effect');
    Waves.init(options);
};

return Waves;

});

//Initialization Waves.attach('.btn:not(.btn-flat), .btn-floating', ['waves-light']); Waves.attach('.btn-flat', ['waves-effect']); Waves.attach('.chip', ['waves-effect']); Waves.attach('.view a .mask', ['waves-light']); Waves.attach('.waves-light', ['waves-light']); Waves.attach('.navbar-nav a:not(.navbar-brand), .nav-icons li a, .nav-tabs .nav-item:not(.dropdown)', ['waves-light']); Waves.attach('.pager li a', ['waves-light']); Waves.attach('.pagination .page-item .page-link', ['waves-effect']); Waves.init(); “use strict”;

var _this = void 0;

(function ($) {

var inputSelector = "".concat(['text', 'password', 'email', 'url', 'tel', 'number', 'search', 'search-md'].map(function (selector) {
  return "input[type=".concat(selector, "]");
}).join(', '), ", textarea");
var textAreaSelector = '.materialize-textarea';

var updateTextFields = function updateTextFields($input) {
  var $labelAndIcon = $input.siblings('label, i');
  var hasValue = $input.val().length;
  var hasPlaceholder = $input.attr('placeholder');
  var addOrRemove = "".concat(hasValue || hasPlaceholder ? 'add' : 'remove', "Class");
  $labelAndIcon[addOrRemove]('active');
};

var validateField = function validateField($input) {
  if ($input.hasClass('validate')) {
    var value = $input.val();
    var noValue = !value.length;
    var isValid = !$input[0].validity.badInput;

    if (noValue && isValid) {
      $input.removeClass('valid').removeClass('invalid');
    } else {
      var valid = $input.is(':valid');
      var length = Number($input.attr('length')) || 0;

      if (valid && (!length || length > value.length)) {
        $input.removeClass('invalid').addClass('valid');
      } else {
        $input.removeClass('valid').addClass('invalid');
      }
    }
  }
};

var textAreaAutoResize = function textAreaAutoResize() {
  var $textarea = $(_this);

  if ($textarea.val().length) {
    var $hiddenDiv = $('.hiddendiv');
    var fontFamily = $textarea.css('font-family');
    var fontSize = $textarea.css('font-size');

    if (fontSize) {
      $hiddenDiv.css('font-size', fontSize);
    }

    if (fontFamily) {
      $hiddenDiv.css('font-family', fontFamily);
    }

    if ($textarea.attr('wrap') === 'off') {
      $hiddenDiv.css('overflow-wrap', 'normal').css('white-space', 'pre');
    }

    $hiddenDiv.text("".concat($textarea.val(), "\n"));
    var content = $hiddenDiv.html().replace(/\n/g, '<br>');
    $hiddenDiv.html(content); // When textarea is hidden, width goes crazy.
    // Approximate with half of window size

    $hiddenDiv.css('width', $textarea.is(':visible') ? $textarea.width() : $(window).width() / 2);
    $textarea.css('height', $hiddenDiv.height());
  }
};

$(inputSelector).each(function (index, input) {
  var $this = $(input);
  var $labelAndIcon = $this.siblings('label, i');
  updateTextFields($this);
  var isValid = input.validity.badInput;

  if (isValid) {
    $labelAndIcon.addClass('active');
  }
});
$(document).on('focus', inputSelector, function (e) {
  $(e.target).siblings('label, i').addClass('active');
});
$(document).on('blur', inputSelector, function (e) {
  var $this = $(e.target);
  var noValue = !$this.val();
  var invalid = !e.target.validity.badInput;
  var noPlaceholder = $this.attr('placeholder') === undefined;

  if (noValue && invalid && noPlaceholder) {
    $this.siblings('label, i').removeClass('active');
  }

  validateField($this);
});
$(document).on('change', inputSelector, function (e) {
  var $this = $(e.target);
  updateTextFields($this);
  validateField($this);
});
$('input[autofocus]').siblings('label, i').addClass('active');
$(document).on('reset', function (e) {
  var $formReset = $(e.target);

  if ($formReset.is('form')) {
    var $formInputs = $formReset.find(inputSelector);
    $formInputs.removeClass('valid').removeClass('invalid').each(function (index, input) {
      var $this = $(input);
      var noDefaultValue = !$this.val();
      var noPlaceholder = !$this.attr('placeholder');

      if (noDefaultValue && noPlaceholder) {
        $this.siblings('label, i').removeClass('active');
      }
    });
    $formReset.find('select.initialized').each(function (index, select) {
      var $select = $(select);
      var $visibleInput = $select.siblings('input.select-dropdown');
      var defaultValue = $select.children('[selected]').val();
      $select.val(defaultValue);
      $visibleInput.val(defaultValue);
    });
  }
});

function init() {
  var $text = $('.md-textarea-auto');

  if ($text.length) {
    var observe;

    if (window.attachEvent) {
      observe = function observe(element, event, handler) {
        element.attachEvent("on".concat(event), handler);
      };
    } else {
      observe = function observe(element, event, handler) {
        element.addEventListener(event, handler, false);
      };
    }

    $text.each(function () {
      var self = this;

      function resize() {
        self.style.height = 'auto';
        self.style.height = "".concat(self.scrollHeight, "px");
      }

      function delayedResize() {
        window.setTimeout(resize, 0);
      }

      observe(self, 'change', resize);
      observe(self, 'cut', delayedResize);
      observe(self, 'paste', delayedResize);
      observe(self, 'drop', delayedResize);
      observe(self, 'keydown', delayedResize);
      resize();
    });
  }
}

init();
var $body = $('body');

if (!$('.hiddendiv').first().length) {
  var $hiddenDiv = $('<div class="hiddendiv common"></div>');
  $body.append($hiddenDiv);
}

$(textAreaSelector).each(textAreaAutoResize);
$body.on('keyup keydown', textAreaSelector, textAreaAutoResize);

})(jQuery); “use strict”;

(function ($) {

$(document).on('click.card', '.card', function (e) {
  var $reveal = $(this).find('.card-reveal');

  if ($reveal.length) {
    var $clicked = $(e.target);
    var isTitle = $clicked.is('.card-reveal .card-title');
    var isTitleIcon = $clicked.is('.card-reveal .card-title i');
    var isActivator = $clicked.is('.card .activator');
    var isActivatorIcon = $clicked.is('.card .activator i');

    if (isTitle || isTitleIcon) {
      // down
      $(this).find('.card-reveal').velocity({
        translateY: 0
      }, {
        duration: 225,
        queue: false,
        easing: 'easeInOutQuad',
        complete: function complete() {
          $(this).css({
            display: 'none'
          });
        }
      });
    } else if (isActivator || isActivatorIcon) {
      // up
      $(this).find('.card-reveal').css({
        display: 'block'
      }).velocity('stop', false).velocity({
        translateY: '-100%'
      }, {
        duration: 300,
        queue: false,
        easing: 'easeInOutQuad'
      });
    }
  }
});
$('.rotate-btn').on('click', function () {
  var cardId = $(this).attr('data-card');
  $("#".concat(cardId)).toggleClass('flipped');
});
$(window).on('load', function () {
  var frontHeight = $('.front').outerHeight();
  var backHeight = $('.back').outerHeight();

  if (frontHeight > backHeight) {
    $('.card-wrapper, .back').height(frontHeight);
  } else if (frontHeight > backHeight) {
    $('.card-wrapper, .front').height(backHeight);
  } else {
    $('.card-wrapper').height(backHeight);
  }
});
$('.card-share > a').on('click', function (e) {
  e.preventDefault();
  $(this).toggleClass('share-expanded').parent().find('div').toggleClass('social-reveal-active');
});

})(jQuery);

$('.map-card').click(function () {

$('.card-body').toggleClass('closed');

}); “use strict”;

var SMOOTH_SCROLL_DURATION = 700; $('.smooth-scroll').on('click', 'a', function () {

var elAttr = $(this).attr('href');

if (typeof elAttr !== typeof undefined && elAttr.indexOf('#') === 0) {
  var offset = $(this).attr('data-offset') ? $(this).attr('data-offset') : 0;
  var setHash = $(this).parentsUntil('.smooth-scroll').last().parent().attr('data-allow-hashes');
  $('body,html').animate({
    scrollTop: $(elAttr).offset().top - offset
  }, SMOOTH_SCROLL_DURATION);

  if (typeof setHash !== typeof undefined && setHash !== false) {
    history.replaceState(null, null, elAttr);
  }

  return false;
}

}); “use strict”;

(function ($) {

$.fn.scrollTo = function (elem) {
  $(this).scrollTop($(this).scrollTop() - $(this).offset().top + $(elem).offset().top);
  return this;
};

$.fn.dropdown = function (option) {
  this.each(function () {
    var origin = $(this);
    var options = $.extend({}, $.fn.dropdown.defaults, option);
    var isFocused = false; // Dropdown menu

    var activates = $("#".concat(origin.attr('data-activates')));

    function updateOptions() {
      if (origin.data('induration') !== undefined) {
        options.inDuration = origin.data('inDuration');
      }

      if (origin.data('outduration') !== undefined) {
        options.outDuration = origin.data('outDuration');
      }

      if (origin.data('constrainwidth') !== undefined) {
        options.constrain_width = origin.data('constrainwidth');
      }

      if (origin.data('hover') !== undefined) {
        options.hover = origin.data('hover');
      }

      if (origin.data('gutter') !== undefined) {
        options.gutter = origin.data('gutter');
      }

      if (origin.data('beloworigin') !== undefined) {
        options.belowOrigin = origin.data('beloworigin');
      }

      if (origin.data('alignment') !== undefined) {
        options.alignment = origin.data('alignment');
      }
    }

    updateOptions(); // Attach dropdown to its activator

    origin.after(activates);
    /*
      Helper function to position and resize dropdown.
      Used in hover and click handler.
    */

    function placeDropdown(eventType) {
      // Check for simultaneous focus and click events.
      if (eventType === 'focus') {
        isFocused = true;
      } // Check html data attributes

      updateOptions(); // Set Dropdown state

      activates.addClass('active');
      origin.addClass('active'); // Constrain width

      if (options.constrain_width === true) {
        activates.css('width', origin.outerWidth());
      } else {
        activates.css('white-space', 'nowrap');
      } // Offscreen detection

      var windowHeight = window.innerHeight;
      var originHeight = origin.innerHeight();
      var offsetLeft = origin.offset().left;
      var offsetTop = origin.offset().top - $(window).scrollTop();
      var currAlignment = options.alignment;
      var gutterSpacing = 0;
      var leftPosition = 0; // Below Origin

      var verticalOffset = 0;

      if (options.belowOrigin === true) {
        verticalOffset = originHeight;
      } // Check for scrolling positioned container.

      var scrollOffset = 0;
      var wrapper = origin.parent();

      if (!wrapper.is('body') && wrapper[0].scrollHeight > wrapper[0].clientHeight) {
        scrollOffset = wrapper[0].scrollTop;
      }

      if (offsetLeft + activates.innerWidth() > $(window).width()) {
        // Dropdown goes past screen on right, force right alignment
        currAlignment = 'right';
      } else if (offsetLeft - activates.innerWidth() + origin.innerWidth() < 0) {
        // Dropdown goes past screen on left, force left alignment
        currAlignment = 'left';
      } // Vertical bottom offscreen detection

      if (offsetTop + activates.innerHeight() > windowHeight) {
        // If going upwards still goes offscreen, just crop height of dropdown.
        if (offsetTop + originHeight - activates.innerHeight() < 0) {
          var adjustedHeight = windowHeight - offsetTop - verticalOffset;
          activates.css('max-height', adjustedHeight);
        } else {
          // Flow upwards.
          if (!verticalOffset) {
            verticalOffset += originHeight;
          }

          verticalOffset -= activates.innerHeight();
        }
      } // Handle edge alignment

      if (currAlignment === 'left') {
        gutterSpacing = options.gutter;
        leftPosition = origin.position().left + gutterSpacing;
      } else if (currAlignment === 'right') {
        var offsetRight = origin.position().left + origin.outerWidth() - activates.outerWidth();
        gutterSpacing = -options.gutter;
        leftPosition = offsetRight + gutterSpacing;
      } // Position dropdown

      activates.css({
        position: 'absolute',
        top: origin.position().top + verticalOffset + scrollOffset,
        left: leftPosition
      }); // Show dropdown

      activates.stop(true, true).css('opacity', 0).slideDown({
        queue: false,
        duration: options.inDuration,
        easing: 'easeOutCubic',
        complete: function complete() {
          $(this).css('height', '');
        }
      }).animate({
        opacity: 1,
        scrollTop: 0
      }, {
        queue: false,
        duration: options.inDuration,
        easing: 'easeOutSine'
      });
    }

    function hideDropdown() {
      // Check for simultaneous focus and click events.
      isFocused = false;
      activates.fadeOut(options.outDuration);
      activates.removeClass('active');
      origin.removeClass('active');
      setTimeout(function () {
        activates.css('max-height', '');
      }, options.outDuration);
    } // Hover

    if (options.hover) {
      var open = false;
      origin.unbind("click.".concat(origin.attr('id'))); // Hover handler to show dropdown

      origin.on('mouseenter', function () {
        // Mouse over
        if (open === false) {
          placeDropdown();
          open = true;
        }
      });
      origin.on('mouseleave', function (e) {
        // If hover on origin then to something other than dropdown content, then close
        var toEl = e.toElement || e.relatedTarget; // added browser compatibility for target element

        if (!$(toEl).closest('.dropdown-content').is(activates)) {
          activates.stop(true, true);
          hideDropdown();
          open = false;
        }
      });
      activates.on('mouseleave', function (e) {
        // Mouse out
        var toEl = e.toElement || e.relatedTarget;

        if (!$(toEl).closest('.dropdown-button').is(origin)) {
          activates.stop(true, true);
          hideDropdown();
          open = false;
        }
      }); // Click
    } else {
      // Click handler to show dropdown
      origin.unbind("click.".concat(origin.attr('id')));
      origin.bind("click.".concat(origin.attr('id')), function (e) {
        if (!isFocused) {
          if (origin[0] === e.currentTarget && !origin.hasClass('active') && $(e.target).closest('.dropdown-content').length === 0) {
            e.preventDefault(); // Prevents button click from moving window

            placeDropdown('click');
          } else if (origin.hasClass('active')) {
            // If origin is clicked and menu is open, close menu
            hideDropdown();
            $(document).unbind("click.".concat(activates.attr('id'), " touchstart.").concat(activates.attr('id')));
          } // If menu open, add click close handler to document

          if (activates.hasClass('active')) {
            $(document).bind("click.".concat(activates.attr('id'), " touchstart.").concat(activates.attr('id')), function (e) {
              if (!activates.is(e.target) && !origin.is(e.target) && !origin.find(e.target).length) {
                hideDropdown();
                $(document).unbind("click.".concat(activates.attr('id'), " touchstart.").concat(activates.attr('id')));
              }
            });
          }
        }
      });
    }

    origin.on('open', function (e, eventType) {
      placeDropdown(eventType);
    });
    origin.on('close', hideDropdown);
  });
};

$.fn.dropdown.defaults = {
  inDuration: 300,
  outDuration: 225,
  constrain_width: true,
  hover: false,
  gutter: 0,
  belowOrigin: false,
  alignment: 'left'
};
$('.dropdown-button').dropdown();

$.fn.mdbDropSearch = function (options) {
  var $mdbInput = $(this).find('input');
  this.filter(function (value, index) {
    $(index).on('keyup', function () {
      var $linksInDropMenu = $mdbInput.closest('div[id]').find('a, li');

      for (var i = 0; i < $linksInDropMenu.length; i++) {
        if ($linksInDropMenu.eq(i).html().toUpperCase().indexOf($mdbInput.val().toUpperCase()) > -1) {
          $linksInDropMenu.eq(i).css({
            display: ''
          });
        } else {
          $linksInDropMenu.eq(i).css({
            display: 'none'
          });
        }
      }
    });
  });
  var settings = $.extend({
    color: '#000',
    backgroundColor: '',
    fontSize: '.9rem',
    fontWeight: '400',
    borderRadius: '',
    borderColor: ''
  }, options);
  return this.css({
    color: settings.color,
    backgroundColor: settings.backgroundColor,
    fontSize: settings.fontSize,
    fontWeight: settings.fontWeight,
    borderRadius: settings.borderRadius,
    border: settings.border,
    margin: settings.margin
  });
};

})(jQuery);

var dropdownSelectors = $('.dropdown, .dropup'); // Custom function to read dropdown data

function dropdownEffectData(target) {

// TODO - page level global?
var effectInDefault = 'fadeIn';
var effectOutDefault = 'fadeOut';
var dropdown = $(target);
var dropdownMenu = $('.dropdown-menu', target);
var parentUl = dropdown.parents('ul.nav'); // If parent is ul.nav allow global effect settings

if (parentUl.height > 0) {
  effectInDefault = parentUl.data('dropdown-in') || null;
  effectOutDefault = parentUl.data('dropdown-out') || null;
}

return {
  target: target,
  dropdown: dropdown,
  dropdownMenu: dropdownMenu,
  effectIn: dropdownMenu.data('dropdown-in') || effectInDefault,
  effectOut: dropdownMenu.data('dropdown-out') || effectOutDefault
};

} // Custom function to start effect (in or out)

function dropdownEffectStart(data, effectToStart) {

if (effectToStart) {
  data.dropdown.addClass('dropdown-animating');
  data.dropdownMenu.addClass(['animated', effectToStart].join(' '));
}

} // Custom function to read when animation is over

function dropdownEffectEnd(data, callbackFunc) {

var animationEnd = 'webkitAnimationEnd mozAnimationEnd MSAnimationEnd oanimationend animationend';
data.dropdown.one(animationEnd, function () {
  data.dropdown.removeClass('dropdown-animating');
  data.dropdownMenu.removeClass(['animated', data.effectIn, data.effectOut].join(' ')); // Custom callback option, used to remove open class in out effect

  if (typeof callbackFunc === 'function') {
    callbackFunc();
  }
});

} // Bootstrap API hooks

dropdownSelectors.on({

'show.bs.dropdown': function showBsDropdown() {
  // On show, start in effect
  var dropdown = dropdownEffectData(this);
  dropdownEffectStart(dropdown, dropdown.effectIn);
},
'shown.bs.dropdown': function shownBsDropdown() {
  // On shown, remove in effect once complete
  var dropdown = dropdownEffectData(this);

  if (dropdown.effectIn && dropdown.effectOut) {
    dropdownEffectEnd(dropdown);
  }
},
'hide.bs.dropdown': function hideBsDropdown(e) {
  // On hide, start out effect
  var dropdown = dropdownEffectData(this);

  if (dropdown.effectOut) {
    e.preventDefault();
    dropdownEffectStart(dropdown, dropdown.effectOut);
    dropdownEffectEnd(dropdown, function () {
      dropdown.dropdown.removeClass('show');
      dropdown.dropdownMenu.removeClass('show');
    });
  }
}

}); “use strict”;

(function ($) {

var _this = this;

$(document).ready(function () {
  $(document).on('mouseenter', '.fixed-action-btn', function () {
    var $this = $(this);
    openFABMenu($this);
  });
  $(document).on('mouseleave', '.fixed-action-btn', function () {
    var $this = $(this);
    closeFABMenu($this);
  });
  $(document).on('click', '.fixed-action-btn > a', function () {
    var $this = $(this);
    var $menu = $this.parent();
    $menu.hasClass('active') ? openFABMenu($menu) : closeFABMenu($menu);

    if ($menu.hasClass('active')) {
      closeFABMenu($menu);
    } else {
      openFABMenu($menu);
    }
  });
});
$.fn.extend({
  openFAB: function openFAB() {
    openFABMenu($(this));
  },
  closeFAB: function closeFAB() {
    closeFABMenu($(this));
  }
});

var openFABMenu = function openFABMenu(btn) {
  var fab = btn;

  if (!fab.hasClass('active')) {
    fab.addClass('active');
    var btnList = document.querySelectorAll('ul .btn-floating');
    btnList.forEach(function (el) {
      el.classList.add('shown');
    });
  }
};

var closeFABMenu = function closeFABMenu(btn) {
  var fab = btn;
  fab.removeClass('active');
  var btnList = document.querySelectorAll('ul .btn-floating');
  btnList.forEach(function (el) {
    el.classList.remove('shown');
  });
};

$('.fixed-action-btn:not(.smooth-scroll) > .btn-floating').on('click', function (e) {
  if (!$(_this).hasClass('smooth-scroll')) {
    e.preventDefault();
    toggleFABMenu($('.fixed-action-btn'));
    return false;
  }
});

function toggleFABMenu(btn) {
  var elem = btn;

  if (elem.hasClass('active')) {
    closeFABMenu(elem);
  } else {
    openFABMenu(elem);
  }
}

})(jQuery); “use strict”;

function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(“Cannot call a class as a function”); } }

function _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (“value” in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } }

function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; }

(function ($) {

var MENU_WIDTH = 240;
var SN_BREAKPOINT = 1440;
var MENU_WIDTH_HALF = 2;
var MENU_LEFT_MIN_BORDER = 0.3;
var MENU_LEFT_MAX_BORDER = -0.5;
var MENU_RIGHT_MIN_BORDER = -0.3;
var MENU_RIGHT_MAX_BORDER = 0.5;
var MENU_VELOCITY_OFFSET = 10;
var MENU_TIME_DURATION_OPEN = 300;
var MENU_TIME_DURATION_CLOSE = 200;
var MENU_TIME_DURATION_OVERLAY_OPEN = 50;
var MENU_TIME_DURATION_OVERLAY_CLOSE = 200;
var MENU_EASING_OPEN = 'easeOutQuad';
var MENU_EASING_CLOSE = 'easeOutCubic';
var SHOW_OVERLAY = true;
var SHOW_CLOSE_BUTTON = false;

var SideNav =
/*#__PURE__*/
function () {
  function SideNav(element, options) {
    _classCallCheck(this, SideNav);

    this.defaults = {
      MENU_WIDTH: MENU_WIDTH,
      edge: 'left',
      closeOnClick: false,
      breakpoint: SN_BREAKPOINT,
      timeDurationOpen: MENU_TIME_DURATION_OPEN,
      timeDurationClose: MENU_TIME_DURATION_CLOSE,
      timeDurationOverlayOpen: MENU_TIME_DURATION_OVERLAY_OPEN,
      timeDurationOverlayClose: MENU_TIME_DURATION_OVERLAY_CLOSE,
      easingOpen: MENU_EASING_OPEN,
      easingClose: MENU_EASING_CLOSE,
      showOverlay: SHOW_OVERLAY,
      showCloseButton: SHOW_CLOSE_BUTTON
    };
    this.$element = element;
    this.$elementCloned = element.clone().css({
      display: 'inline-block',
      lineHeight: '24px'
    });
    this.options = this.assignOptions(options);
    this.menuOut = false;
    this.lastTouchVelocity = {
      x: {
        startPosition: 0,
        startTime: 0,
        endPosition: 0,
        endTime: 0
      }
    };
    this.$body = $('body');
    this.$menu = $("#".concat(this.$element.attr('data-activates')));
    this.$sidenavOverlay = $('#sidenav-overlay');
    this.$dragTarget = $('<div class="drag-target"></div>');
    this.$body.append(this.$dragTarget);
    this.init();
  }

  _createClass(SideNav, [{
    key: "init",
    value: function init() {
      this.setMenuWidth();
      this.setMenuTranslation();
      this.closeOnClick();
      this.openOnClick();
      this.bindTouchEvents();
      this.showCloseButton();
      this.inputOnClick();
    }
  }, {
    key: "bindTouchEvents",
    value: function bindTouchEvents() {
      var _this = this;

      this.$dragTarget.on('click', function () {
        return _this.removeMenu();
      });
      this.$elementCloned.on('click', function () {
        return _this.removeMenu();
      });
      this.$dragTarget.on('touchstart', function (e) {
        _this.lastTouchVelocity.x.startPosition = e.touches[0].clientX;
        _this.lastTouchVelocity.x.startTime = Date.now();
      });
      this.$dragTarget.on('touchmove', this.touchmoveEventHandler.bind(this));
      this.$dragTarget.on('touchend', this.touchendEventHandler.bind(this));
    }
  }, {
    key: "touchmoveEventHandler",
    value: function touchmoveEventHandler(e) {
      if (e.type !== 'touchmove') {
        return;
      }

      var touch = e.touches[0];
      var touchX = touch.clientX; // calculate velocity every 20ms

      if (Date.now() - this.lastTouchVelocity.x.startTime > 20) {
        this.lastTouchVelocity.x.startPosition = touch.clientX;
        this.lastTouchVelocity.x.startTime = Date.now();
      }

      this.disableScrolling();
      var overlayExists = this.$sidenavOverlay.length !== 0;

      if (!overlayExists) {
        this.buildSidenavOverlay();
      } // Keep within boundaries

      if (this.options.edge === 'left') {
        if (touchX > this.options.MENU_WIDTH) {
          touchX = this.options.MENU_WIDTH;
        } else if (touchX < 0) {
          touchX = 0;
        }
      }

      this.translateSidenavX(touchX);
      this.updateOverlayOpacity(touchX);
    }
  }, {
    key: "panEventHandler",
    value: function panEventHandler(e) {
      if (e.gesture.pointerType !== 'touch') {
        return;
      }

      var touchX = e.gesture.center.x;
      this.disableScrolling();
      var overlayExists = this.$sidenavOverlay.length !== 0;

      if (!overlayExists) {
        this.buildSidenavOverlay();
      } // Keep within boundaries

      if (this.options.edge === 'left') {
        if (touchX > this.options.MENU_WIDTH) {
          touchX = this.options.MENU_WIDTH;
        } else if (touchX < 0) {
          touchX = 0;
        }
      }

      this.translateSidenavX(touchX);
      this.updateOverlayOpacity(touchX);
    }
  }, {
    key: "translateSidenavX",
    value: function translateSidenavX(touchX) {
      if (this.options.edge === 'left') {
        var isRightDirection = touchX >= this.options.MENU_WIDTH / MENU_WIDTH_HALF;
        this.menuOut = isRightDirection;
        this.$menu.css('transform', "translateX(".concat(touchX - this.options.MENU_WIDTH, "px)"));
      } else {
        var isLeftDirection = touchX < window.innerWidth - this.options.MENU_WIDTH / MENU_WIDTH_HALF;
        this.menuOut = isLeftDirection;
        var rightPos = touchX - this.options.MENU_WIDTH / MENU_WIDTH_HALF;

        if (rightPos < 0) {
          rightPos = 0;
        }

        this.$menu.css('transform', "translateX(".concat(rightPos, "px)"));
      }
    }
  }, {
    key: "updateOverlayOpacity",
    value: function updateOverlayOpacity(touchX) {
      var overlayPercentage;

      if (this.options.edge === 'left') {
        overlayPercentage = touchX / this.options.MENU_WIDTH;
      } else {
        overlayPercentage = Math.abs((touchX - window.innerWidth) / this.options.MENU_WIDTH);
      }

      this.$sidenavOverlay.velocity({
        opacity: overlayPercentage
      }, {
        duration: 10,
        queue: false,
        easing: this.options.easingOpen
      });
    }
  }, {
    key: "buildSidenavOverlay",
    value: function buildSidenavOverlay() {
      var _this2 = this;

      if (this.options.showOverlay === true) {
        this.$sidenavOverlay = $('<div id="sidenav-overlay"></div>');
        this.$sidenavOverlay.css('opacity', 0).on('click', function () {
          return _this2.removeMenu();
        });
        this.$body.append(this.$sidenavOverlay);
      }
    }
  }, {
    key: "disableScrolling",
    value: function disableScrolling() {
      var oldWidth = this.$body.innerWidth();
      this.$body.css('overflow', 'hidden');
      this.$body.width(oldWidth);
    }
  }, {
    key: "touchendEventHandler",
    value: function touchendEventHandler(e) {
      if (e.type !== 'touchend') {
        return;
      }

      var touch = e.changedTouches[0];
      this.lastTouchVelocity.x.endTime = Date.now();
      this.lastTouchVelocity.x.endPosition = touch.clientX;
      var velocityX = this.calculateTouchVelocityX();
      var touchX = touch.clientX;
      var leftPos = touchX - this.options.MENU_WIDTH;
      var rightPos = touchX - this.options.MENU_WIDTH / MENU_WIDTH_HALF;

      if (leftPos > 0) {
        leftPos = 0;
      }

      if (rightPos < 0) {
        rightPos = 0;
      }

      if (this.options.edge === 'left') {
        // If velocityX <= 0.3 then the user is flinging the menu closed so ignore this.menuOut
        if (this.menuOut && velocityX <= MENU_LEFT_MIN_BORDER || velocityX < MENU_LEFT_MAX_BORDER) {
          if (leftPos !== 0) {
            this.translateMenuX([0, leftPos], '300');
          }

          this.showSidenavOverlay();
        } else if (!this.menuOut || velocityX > MENU_LEFT_MIN_BORDER) {
          this.enableScrolling();
          this.translateMenuX([-1 * this.options.MENU_WIDTH - MENU_VELOCITY_OFFSET, leftPos], '200');
          this.hideSidenavOverlay();
        }

        this.$dragTarget.css({
          width: '10px',
          right: '',
          left: 0
        });
      } else if (this.menuOut && velocityX >= MENU_RIGHT_MIN_BORDER || velocityX > MENU_RIGHT_MAX_BORDER) {
        this.translateMenuX([0, rightPos], '300');
        this.showSidenavOverlay();
        this.$dragTarget.css({
          width: '50%',
          right: '',
          left: 0
        });
      } else if (!this.menuOut || velocityX < MENU_RIGHT_MIN_BORDER) {
        this.enableScrolling();
        this.translateMenuX([this.options.MENU_WIDTH + MENU_VELOCITY_OFFSET, rightPos], '200');
        this.hideSidenavOverlay();
        this.$dragTarget.css({
          width: '10px',
          right: 0,
          left: ''
        });
      }
    }
  }, {
    key: "calculateTouchVelocityX",
    value: function calculateTouchVelocityX() {
      var distance = Math.abs(this.lastTouchVelocity.x.endPosition - this.lastTouchVelocity.x.startPosition);
      var time = Math.abs(this.lastTouchVelocity.x.endTime - this.lastTouchVelocity.x.startTime);
      return distance / time;
    }
  }, {
    key: "panendEventHandler",
    value: function panendEventHandler(e) {
      if (e.gesture.pointerType !== 'touch') {
        return;
      }

      var velocityX = e.gesture.velocityX;
      var touchX = e.gesture.center.x;
      var leftPos = touchX - this.options.MENU_WIDTH;
      var rightPos = touchX - this.options.MENU_WIDTH / MENU_WIDTH_HALF;

      if (leftPos > 0) {
        leftPos = 0;
      }

      if (rightPos < 0) {
        rightPos = 0;
      }

      if (this.options.edge === 'left') {
        // If velocityX <= 0.3 then the user is flinging the menu closed so ignore this.menuOut
        if (this.menuOut && velocityX <= MENU_LEFT_MIN_BORDER || velocityX < MENU_LEFT_MAX_BORDER) {
          if (leftPos !== 0) {
            this.translateMenuX([0, leftPos], '300');
          }

          this.showSidenavOverlay();
        } else if (!this.menuOut || velocityX > MENU_LEFT_MIN_BORDER) {
          this.enableScrolling();
          this.translateMenuX([-1 * this.options.MENU_WIDTH - MENU_VELOCITY_OFFSET, leftPos], '200');
          this.hideSidenavOverlay();
        }

        this.$dragTarget.css({
          width: '10px',
          right: '',
          left: 0
        });
      } else if (this.menuOut && velocityX >= MENU_RIGHT_MIN_BORDER || velocityX > MENU_RIGHT_MAX_BORDER) {
        this.translateMenuX([0, rightPos], '300');
        this.showSidenavOverlay();
        this.$dragTarget.css({
          width: '50%',
          right: '',
          left: 0
        });
      } else if (!this.menuOut || velocityX < MENU_RIGHT_MIN_BORDER) {
        this.enableScrolling();
        this.translateMenuX([this.options.MENU_WIDTH + MENU_VELOCITY_OFFSET, rightPos], '200');
        this.hideSidenavOverlay();
        this.$dragTarget.css({
          width: '10px',
          right: 0,
          left: ''
        });
      }
    }
  }, {
    key: "translateMenuX",
    value: function translateMenuX(fromTo, duration) {
      this.$menu.velocity({
        translateX: fromTo
      }, {
        duration: typeof duration === 'string' ? Number(duration) : duration,
        queue: false,
        easing: this.options.easingOpen
      });
    }
  }, {
    key: "hideSidenavOverlay",
    value: function hideSidenavOverlay() {
      this.$sidenavOverlay.velocity({
        opacity: 0
      }, {
        duration: this.options.timeDurationOverlayClose,
        queue: false,
        easing: this.options.easingOpen,
        complete: function complete() {
          $(this).remove();
        }
      });
    }
  }, {
    key: "showSidenavOverlay",
    value: function showSidenavOverlay() {
      this.$sidenavOverlay.velocity({
        opacity: 1
      }, {
        duration: this.options.timeDurationOverlayOpen,
        queue: false,
        easing: this.options.easingOpen
      });
    }
  }, {
    key: "enableScrolling",
    value: function enableScrolling() {
      this.$body.css({
        overflow: '',
        width: ''
      });
    }
  }, {
    key: "openOnClick",
    value: function openOnClick() {
      var _this3 = this;

      this.$element.on('click', function (e) {
        e.preventDefault();

        if (_this3.menuOut === true) {
          _this3.menuOut = false;

          _this3.removeMenu();
        } else {
          if (_this3.options.showOverlay === true) {
            _this3.$sidenavOverlay = $('<div id="sidenav-overlay"></div>');

            _this3.$body.append(_this3.$sidenavOverlay);
          } else {
            _this3.showCloseButton();
          }

          var translateX = [];

          if (_this3.options.edge === 'left') {
            translateX = [0, -1 * _this3.options.MENU_WIDTH];
          } else {
            translateX = [0, _this3.options.MENU_WIDTH];
          }

          _this3.$menu.velocity({
            translateX: translateX
          }, {
            duration: _this3.options.timeDurationOpen,
            queue: false,
            easing: _this3.options.easingOpen
          });

          _this3.$sidenavOverlay.on('click', function () {
            return _this3.removeMenu();
          });

          _this3.$sidenavOverlay.on('touchmove', _this3.touchmoveEventHandler.bind(_this3));

          _this3.$menu.on('touchmove', function (e) {
            e.preventDefault();

            _this3.$menu.find('.custom-scrollbar').css('padding-bottom', '30px');
          });
        }
      });
    }
  }, {
    key: "closeOnClick",
    value: function closeOnClick() {
      var _this4 = this;

      if (this.options.closeOnClick === true) {
        this.$menu.on('click', 'a:not(.collapsible-header)', function () {
          return _this4.removeMenu();
        });
      }
    }
  }, {
    key: "showCloseButton",
    value: function showCloseButton() {
      if (this.options.showCloseButton === true) {
        this.$menu.prepend(this.$elementCloned);
        this.$menu.find('.logo-wrapper').css({
          borderTop: '1px solid rgba(153,153,153,.3)'
        });
      }
    }
  }, {
    key: "setMenuTranslation",
    value: function setMenuTranslation() {
      var _this5 = this;

      if (this.options.edge === 'left') {
        this.$menu.css('transform', 'translateX(-100%)');
        this.$dragTarget.css({
          left: 0
        });
      } else {
        this.$menu.addClass('right-aligned').css('transform', 'translateX(100%)');
        this.$dragTarget.css({
          right: 0
        });
      }

      if (this.$menu.hasClass('fixed')) {
        if (window.innerWidth > this.options.breakpoint) {
          this.$menu.css('transform', 'translateX(0)');
        }

        this.$menu.find('input[type=text]').on('touchstart', function () {
          _this5.$menu.addClass('transform-fix-input');
        });
        $(window).resize(function () {
          if (window.innerWidth > _this5.options.breakpoint) {
            if (_this5.$sidenavOverlay.length) {
              _this5.removeMenu(true);
            } else {
              _this5.$menu.css('transform', 'translateX(0%)');
            }
          } else if (_this5.menuOut === false) {
            var xValue = _this5.options.edge === 'left' ? '-100' : '100';

            _this5.$menu.css('transform', "translateX(".concat(xValue, "%)"));
          }
        });
      }
    }
  }, {
    key: "setMenuWidth",
    value: function setMenuWidth() {
      var $sidenavBg = $("#".concat(this.$menu.attr('id'))).find('> .sidenav-bg');

      if (this.options.MENU_WIDTH !== MENU_WIDTH) {
        this.$menu.css('width', this.options.MENU_WIDTH);
        $sidenavBg.css('width', this.options.MENU_WIDTH);
      }
    }
  }, {
    key: "inputOnClick",
    value: function inputOnClick() {
      var _this6 = this;

      this.$menu.find('input[type=text]').on('touchstart', function () {
        return _this6.$menu.css('transform', 'translateX(0)');
      });
    }
  }, {
    key: "assignOptions",
    value: function assignOptions(newOptions) {
      return $.extend({}, this.defaults, newOptions);
    }
  }, {
    key: "removeMenu",
    value: function removeMenu(restoreMenu) {
      var _this7 = this;

      this.$body.css({
        overflow: '',
        width: ''
      });
      this.$menu.velocity({
        translateX: this.options.edge === 'left' ? '-100%' : '100%'
      }, {
        duration: this.options.timeDurationClose,
        queue: false,
        easing: this.options.easingClose,
        complete: function complete() {
          if (restoreMenu === true) {
            _this7.$menu.removeAttr('style');

            _this7.$menu.css('width', _this7.options.MENU_WIDTH);
          }
        }
      });

      if (this.$menu.hasClass('transform-fix-input')) {
        this.$menu.removeClass('transform-fix-input');
      }

      this.hideSidenavOverlay();
    }
  }]);

  return SideNav;
}();

$.fn.sideNav = function (options) {
  return this.each(function () {
    new SideNav($(this), options);
  });
};

})(jQuery);

$(function () {

$("#toggle").click(function () {
  if ($("#slide-out").hasClass('slim')) {
    $("#slide-out").removeClass('slim');
    $(".sv-slim-icon").removeClass('fa-angle-double-right').addClass('fa-angle-double-left');
  } else {
    $("#slide-out").addClass('slim');
    $(".sv-slim-icon").removeClass('fa-angle-double-left').addClass('fa-angle-double-right');
  }
});

}); “use strict”;

(function ($) {

$.fn.collapsible = function (options) {
  var defaults = {
    accordion: undefined
  };
  options = $.extend(defaults, options);

  function accordionOpen($collapsible, object) {
    $panelHeaders = $collapsible.find('> li > .collapsible-header');

    if (object.hasClass('active')) {
      object.parent().addClass('active');
    } else {
      object.parent().removeClass('active');
    }

    if (object.parent().hasClass('active')) {
      object.siblings('.collapsible-body').stop(true, false).slideDown({
        duration: 350,
        easing: 'easeOutQuart',
        queue: false,
        complete: function complete() {
          $(this).css('height', '');
        }
      });
    } else {
      object.siblings('.collapsible-body').stop(true, false).slideUp({
        duration: 350,
        easing: 'easeOutQuart',
        queue: false,
        complete: function complete() {
          $(this).css('height', '');
        }
      });
    }

    $panelHeaders.not(object).removeClass('active').parent().removeClass('active');
    $panelHeaders.not(object).parent().children('.collapsible-body').stop(true, false).slideUp({
      duration: 350,
      easing: 'easeOutQuart',
      queue: false,
      complete: function complete() {
        $(this).css('height', '');
      }
    });
  }

  function expandableOpen(object) {
    if (object.hasClass('active')) {
      object.parent().addClass('active');
    } else {
      object.parent().removeClass('active');
    }

    if (object.parent().hasClass('active')) {
      object.siblings('.collapsible-body').stop(true, false).slideDown({
        duration: 350,
        easing: 'easeOutQuart',
        queue: false,
        complete: function complete() {
          $(this).css('height', '');
        }
      });
    } else {
      object.siblings('.collapsible-body').stop(true, false).slideUp({
        duration: 350,
        easing: 'easeOutQuart',
        queue: false,
        complete: function complete() {
          $(this).css('height', '');
        }
      });
    }
  }

  function isChildrenOfPanelHeader(object) {
    var panelHeader = getPanelHeader(object);
    return panelHeader.length > 0;
  }

  function getPanelHeader(object) {
    return object.closest('li > .collapsible-header');
  }

  return this.each(function () {
    var $this = $(this);
    var $panelHeaders = $(this).find('> li > .collapsible-header');
    var collapsibleType = $this.data('collapsible'); // Turn off any existing event handlers

    $this.off('click.collapse', '.collapsible-header');
    $panelHeaders.off('click.collapse');

    if (options.accordion || collapsibleType === 'accordion' || collapsibleType === undefined) {
      $panelHeaders = $this.find('> li > .collapsible-header');
      $panelHeaders.on('click.collapse', function (e) {
        var element = $(e.target);

        if (isChildrenOfPanelHeader(element)) {
          element = getPanelHeader(element);
        }

        element.toggleClass('active');
        accordionOpen($this, element);
      });
      accordionOpen($this, $panelHeaders.filter('.active').first());
    } else {
      $panelHeaders.each(function () {
        $(this).on('click.collapse', function (e) {
          var element = $(e.target);

          if (isChildrenOfPanelHeader(element)) {
            element = getPanelHeader(element);
          }

          element.toggleClass('active');
          expandableOpen(element);
        });

        if ($(this).hasClass('active')) {
          expandableOpen($(this));
        }
      });
    }
  });
};

$('.collapsible').collapsible();

})(jQuery); “use strict”;

function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(“Cannot call a class as a function”); } }

function _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (“value” in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } }

function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; }

(function ($) {

var MaterialSelect =
/*#__PURE__*/
function () {
  function MaterialSelect($nativeSelect, options) {
    _classCallCheck(this, MaterialSelect);

    this.$nativeSelect = $nativeSelect;
    this.defaults = {
      destroy: false,
      nativeID: null,
      BSsearchIn: false,
      BSinputText: false,
      fasClasses: '',
      farClasses: '',
      fabClasses: '',
      copyClassesOption: false,
      language: {
        active: false,
        pl: {
          selectAll: 'Wybierz wszystko',
          optionsSelected: 'wybranych opcji'
        },
        in: {
          selectAll: 'Pilih semuanya',
          optionsSelected: 'opsi yang dipilih'
        },
        fr: {
          selectAll: 'Tout choisir',
          optionsSelected: 'options sélectionnées'
        },
        ge: {
          selectAll: 'Wähle alles aus',
          optionsSelected: 'ausgewählte Optionen'
        },
        ar: {
          selectAll: 'اختر كل شيء',
          optionsSelected: 'الخيارات المحددة'
        }
      }
    };
    this.options = this.assignOptions(options);
    this.isMultiple = Boolean(this.$nativeSelect.attr('multiple'));
    this.isSearchable = Boolean(this.$nativeSelect.attr('searchable'));
    this.isRequired = Boolean(this.$nativeSelect.attr('required'));
    this.uuid = this.options.nativeID !== null && this.options.nativeID !== '' && this.options.nativeID !== undefined && typeof this.options.nativeID === 'string' ? this.options.nativeID : this._randomUUID();
    this.$selectWrapper = $('<div class="select-wrapper"></div>');
    this.$materialOptionsList = $("<ul id=\"select-options-".concat(this.uuid, "\" class=\"dropdown-content select-dropdown w-100 ").concat(this.isMultiple ? 'multiple-select-dropdown' : '', "\"></ul>"));
    this.$materialSelectedOption = this.$nativeSelect.find('option:selected');
    this.$materialSelectInitialOption = this.$nativeSelect.find('option:first').text() || '';
    this.$nativeSelectChildren = this.$nativeSelect.children('option, optgroup');
    this.$materialSelect = $("<input type=\"text\" class=\"".concat(this.options.BSinputText ? 'browser-default custom-select multi-bs-select select-dropdown' : 'select-dropdown', "\" readonly=\"true\" ").concat(this.$nativeSelect.is(' :disabled') ? 'disabled' : '', " data-activates=\"select-options-").concat(this.uuid, "\" value=\"\"/>"));
    this.$dropdownIcon = this.options.BSinputText ? '' : $('<span class="caret">&#9660;</span>');
    this.$searchInput = null;
    this.$toggleAll = $('<li class="select-toggle-all"><span><input type="checkbox" class="form-check-input"><label>Select all</label></span></li>');
    this.label = this.$nativeSelect.next('label').not('.mdb-main-label');
    this.mainLabel = this.$nativeSelect.next('.mdb-main-label');
    this.valuesSelected = [];
    this.keyCodes = {
      tab: 9,
      esc: 27,
      enter: 13,
      arrowUp: 38,
      arrowDown: 40
    };
    MaterialSelect.mutationObservers = [];
  }

  _createClass(MaterialSelect, [{
    key: "assignOptions",
    value: function assignOptions(newOptions) {
      return $.extend({}, this.defaults, newOptions);
    }
  }, {
    key: "init",
    value: function init() {
      var alreadyInitialized = Boolean(this.$nativeSelect.data('select-id'));

      if (alreadyInitialized) {
        this._removeMaterialWrapper();
      }

      if (this.options.destroy) {
        this.$nativeSelect.data('select-id', null).removeClass('initialized');
        return;
      }

      if (this.options.BSsearchIn || this.options.BSinputText) {
        this.$selectWrapper.addClass(this.$nativeSelect.attr('class').split(' ').filter(function (el) {
          return el !== 'md-form';
        }).join(' ')).css({
          marginTop: '1.5rem',
          marginBottom: '1.5rem'
        });
      } else {
        this.$selectWrapper.addClass(this.$nativeSelect.attr('class'));
      }

      this.$nativeSelect.data('select-id', this.uuid);
      var sanitizedLabelHtml = this.$materialSelectInitialOption.replace(/"/g, '&quot;').replace(/  +/g, ' ').trim();

      if (this.mainLabel.length === 0) {
        this.$materialSelect.val(sanitizedLabelHtml);
      } else {
        this.mainLabel.text();
      }

      if (this.$materialSelectedOption.length > 0 && this.$nativeSelect.hasClass('md-selected')) {
        this.mainLabel.addClass('active');
        this.$materialSelect.val(this.$materialSelectedOption.text());
      }

      this.renderMaterialSelect();
      this.bindEvents();

      if (this.isRequired) {
        this.enableValidation();
      }

      if (this.options.language.active && this.$toggleAll) {
        if (this.options.language.pl) {
          this.$toggleAll.find('label').text(this.options.language.pl.selectAll ? this.options.language.pl.selectAll : this.defaults.language.pl.selectAll);
        }

        if (this.options.language.fr) {
          this.$toggleAll.find('label').text(this.options.language.fr.selectAll ? this.options.language.fr.selectAll : this.defaults.language.fr.selectAll);
        }

        if (this.options.language.ge) {
          this.$toggleAll.find('label').text(this.options.language.ge.selectAll ? this.options.language.ge.selectAll : this.defaults.language.ge.selectAll);
        }

        if (this.options.language.ar) {
          this.$toggleAll.find('label').text(this.options.language.ar.selectAll ? this.options.language.ar.selectAll : this.defaults.language.ar.selectAll);
        }

        if (this.options.language.in) {
          this.$toggleAll.find('label').text(this.options.language.in.selectAll ? this.options.language.in.selectAll : this.defaults.language.in.selectAll);
        }
      }

      if (this.$materialSelect.hasClass('custom-select') && this.$materialSelect.hasClass('select-dropdown')) {
        this.$materialSelect.css({
          display: 'inline-block',
          width: '100%',
          height: 'calc(1.5em + .75rem + 2px)',
          padding: '.375rem 1.75rem .375rem .75rem',
          fontSize: '1rem',
          lineHeight: '1.5',
          backgroundColor: '#fff',
          border: '1px solid #ced4da'
        });
      }
    }
  }, {
    key: "_removeMaterialWrapper",
    value: function _removeMaterialWrapper() {
      var currentUuid = this.$nativeSelect.data('select-id');
      this.$nativeSelect.parent().find('span.caret').remove();
      this.$nativeSelect.parent().find('input').remove();
      this.$nativeSelect.unwrap();
      $("ul#select-options-".concat(currentUuid)).remove();
    }
  }, {
    key: "renderMaterialSelect",
    value: function renderMaterialSelect() {
      var _this = this;

      this.$nativeSelect.before(this.$selectWrapper);
      this.appendDropdownIcon();
      this.appendMaterialSelect();
      this.appendMaterialOptionsList();
      this.appendNativeSelect();
      this.appendSaveSelectButton();

      if (!this.$nativeSelect.is(':disabled')) {
        this.$materialSelect.dropdown({
          hover: false,
          closeOnClick: false
        });
      }

      if (this.$nativeSelect.data('inherit-tabindex') !== false) {
        this.$materialSelect.attr('tabindex', this.$nativeSelect.attr('tabindex'));
      }

      if (this.isMultiple) {
        this.$nativeSelect.find('option:selected:not(:disabled)').each(function (i, element) {
          var index = element.index;

          _this._toggleSelectedValue(index);

          _this.$materialOptionsList.find('li:not(.optgroup):not(.select-toggle-all)').eq(index).find(':checkbox').prop('checked', true);
        });
      } else {
        var index = this.$nativeSelect.find('option:selected').index();
        this.$materialOptionsList.find('li').eq(index).addClass('active');
      }

      this.$nativeSelect.addClass('initialized');

      if (this.options.BSinputText) {
        this.mainLabel.css('top', '-7px');
      }
    }
  }, {
    key: "appendDropdownIcon",
    value: function appendDropdownIcon() {
      if (this.$nativeSelect.is(':disabled')) {
        this.$dropdownIcon.addClass('disabled');
      }

      this.$selectWrapper.append(this.$dropdownIcon);
    }
  }, {
    key: "appendMaterialSelect",
    value: function appendMaterialSelect() {
      this.$selectWrapper.append(this.$materialSelect);
    }
  }, {
    key: "appendMaterialOptionsList",
    value: function appendMaterialOptionsList() {
      if (this.isSearchable) {
        this.appendSearchInputOption();
      }

      this.buildMaterialOptions();

      if (this.isMultiple) {
        this.appendToggleAllCheckbox();
      }

      this.$selectWrapper.append(this.$materialOptionsList);
    }
  }, {
    key: "appendNativeSelect",
    value: function appendNativeSelect() {
      this.$nativeSelect.appendTo(this.$selectWrapper);
    }
  }, {
    key: "appendSearchInputOption",
    value: function appendSearchInputOption() {
      var placeholder = this.$nativeSelect.attr('searchable');

      if (this.options.BSsearchIn) {
        this.$searchInput = $("<span class=\"search-wrap ml-2\"><div class=\"mt-0\"><input type=\"text\" class=\"search form-control mb-2 w-100 d-block select-default\" placeholder=\"".concat(placeholder, "\"></div></span>"));
      } else {
        this.$searchInput = $("<span class=\"search-wrap ml-2\"><div class=\"md-form mt-0\"><input type=\"text\" class=\"search form-control w-100 d-block\" placeholder=\"".concat(placeholder, "\"></div></span>"));
      }

      this.$materialOptionsList.append(this.$searchInput);
      this.$searchInput.on('click', function (e) {
        e.stopPropagation();
      });
    }
  }, {
    key: "appendToggleAllCheckbox",
    value: function appendToggleAllCheckbox() {
      this.$materialOptionsList.find('li.disabled').first().after(this.$toggleAll);
    }
  }, {
    key: "appendSaveSelectButton",
    value: function appendSaveSelectButton() {
      this.$selectWrapper.parent().find('button.btn-save').appendTo(this.$materialOptionsList);
    }
  }, {
    key: "buildMaterialOptions",
    value: function buildMaterialOptions() {
      var _this2 = this;

      this.$nativeSelectChildren.each(function (index, option) {
        var $this = $(option);

        if ($this.is('option')) {
          _this2.buildSingleOption($this, _this2.isMultiple ? 'multiple' : '');
        } else if ($this.is('optgroup')) {
          var $materialOptgroup = $("<li class=\"optgroup\"><span>".concat($this.attr('label'), "</span></li>"));

          _this2.$materialOptionsList.append($materialOptgroup);

          var $optgroupOptions = $this.children('option');
          $optgroupOptions.each(function (index, optgroupOption) {
            _this2.buildSingleOption($(optgroupOption), 'optgroup-option');
          });
        }
      });
    }
  }, {
    key: "buildSingleOption",
    value: function buildSingleOption($nativeSelectChild, type) {
      var disabled = $nativeSelectChild.is(':disabled') ? 'disabled' : '';
      var optgroupClass = type === 'optgroup-option' ? 'optgroup-option' : '';
      var iconUrl = $nativeSelectChild.data('icon');
      var fas = $nativeSelectChild.data('fas') ? "<i class=\"fa-pull-right m-2 fas fa-".concat($nativeSelectChild.data('fas'), " ").concat([...this.options.fasClasses].join(''), "\"></i> ") : '';
      var far = $nativeSelectChild.data('far') ? "<i class=\"fa-pull-right m-2 far fa-".concat($nativeSelectChild.data('far'), " ").concat([...this.options.farClasses].join(''), "\"></i> ") : '';
      var fab = $nativeSelectChild.data('fab') ? "<i class=\"fa-pull-right m-2 fab fa-".concat($nativeSelectChild.data('fab'), " ").concat([...this.options.fabClasses].join(''), "\"></i> ") : '';
      var classes = $nativeSelectChild.attr('class');
      var iconHtml = iconUrl ? "<img alt=\"\" src=\"".concat(iconUrl, "\" class=\"").concat(classes, "\">") : '';
      var checkboxHtml = this.isMultiple ? "<input type=\"checkbox\" class=\"form-check-input\" ".concat(disabled, "/><label></label>") : '';
      this.$materialOptionsList.append($("<li class=\"".concat(disabled, " ").concat(optgroupClass, " ").concat(this.options.copyClassesOption ? classes : '', " \">").concat(iconHtml, "<span class=\"filtrable\">").concat(checkboxHtml, " ").concat($nativeSelectChild.html(), " ").concat(fas, " ").concat(far, " ").concat(fab, "</span></li>")));
    }
  }, {
    key: "enableValidation",
    value: function enableValidation() {
      this.$nativeSelect.css({
        position: 'absolute',
        top: '1rem',
        left: '0',
        height: '0',
        width: '0',
        opacity: '0',
        padding: '0',
        'pointer-events': 'none'
      });

      if (this.$nativeSelect.attr('style').indexOf('inline!important') === -1) {
        this.$nativeSelect.attr('style', "".concat(this.$nativeSelect.attr('style'), " display: inline!important;"));
      }

      this.$nativeSelect.attr('tabindex', -1);
      this.$nativeSelect.data('inherit-tabindex', false);
    }
  }, {
    key: "bindEvents",
    value: function bindEvents() {
      var _this3 = this;

      var config = {
        attributes: true,
        childList: true,
        characterData: true,
        subtree: true
      };
      var observer = new MutationObserver(this._onMutationObserverChange.bind(this));
      observer.observe(this.$nativeSelect.get(0), config);
      observer.customId = this.uuid;
      observer.customStatus = 'observing';
      MaterialSelect.clearMutationObservers();
      MaterialSelect.mutationObservers.push(observer);
      var $saveSelectBtn = this.$nativeSelect.parent().find('button.btn-save');
      $saveSelectBtn.on('click', this._onSaveSelectBtnClick.bind(this));
      this.$materialSelect.on('focus', this._onMaterialSelectFocus.bind(this));
      this.$materialSelect.on('click', this._onMaterialSelectClick.bind(this));
      this.$materialSelect.on('blur', this._onMaterialSelectBlur.bind(this));
      this.$materialSelect.on('keydown', this._onMaterialSelectKeydown.bind(this));
      this.$toggleAll.on('click', this._onToggleAllClick.bind(this));
      this.$materialOptionsList.on('mousedown', this._onEachMaterialOptionMousedown.bind(this));
      this.$materialOptionsList.find('li:not(.optgroup)').not(this.$toggleAll).each(function (materialOptionIndex, materialOption) {
        $(materialOption).on('click', _this3._onEachMaterialOptionClick.bind(_this3, materialOptionIndex, materialOption));
      });

      if (!this.isMultiple && this.isSearchable) {
        this.$materialOptionsList.find('li').on('click', this._onSingleMaterialOptionClick.bind(this));
      }

      if (this.isSearchable) {
        this.$searchInput.find('.search').on('keyup', this._onSearchInputKeyup);
      }

      $('html').on('click', this._onHTMLClick.bind(this));
    }
  }, {
    key: "_onMutationObserverChange",
    value: function _onMutationObserverChange(mutationsList) {
      mutationsList.forEach(function (mutation) {
        var $select = $(mutation.target).closest('select');

        if ($select.data('stop-refresh') !== true && (mutation.type === 'childList' || mutation.type === 'attributes' && $(mutation.target).is('option'))) {
          MaterialSelect.clearMutationObservers();
          $select.materialSelect({
            destroy: true
          });
          $select.materialSelect();
        }
      });
    }
  }, {
    key: "_onSaveSelectBtnClick",
    value: function _onSaveSelectBtnClick() {
      $('input.multi-bs-select').trigger('close');
      this.$materialOptionsList.hide();
      this.$materialSelect.removeClass('active');
    }
  }, {
    key: "_onEachMaterialOptionClick",
    value: function _onEachMaterialOptionClick(materialOptionIndex, materialOption, e) {
      e.stopPropagation();
      var $this = $(materialOption);

      if ($this.hasClass('disabled') || $this.hasClass('optgroup')) {
        return;
      }

      var selected = true;

      if (this.isMultiple) {
        $this.find('input[type="checkbox"]').prop('checked', function (index, oldPropertyValue) {
          return !oldPropertyValue;
        });
        var hasOptgroup = Boolean(this.$nativeSelect.find('optgroup').length);
        var thisIndex = this._isToggleAllPresent() ? $this.index() - 1 : $this.index();

        if (this.isSearchable && hasOptgroup) {
          selected = this._toggleSelectedValue(thisIndex - $this.prevAll('.optgroup').length - 1);
        } else if (this.isSearchable) {
          selected = this._toggleSelectedValue(thisIndex - 1);
        } else if (hasOptgroup) {
          selected = this._toggleSelectedValue(thisIndex - $this.prevAll('.optgroup').length);
        } else {
          selected = this._toggleSelectedValue(thisIndex);
        }

        if (this._isToggleAllPresent()) {
          this._updateToggleAllOption();
        }

        this.$materialSelect.trigger('focus');
      } else {
        this.$materialOptionsList.find('li').removeClass('active');
        $this.toggleClass('active');
        this.$materialSelect.val($this.text().replace(/  +/g, ' ').trim());
        this.$materialSelect.trigger('close');
      }

      this._selectSingleOption($this);

      this.$nativeSelect.data('stop-refresh', true);
      this.$nativeSelect.find('option').eq(materialOptionIndex).prop('selected', selected);
      this.$nativeSelect.removeData('stop-refresh');

      this._triggerChangeOnNativeSelect();

      if (this.mainLabel.prev().find('input').hasClass('select-dropdown')) {
        if (this.mainLabel.prev().find('input.select-dropdown').val().length > 0) {
          this.mainLabel.addClass('active');
        }
      }

      if (typeof this.options === 'function') {
        this.options();
      }

      if ($this.hasClass('li-added')) {
        this.$materialOptionsList.append(this.buildSingleOption($this, ''));
      }
    }
  }, {
    key: "_triggerChangeOnNativeSelect",
    value: function _triggerChangeOnNativeSelect() {
      var keyboardEvt = new KeyboardEvent('change', {
        bubbles: true,
        cancelable: true
      });
      this.$nativeSelect.get(0).dispatchEvent(keyboardEvt);
    }
  }, {
    key: "_onMaterialSelectFocus",
    value: function _onMaterialSelectFocus(e) {
      var $this = $(e.target);

      if ($('ul.select-dropdown').not(this.$materialOptionsList.get(0)).is(':visible')) {
        $('input.select-dropdown').trigger('close');
      }

      this.mainLabel.addClass('active');

      if (!this.$materialOptionsList.is(':visible')) {
        $this.trigger('open', ['focus']);
        var label = $this.val();
        var $selectedOption = this.$materialOptionsList.find('li').filter(function () {
          return $(this).text().toLowerCase() === label.toLowerCase();
        })[0];

        this._selectSingleOption($selectedOption);
      }

      if (!this.isMultiple) {
        this.mainLabel.addClass('active ');
      }

      $(document).find('input.select-dropdown').each(function (i, el) {
        return $(el).val().length <= 0;
      }).parent().next('.mdb-main-label').filter(function (i, el) {
        return $(el).prev().find('input.select-dropdown').val().length <= 0 && !$(el).prev().find('input.select-dropdown').hasClass('active');
      }).removeClass('active');
    }
  }, {
    key: "_onMaterialSelectClick",
    value: function _onMaterialSelectClick(e) {
      this.mainLabel.addClass('active ');
      e.stopPropagation();
    }
  }, {
    key: "_onMaterialSelectBlur",
    value: function _onMaterialSelectBlur(e) {
      var $this = $(e);

      if (!this.isMultiple && !this.isSearchable) {
        $this.trigger('close');
      }

      this.$materialOptionsList.find('li.selected').removeClass('selected');
    }
  }, {
    key: "_onSingleMaterialOptionClick",
    value: function _onSingleMaterialOptionClick() {
      this.$materialSelect.trigger('close');
    }
  }, {
    key: "_onEachMaterialOptionMousedown",
    value: function _onEachMaterialOptionMousedown(e) {
      var option = e.target;

      if ($('.modal-content').find(this.$materialOptionsList).length) {
        if (option.scrollHeight > option.offsetHeight) {
          e.preventDefault();
        }
      }
    }
  }, {
    key: "_onHTMLClick",
    value: function _onHTMLClick(e) {
      if (!$(e.target).closest("#select-options-".concat(this.uuid)).length && !$(e.target).hasClass('mdb-select') && $("#select-options-".concat(this.uuid)).hasClass('active')) {
        this.$materialSelect.trigger('close');

        if (!this.$materialSelect.val().length > 0) {
          this.mainLabel.removeClass('active');
        }
      }

      if (this.isSearchable && this.$searchInput !== null && this.$materialOptionsList.hasClass('active')) {
        this.$materialOptionsList.find('.search-wrap input.search').focus();
      }
    }
  }, {
    key: "_onToggleAllClick",
    value: function _onToggleAllClick(e) {
      var _this4 = this;

      var checkbox = $(this.$toggleAll).find('input[type="checkbox"]').first();
      var state = !$(checkbox).prop('checked');
      $(checkbox).prop('checked', state);
      this.$materialOptionsList.find('li:not(.optgroup):not(.disabled):not(.select-toggle-all)').each(function (materialOptionIndex, materialOption) {
        var $optionCheckbox = $(materialOption).find('input[type="checkbox"]');

        if (state && $optionCheckbox.is(':checked') || !state && !$optionCheckbox.is(':checked')) {
          return;
        }

        if (_this4._isToggleAllPresent()) {
          materialOptionIndex++;
        }

        $optionCheckbox.prop('checked', state);

        _this4.$nativeSelect.find('option').eq(materialOptionIndex).prop('selected', state);

        if (state) {
          $(materialOption).removeClass('active');
        } else {
          $(materialOption).addClass('active');
        }

        _this4._toggleSelectedValue(materialOptionIndex);

        _this4._selectOption(materialOption);

        _this4._setValueToMaterialSelect();
      });
      this.$nativeSelect.data('stop-refresh', true);

      this._triggerChangeOnNativeSelect();

      this.$nativeSelect.removeData('stop-refresh');
      e.stopPropagation();
    }
  }, {
    key: "_onMaterialSelectKeydown",
    value: function _onMaterialSelectKeydown(e) {
      var $this = $(e.target);
      var isTab = e.which === this.keyCodes.tab;
      var isEsc = e.which === this.keyCodes.esc;
      var isEnter = e.which === this.keyCodes.enter;
      var isArrowUp = e.which === this.keyCodes.arrowUp;
      var isArrowDown = e.which === this.keyCodes.arrowDown;
      var isMaterialSelectVisible = this.$materialOptionsList.is(':visible');

      if (isTab) {
        this._handleTabKey($this);

        return;
      } else if (isArrowDown && !isMaterialSelectVisible) {
        $this.trigger('open');
        return;
      } else if (isEnter && !isMaterialSelectVisible) {
        return;
      }

      e.preventDefault();

      if (isEnter) {
        this._handleEnterKey($this);
      } else if (isArrowDown) {
        this._handleArrowDownKey();
      } else if (isArrowUp) {
        this._handleArrowUpKey();
      } else if (isEsc) {
        this._handleEscKey($this);
      } else {
        this._handleLetterKey(e);
      }
    }
  }, {
    key: "_handleTabKey",
    value: function _handleTabKey(materialSelect) {
      this._handleEscKey(materialSelect);
    }
  }, {
    key: "_handleEnterKey",
    value: function _handleEnterKey(materialSelect) {
      var $activeOption = this.$materialOptionsList.find('li.selected:not(.disabled)');
      $activeOption.trigger('click').addClass('active');

      if (!this.isMultiple) {
        $(materialSelect).trigger('close');
      }
    }
  }, {
    key: "_handleArrowDownKey",
    value: function _handleArrowDownKey() {
      var $firstOption = this.$materialOptionsList.find('li').not('.disabled').first();
      var $lastOption = this.$materialOptionsList.find('li').not('.disabled').last();
      var anySelected = this.$materialOptionsList.find('li.selected').length > 0;
      var $currentOption = anySelected ? this.$materialOptionsList.find('li.selected') : $firstOption;
      var $matchedMaterialOption = $currentOption.is($lastOption) || !anySelected ? $currentOption : $currentOption.next('li:not(.disabled)');

      this._selectSingleOption($matchedMaterialOption);

      if (!$matchedMaterialOption.find('input').is(':checked')) {
        $matchedMaterialOption.removeClass('active');
      }

      if (!$matchedMaterialOption.prev().hasClass('selected') && !$matchedMaterialOption.prev().find('input').is(':checked')) {
        $matchedMaterialOption.prev().removeClass('active');
      }

      $matchedMaterialOption.addClass('active');
    }
  }, {
    key: "_handleArrowUpKey",
    value: function _handleArrowUpKey() {
      var $firstOption = this.$materialOptionsList.find('li').not('.disabled').first();
      var $lastOption = this.$materialOptionsList.find('li').not('.disabled').last();
      var anySelected = this.$materialOptionsList.find('li.selected').length > 0;
      var $currentOption = anySelected ? this.$materialOptionsList.find('li.selected') : $lastOption;
      var $matchedMaterialOption = $currentOption.is($firstOption) || !anySelected ? $currentOption : $currentOption.prev('li:not(.disabled)');

      this._selectSingleOption($matchedMaterialOption);

      if (!$matchedMaterialOption.find('input').is(':checked')) {
        $matchedMaterialOption.removeClass('active');
      }

      if (!$matchedMaterialOption.next().hasClass('selected') && !$matchedMaterialOption.next().find('input').is(':checked')) {
        $matchedMaterialOption.next().removeClass('active');
      }

      $matchedMaterialOption.addClass('active');
    }
  }, {
    key: "_handleEscKey",
    value: function _handleEscKey(materialSelect) {
      $(materialSelect).trigger('close');
    }
  }, {
    key: "_handleLetterKey",
    value: function _handleLetterKey(e) {
      var _this5 = this;

      var filterQueryString = '';
      var letter = String.fromCharCode(e.which).toLowerCase();
      var nonLetters = Object.keys(this.keyCodes).map(function (key) {
        return _this5.keyCodes[key];
      });
      var isLetterSearchable = letter && nonLetters.indexOf(e.which) === -1;

      if (isLetterSearchable) {
        filterQueryString += letter;
        var $matchedMaterialOption = this.$materialOptionsList.find('li').filter(function (index, element) {
          return $(element).text().toLowerCase().includes(filterQueryString);
        }).first();

        if (!this.isMultiple) {
          this.$materialOptionsList.find('li').removeClass('active');
        }

        $matchedMaterialOption.addClass('active');

        this._selectSingleOption($matchedMaterialOption);
      }
    }
  }, {
    key: "_onSearchInputKeyup",
    value: function _onSearchInputKeyup(e) {
      var $this = $(e.target);
      var $ul = $this.closest('ul');
      var searchValue = $this.val();
      var $options = $ul.find('li span.filtrable');
      $options.each(function () {
        var $option = $(this);

        if (typeof this.outerHTML === 'string') {
          var liValue = this.textContent.toLowerCase();

          if (liValue.includes(searchValue.toLowerCase())) {
            $option.show().parent().show();
          } else {
            $option.hide().parent().hide();
          }
        }
      });
    }
  }, {
    key: "_isToggleAllPresent",
    value: function _isToggleAllPresent() {
      return this.$materialOptionsList.find(this.$toggleAll).length;
    }
  }, {
    key: "_updateToggleAllOption",
    value: function _updateToggleAllOption() {
      var $allOptionsButToggleAll = this.$materialOptionsList.find('li').not('.select-toggle-all, .disabled').find('[type=checkbox]');
      var $checkedOptionsButToggleAll = $allOptionsButToggleAll.filter(':checked');
      var isToggleAllChecked = this.$toggleAll.find('[type=checkbox]').is(':checked');

      if ($checkedOptionsButToggleAll.length === $allOptionsButToggleAll.length && !isToggleAllChecked) {
        this.$toggleAll.find('[type=checkbox]').prop('checked', true);
      } else if ($checkedOptionsButToggleAll.length < $allOptionsButToggleAll.length && isToggleAllChecked) {
        this.$toggleAll.find('[type=checkbox]').prop('checked', false);
      }
    }
  }, {
    key: "_toggleSelectedValue",
    value: function _toggleSelectedValue(optionIndex) {
      var selectedValueIndex = this.valuesSelected.indexOf(optionIndex);
      var isSelected = selectedValueIndex !== -1;

      if (!isSelected) {
        this.valuesSelected.push(optionIndex);
      } else {
        this.valuesSelected.splice(selectedValueIndex, 1);
      }

      this.$materialOptionsList.find('li:not(.optgroup):not(.select-toggle-all)').eq(optionIndex).toggleClass('active');
      this.$nativeSelect.find('option').eq(optionIndex).prop('selected', !isSelected);

      this._setValueToMaterialSelect();

      return !isSelected;
    }
  }, {
    key: "_selectSingleOption",
    value: function _selectSingleOption(newOption) {
      this.$materialOptionsList.find('li.selected').removeClass('selected');

      this._selectOption(newOption);
    }
  }, {
    key: "_selectOption",
    value: function _selectOption(newOption) {
      var option = $(newOption);
      option.addClass('selected');
    }
  }, {
    key: "_setValueToMaterialSelect",
    value: function _setValueToMaterialSelect() {
      var _this6 = this;

      var value = '';
      var optionsSelected = 'options selected';
      var itemsCount = this.valuesSelected.length;

      if (this.options.language.active && this.$toggleAll) {
        if (this.options.language.pl) {
          optionsSelected = this.options.language.pl.optionsSelected ? this.options.language.pl.optionsSelected : this.defaults.language.pl.optionsSelected;
        } else if (this.options.language.fr) {
          optionsSelected = this.options.language.fr.optionsSelected ? this.options.language.fr.optionsSelected : this.defaults.language.fr.optionsSelected;
        } else if (this.options.language.ge) {
          optionsSelected = this.options.language.ge.optionsSelected ? this.options.language.ge.optionsSelected : this.defaults.language.ge.optionsSelected;
        } else if (this.options.language.ar) {
          optionsSelected = this.options.language.ar.optionsSelected ? this.options.language.ar.optionsSelected : this.defaults.language.ar.optionsSelected;
        } else if (this.options.language.in) {
          optionsSelected = this.options.language.in.optionsSelected ? this.options.language.in.optionsSelected : this.defaults.language.in.optionsSelected;
        }
      }

      this.valuesSelected.map(function (el) {
        return value += ", ".concat(_this6.$nativeSelect.find('option').eq(el).text().replace(/  +/g, ' ').trim());
      });
      itemsCount >= 5 ? value = "".concat(itemsCount, " ").concat(optionsSelected) : value = value.substring(2);
      value.length === 0 && this.mainLabel.length === 0 ? value = this.$nativeSelect.find('option:disabled').eq(0).text() : null;
      value.length > 0 && !this.options.BSinputText ? this.mainLabel.addClass('active ') : this.mainLabel.removeClass('active');
      this.options.BSinputText ? this.mainLabel.css('top', '-7px') : null;
      this.$nativeSelect.siblings("".concat(this.options.BSinputText ? 'input.multi-bs-select' : 'input.select-dropdown')).val(value);
    }
  }, {
    key: "_randomUUID",
    value: function _randomUUID() {
      var d = new Date().getTime();
      return 'xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx'.replace(/[xy]/g, function (c) {
        var r = (d + Math.random() * 16) % 16 | 0;
        d = Math.floor(d / 16);
        return (c === 'x' ? r : r & 0x3 | 0x8).toString(16);
      });
    }
  }], [{
    key: "clearMutationObservers",
    value: function clearMutationObservers() {
      MaterialSelect.mutationObservers.forEach(function (observer) {
        observer.disconnect();
        observer.customStatus = 'stopped';
      });
    }
  }]);

  return MaterialSelect;
}();

$.fn.materialSelect = function (callback) {
  $(this).not('.browser-default').not('.custom-select').each(function () {
    var materialSelect = new MaterialSelect($(this), callback);
    materialSelect.init();
  });
};

$.fn.material_select = $.fn.materialSelect;

(function (originalVal) {
  $.fn.val = function (value) {
    if (!arguments.length) {
      return originalVal.call(this);
    }

    if (this.data('stop-refresh') !== true && this.hasClass('mdb-select') && this.hasClass('initialized')) {
      MaterialSelect.clearMutationObservers();
      this.materialSelect({
        destroy: true
      });
      var ret = originalVal.call(this, value);
      this.materialSelect();
      return ret;
    }

    return originalVal.call(this, value);
  };
})($.fn.val);

})(jQuery);

$('select').siblings('input.select-dropdown', 'input.multi-bs-select').on('mousedown', function (e) {

if (/Android|webOS|iPhone|iPad|iPod|BlackBerry|IEMobile|Opera Mini/i.test(navigator.userAgent)) {
  if (e.clientX >= e.target.clientWidth || e.clientY >= e.target.clientHeight) {
    e.preventDefault();
  }
}

}); /*!

* pickadate.js v3.6.3, 2019/04/03
* By Amsul, http://amsul.ca
* Hosted on http://amsul.github.io/pickadate.js
* Licensed under MIT
*/

(function ( factory ) {

// AMD.
if ( typeof define == 'function' && define.amd )
    define( 'picker', ['jquery'], factory )

// Node.js/browserify.
else if ( typeof exports == 'object' )
    module.exports = factory( require('jquery') )

// Browser globals.
else this.Picker = factory( jQuery )

}(function( $ ) {

var $window = $( window ) var $document = $( document ) var $html = $( document.documentElement ) var supportsTransitions = document.documentElement.style.transition != null

/**

*/ function PickerConstructor( ELEMENT, NAME, COMPONENT, OPTIONS ) {

// If there’s no element, return the picker constructor.
if ( !ELEMENT ) return PickerConstructor

var
    IS_DEFAULT_THEME = false,

    // The state of the picker.
    STATE = {
        id: ELEMENT.id || 'P' + Math.abs( ~~(Math.random() * new Date()) ),
        handlingOpen: false,
    },

    // Merge the defaults and options passed.
    SETTINGS = COMPONENT ? $.extend( true, {}, COMPONENT.defaults, OPTIONS ) : OPTIONS || {},

    // Merge the default classes with the settings classes.
    CLASSES = $.extend( {}, PickerConstructor.klasses(), SETTINGS.klass ),

    // The element node wrapper into a jQuery object.
    $ELEMENT = $( ELEMENT ),

    // Pseudo picker constructor.
    PickerInstance = function() {
        return this.start()
    },

    // The picker prototype.
    P = PickerInstance.prototype = {

        constructor: PickerInstance,

        $node: $ELEMENT,

        /**
         * Initialize everything
         */
        start: function() {

            // If it’s already started, do nothing.
            if ( STATE && STATE.start ) return P

            // Update the picker states.
            STATE.methods = {}
            STATE.start = true
            STATE.open = false
            STATE.type = ELEMENT.type

            // Confirm focus state, convert into text input to remove UA stylings,
            // and set as readonly to prevent keyboard popup.
            ELEMENT.autofocus = ELEMENT == getActiveElement()
            ELEMENT.readOnly = !SETTINGS.editable
            ELEMENT.id = ELEMENT.id || STATE.id
            if ( ELEMENT.type != 'text' ) {
                ELEMENT.type = 'text'
            }

            // Create a new picker component with the settings.
            P.component = new COMPONENT(P, SETTINGS)

            // Create the picker root and then prepare it.
            P.$root = $( '<div class="' + CLASSES.picker + '" id="' + ELEMENT.id + '_root" />' )
            prepareElementRoot()

            // Create the picker holder and then prepare it.
            P.$holder = $( createWrappedComponent() ).appendTo( P.$root )
            prepareElementHolder()

            // If there’s a format for the hidden input element, create the element.
            if ( SETTINGS.formatSubmit ) {
                prepareElementHidden()
            }

            // Prepare the input element.
            prepareElement()

            // Insert the hidden input as specified in the settings.
            if ( SETTINGS.containerHidden ) $( SETTINGS.containerHidden ).append( P._hidden )
            else $ELEMENT.after( P._hidden )

            // Insert the root as specified in the settings.
            if ( SETTINGS.container ) $( SETTINGS.container ).append( P.$root )
            else $ELEMENT.after( P.$root )

            // Bind the default component and settings events.
            P.on({
                start: P.component.onStart,
                render: P.component.onRender,
                stop: P.component.onStop,
                open: P.component.onOpen,
                close: P.component.onClose,
                set: P.component.onSet
            }).on({
                start: SETTINGS.onStart,
                render: SETTINGS.onRender,
                stop: SETTINGS.onStop,
                open: SETTINGS.onOpen,
                close: SETTINGS.onClose,
                set: SETTINGS.onSet
            })

            // Once we’re all set, check the theme in use.
            IS_DEFAULT_THEME = isUsingDefaultTheme( P.$holder[0] )

            // If the element has autofocus, open the picker.
            if ( ELEMENT.autofocus ) {
                P.open()
            }

            // Trigger queued the “start” and “render” events.
            return P.trigger( 'start' ).trigger( 'render' )
        }, //start

        /**
         * Render a new picker
         */
        render: function( entireComponent ) {

            // Insert a new component holder in the root or box.
            if ( entireComponent ) {
                P.$holder = $( createWrappedComponent() )
                prepareElementHolder()
                P.$root.html( P.$holder )
            }
            else P.$root.find( '.' + CLASSES.box ).html( P.component.nodes( STATE.open ) )

            // Trigger the queued “render” events.
            return P.trigger( 'render' )
        }, //render

        /**
         * Destroy everything
         */
        stop: function() {

            // If it’s already stopped, do nothing.
            if ( !STATE.start ) return P

            // Then close the picker.
            P.close()

            // Remove the hidden field.
            if ( P._hidden ) {
                P._hidden.parentNode.removeChild( P._hidden )
            }

            // Remove the root.
            P.$root.remove()

            // Remove the input class, remove the stored data, and unbind
            // the events (after a tick for IE - see `P.close`).
            $ELEMENT.removeClass( CLASSES.input ).removeData( NAME )
            setTimeout( function() {
                $ELEMENT.off( '.' + STATE.id )
            }, 0)

            // Restore the element state
            ELEMENT.type = STATE.type
            ELEMENT.readOnly = false

            // Trigger the queued “stop” events.
            P.trigger( 'stop' )

            // Reset the picker states.
            STATE.methods = {}
            STATE.start = false

            return P
        }, //stop

        /**
         * Open up the picker
         */
        open: function( dontGiveFocus ) {

            // If it’s already open, do nothing.
            if ( STATE.open ) return P

            // Add the “active” class.
            $ELEMENT.addClass( CLASSES.active )
            aria( ELEMENT, 'expanded', true )

            // * A Firefox bug, when `html` has `overflow:hidden`, results in
            //   killing transitions :(. So add the “opened” state on the next tick.
            //   Bug: https://bugzilla.mozilla.org/show_bug.cgi?id=625289
            setTimeout( function() {

                // Add the “opened” class to the picker root.
                P.$root.addClass( CLASSES.opened )
                aria( P.$root[0], 'hidden', false )

            }, 0 )

            // If we have to give focus, bind the element and doc events.
            if ( dontGiveFocus !== false ) {

                // Set it as open.
                STATE.open = true

                // Prevent the page from scrolling.
                if ( IS_DEFAULT_THEME ) {
                    $('body').
                        css( 'overflow', 'hidden' ).
                        css( 'padding-right', '+=' + getScrollbarWidth() )
                }

                // Pass focus to the root element’s jQuery object.
                focusPickerOnceOpened()

                // Bind the document events.
                $document.on( 'click.' + STATE.id + ' focusin.' + STATE.id, function( event ) {
                    // If the picker is currently midway through processing
                    // the opening sequence of events then don't handle clicks
                    // on any part of the DOM. This is caused by a bug in Chrome 73
                    // where a click event is being generated with the incorrect
                    // path in it.
                    // In short, if someone does a click that finishes after the
                    // new element is created then the path contains only the
                    // parent element and not the input element itself.
                    if (STATE.handlingOpen) {
                      return;
                    }

                    var target = getRealEventTarget( event, ELEMENT )

                    // If the target of the event is not the element, close the picker picker.
                    // * Don’t worry about clicks or focusins on the root because those don’t bubble up.
                    //   Also, for Firefox, a click on an `option` element bubbles up directly
                    //   to the doc. So make sure the target wasn't the doc.
                    // * In Firefox stopPropagation() doesn’t prevent right-click events from bubbling,
                    //   which causes the picker to unexpectedly close when right-clicking it. So make
                    //   sure the event wasn’t a right-click.
                    // * In Chrome 62 and up, password autofill causes a simulated focusin event which
                    //   closes the picker.
                    if ( ! event.isSimulated && target != ELEMENT && target != document && event.which != 3 ) {

                        // If the target was the holder that covers the screen,
                        // keep the element focused to maintain tabindex.
                        P.close( target === P.$holder[0] )
                    }

                }).on( 'keydown.' + STATE.id, function( event ) {

                    var
                        // Get the keycode.
                        keycode = event.keyCode,

                        // Translate that to a selection change.
                        keycodeToMove = P.component.key[ keycode ],

                        // Grab the target.
                        target = getRealEventTarget( event, ELEMENT )

                    // On escape, close the picker and give focus.
                    if ( keycode == 27 ) {
                        P.close( true )
                    }

                    // Check if there is a key movement or “enter” keypress on the element.
                    else if ( target == P.$holder[0] && ( keycodeToMove || keycode == 13 ) ) {

                        // Prevent the default action to stop page movement.
                        event.preventDefault()

                        // Trigger the key movement action.
                        if ( keycodeToMove ) {
                            PickerConstructor._.trigger( P.component.key.go, P, [ PickerConstructor._.trigger( keycodeToMove ) ] )
                        }

                        // On “enter”, if the highlighted item isn’t disabled, set the value and close.
                        else if ( !P.$root.find( '.' + CLASSES.highlighted ).hasClass( CLASSES.disabled ) ) {
                            P.set( 'select', P.component.item.highlight )
                            if ( SETTINGS.closeOnSelect ) {
                                P.close( true )
                            }
                        }
                    }

                    // If the target is within the root and “enter” is pressed,
                    // prevent the default action and trigger a click on the target instead.
                    else if ( $.contains( P.$root[0], target ) && keycode == 13 ) {
                        event.preventDefault()
                        target.click()
                    }
                })
            }

            // Trigger the queued “open” events.
            return P.trigger( 'open' )
        }, //open

        /**
         * Close the picker
         */
        close: function( giveFocus ) {

            // If we need to give focus, do it before changing states.
            if ( giveFocus ) {
                if ( SETTINGS.editable ) {
                    ELEMENT.focus()
                }
                else {
                    // ....ah yes! It would’ve been incomplete without a crazy workaround for IE :|
                    // The focus is triggered *after* the close has completed - causing it
                    // to open again. So unbind and rebind the event at the next tick.
                    P.$holder.off( 'focus.toOpen' ).focus()
                    setTimeout( function() {
                        P.$holder.on( 'focus.toOpen', handleFocusToOpenEvent )
                    }, 0 )
                }
            }

            // Remove the “active” class.
            $ELEMENT.removeClass( CLASSES.active )
            aria( ELEMENT, 'expanded', false )

            // * A Firefox bug, when `html` has `overflow:hidden`, results in
            //   killing transitions :(. So remove the “opened” state on the next tick.
            //   Bug: https://bugzilla.mozilla.org/show_bug.cgi?id=625289
            setTimeout( function() {

                // Remove the “opened” and “focused” class from the picker root.
                P.$root.removeClass( CLASSES.opened + ' ' + CLASSES.focused )
                aria( P.$root[0], 'hidden', true )

            }, 0 )

            // If it’s already closed, do nothing more.
            if ( !STATE.open ) return P

            // Set it as closed.
            STATE.open = false

            // Allow the page to scroll.
            if ( IS_DEFAULT_THEME ) {
                $('body').
                    css( 'overflow', '' ).
                    css( 'padding-right', '-=' + getScrollbarWidth() )
            }

            // Unbind the document events.
            $document.off( '.' + STATE.id )

            // Trigger the queued “close” events.
            return P.trigger( 'close' )
        }, //close

        /**
         * Clear the values
         */
        clear: function( options ) {
            return P.set( 'clear', null, options )
        }, //clear

        /**
         * Set something
         */
        set: function( thing, value, options ) {

            var thingItem, thingValue,
                thingIsObject = $.isPlainObject( thing ),
                thingObject = thingIsObject ? thing : {}

            // Make sure we have usable options.
            options = thingIsObject && $.isPlainObject( value ) ? value : options || {}

            if ( thing ) {

                // If the thing isn’t an object, make it one.
                if ( !thingIsObject ) {
                    thingObject[ thing ] = value
                }

                // Go through the things of items to set.
                for ( thingItem in thingObject ) {

                    // Grab the value of the thing.
                    thingValue = thingObject[ thingItem ]

                    // First, if the item exists and there’s a value, set it.
                    if ( thingItem in P.component.item ) {
                        if ( thingValue === undefined ) thingValue = null
                        P.component.set( thingItem, thingValue, options )
                    }

                    // Then, check to update the element value and broadcast a change.
                    if ( ( thingItem == 'select' || thingItem == 'clear' ) && SETTINGS.updateInput ) {
                        $ELEMENT.
                            val( thingItem == 'clear' ? '' : P.get( thingItem, SETTINGS.format ) ).
                            trigger( 'change' )
                    }
                }

                // Render a new picker.
                P.render()
            }

            // When the method isn’t muted, trigger queued “set” events and pass the `thingObject`.
            return options.muted ? P : P.trigger( 'set', thingObject )
        }, //set

        /**
         * Get something
         */
        get: function( thing, format ) {

            // Make sure there’s something to get.
            thing = thing || 'value'

            // If a picker state exists, return that.
            if ( STATE[ thing ] != null ) {
                return STATE[ thing ]
            }

            // Return the submission value, if that.
            if ( thing == 'valueSubmit' ) {
                if ( P._hidden ) {
                    return P._hidden.value
                }
                thing = 'value'
            }

            // Return the value, if that.
            if ( thing == 'value' ) {
                return ELEMENT.value
            }

            // Check if a component item exists, return that.
            if ( thing in P.component.item ) {
                if ( typeof format == 'string' ) {
                    var thingValue = P.component.get( thing )
                    return thingValue ?
                        PickerConstructor._.trigger(
                            P.component.formats.toString,
                            P.component,
                            [ format, thingValue ]
                        ) : ''
                }
                return P.component.get( thing )
            }
        }, //get

        /**
         * Bind events on the things.
         */
        on: function( thing, method, internal ) {

            var thingName, thingMethod,
                thingIsObject = $.isPlainObject( thing ),
                thingObject = thingIsObject ? thing : {}

            if ( thing ) {

                // If the thing isn’t an object, make it one.
                if ( !thingIsObject ) {
                    thingObject[ thing ] = method
                }

                // Go through the things to bind to.
                for ( thingName in thingObject ) {

                    // Grab the method of the thing.
                    thingMethod = thingObject[ thingName ]

                    // If it was an internal binding, prefix it.
                    if ( internal ) {
                        thingName = '_' + thingName
                    }

                    // Make sure the thing methods collection exists.
                    STATE.methods[ thingName ] = STATE.methods[ thingName ] || []

                    // Add the method to the relative method collection.
                    STATE.methods[ thingName ].push( thingMethod )
                }
            }

            return P
        }, //on

        /**
         * Unbind events on the things.
         */
        off: function() {
            var i, thingName,
                names = arguments;
            for ( i = 0, namesCount = names.length; i < namesCount; i += 1 ) {
                thingName = names[i]
                if ( thingName in STATE.methods ) {
                    delete STATE.methods[thingName]
                }
            }
            return P
        },

        /**
         * Fire off method events.
         */
        trigger: function( name, data ) {
            var _trigger = function( name ) {
                var methodList = STATE.methods[ name ]
                if ( methodList ) {
                    methodList.map( function( method ) {
                        PickerConstructor._.trigger( method, P, [ data ] )
                    })
                }
            }
            _trigger( '_' + name )
            _trigger( name )
            return P
        } //trigger
    } //PickerInstance.prototype

/**
 * Wrap the picker holder components together.
 */
function createWrappedComponent() {

    // Create a picker wrapper holder
    return PickerConstructor._.node( 'div',

        // Create a picker wrapper node
        PickerConstructor._.node( 'div',

            // Create a picker frame
            PickerConstructor._.node( 'div',

                // Create a picker box node
                PickerConstructor._.node( 'div',

                    // Create the components nodes.
                    P.component.nodes( STATE.open ),

                    // The picker box class
                    CLASSES.box
                ),

                // Picker wrap class
                CLASSES.wrap
            ),

            // Picker frame class
            CLASSES.frame
        ),

        // Picker holder class
        CLASSES.holder,

        'tabindex="-1"'
    ) //endreturn
} //createWrappedComponent

/**
 * Prepare the input element with all bindings.
 */
function prepareElement() {

    $ELEMENT.

        // Store the picker data by component name.
        data(NAME, P).

        // Add the “input” class name.
        addClass(CLASSES.input).

        // If there’s a `data-value`, update the value of the element.
        val( $ELEMENT.data('value') ?
            P.get('select', SETTINGS.format) :
            ELEMENT.value
        ).

        // On focus/click, open the picker.
        on( 'focus.' + STATE.id + ' click.' + STATE.id,
        debounce(function(event) {
            event.preventDefault()
            P.open()
        }, 100))

        // Mousedown handler to capture when the user starts interacting
        // with the picker. This is used in working around a bug in Chrome 73.
        .on('mousedown', function() {
          STATE.handlingOpen = true;
          var handler = function() {
            // By default mouseup events are fired before a click event.
            // By using a timeout we can force the mouseup to be handled
            // after the corresponding click event is handled.
            setTimeout(function() {
              $(document).off('mouseup', handler);
              STATE.handlingOpen = false;
            }, 0);
          };
          $(document).on('mouseup', handler);
        });

    // Only bind keydown events if the element isn’t editable.
    if ( !SETTINGS.editable ) {

        $ELEMENT.

            // Handle keyboard event based on the picker being opened or not.
            on( 'keydown.' + STATE.id, handleKeydownEvent )
    }

    // Update the aria attributes.
    aria(ELEMENT, {
        haspopup: true,
        expanded: false,
        readonly: false,
        owns: ELEMENT.id + '_root'
    })
}

/**
 * Prepare the root picker element with all bindings.
 */
function prepareElementRoot() {
    aria( P.$root[0], 'hidden', true )
}

 /**
  * Prepare the holder picker element with all bindings.
  */
function prepareElementHolder() {

    P.$holder.

        on({

            // For iOS8.
            keydown: handleKeydownEvent,

            'focus.toOpen': handleFocusToOpenEvent,

            blur: function() {
                // Remove the “target” class.
                $ELEMENT.removeClass( CLASSES.target )
            },

            // When something within the holder is focused, stop from bubbling
            // to the doc and remove the “focused” state from the root.
            focusin: function( event ) {
                P.$root.removeClass( CLASSES.focused )
                event.stopPropagation()
            },

            // When something within the holder is clicked, stop it
            // from bubbling to the doc.
            'mousedown click': function( event ) {

                var target = getRealEventTarget( event, ELEMENT )

                // Make sure the target isn’t the root holder so it can bubble up.
                if ( target != P.$holder[0] ) {

                    event.stopPropagation()

                    // * For mousedown events, cancel the default action in order to
                    //   prevent cases where focus is shifted onto external elements
                    //   when using things like jQuery mobile or MagnificPopup (ref: #249 & #120).
                    //   Also, for Firefox, don’t prevent action on the `option` element.
                    if ( event.type == 'mousedown' && !$( target ).is( 'input, select, textarea, button, option' )) {

                        event.preventDefault()

                        // Re-focus onto the holder so that users can click away
                        // from elements focused within the picker.
                        P.$holder.eq(0).focus()
                    }
                }
            }

        }).

        // If there’s a click on an actionable element, carry out the actions.
        on( 'click', '[data-pick], [data-nav], [data-clear], [data-close]', function() {

            var $target = $( this ),
                targetData = $target.data(),
                targetDisabled = $target.hasClass( CLASSES.navDisabled ) || $target.hasClass( CLASSES.disabled ),

                // * For IE, non-focusable elements can be active elements as well
                //   (http://stackoverflow.com/a/2684561).
                activeElement = getActiveElement()
                activeElement = activeElement && ( (activeElement.type || activeElement.href ) ? activeElement : null);

            // If it’s disabled or nothing inside is actively focused, re-focus the element.
            if ( targetDisabled || activeElement && !$.contains( P.$root[0], activeElement ) ) {
                P.$holder.eq(0).focus()
            }

            // If something is superficially changed, update the `highlight` based on the `nav`.
            if ( !targetDisabled && targetData.nav ) {
                P.set( 'highlight', P.component.item.highlight, { nav: targetData.nav } )
            }

            // If something is picked, set `select` then close with focus.
            else if ( !targetDisabled && 'pick' in targetData ) {
                P.set( 'select', targetData.pick )
                if ( SETTINGS.closeOnSelect ) {
                    P.close( true )
                }
            }

            // If a “clear” button is pressed, empty the values and close with focus.
            else if ( targetData.clear ) {
                P.clear()
                if ( SETTINGS.closeOnClear ) {
                    P.close( true )
                }
            }

            else if ( targetData.close ) {
                P.close( true )
            }

        }) //P.$holder

}

 /**
  * Prepare the hidden input element along with all bindings.
  */
function prepareElementHidden() {

    var name

    if ( SETTINGS.hiddenName === true ) {
        name = ELEMENT.name
        ELEMENT.name = ''
    }
    else {
        name = [
            typeof SETTINGS.hiddenPrefix == 'string' ? SETTINGS.hiddenPrefix : '',
            typeof SETTINGS.hiddenSuffix == 'string' ? SETTINGS.hiddenSuffix : '_submit'
        ]
        name = name[0] + ELEMENT.name + name[1]
    }

    P._hidden = $(
        '<input ' +
        'type=hidden ' +

        // Create the name using the original input’s with a prefix and suffix.
        'name="' + name + '"' +

        // If the element has a value, set the hidden value as well.
        (
            $ELEMENT.data('value') || ELEMENT.value ?
                ' value="' + P.get('select', SETTINGS.formatSubmit) + '"' :
                ''
        ) +
        '>'
    )[0]

    $ELEMENT.

        // If the value changes, update the hidden input with the correct format.
        on('change.' + STATE.id, function() {
            P._hidden.value = ELEMENT.value ?
                P.get('select', SETTINGS.formatSubmit) :
                ''
        })
}

// Wait for transitions to end before focusing the holder. Otherwise, while
// using the `container` option, the view jumps to the container.
function focusPickerOnceOpened() {

    if (IS_DEFAULT_THEME && supportsTransitions) {
        P.$holder.find('.' + CLASSES.frame).one('transitionend', function() {
            P.$holder.eq(0).focus()
        })
    }
    else {
        setTimeout(function() {
            P.$holder.eq(0).focus()
        }, 0)
    }
}

function handleFocusToOpenEvent(event) {

    // Stop the event from propagating to the doc.
    event.stopPropagation()

    // Add the “target” class.
    $ELEMENT.addClass( CLASSES.target )

    // Add the “focused” class to the root.
    P.$root.addClass( CLASSES.focused )

    // And then finally open the picker.
    P.open()
}

// For iOS8.
function handleKeydownEvent( event ) {

    var keycode = event.keyCode,

        // Check if one of the delete keys was pressed.
        isKeycodeDelete = /^(8|46)$/.test(keycode)

    // For some reason IE clears the input value on “escape”.
    if ( keycode == 27 ) {
        P.close( true )
        return false
    }

    // Check if `space` or `delete` was pressed or the picker is closed with a key movement.
    if ( keycode == 32 || isKeycodeDelete || !STATE.open && P.component.key[keycode] ) {

        // Prevent it from moving the page and bubbling to doc.
        event.preventDefault()
        event.stopPropagation()

        // If `delete` was pressed, clear the values and close the picker.
        // Otherwise open the picker.
        if ( isKeycodeDelete ) { P.clear().close() }
        else { P.open() }
    }
}

// Return a new picker instance.
return new PickerInstance()

} //PickerConstructor

/**

*/ PickerConstructor.klasses = function( prefix ) {

prefix = prefix || 'picker'
return {

    picker: prefix,
    opened: prefix + '--opened',
    focused: prefix + '--focused',

    input: prefix + '__input',
    active: prefix + '__input--active',
    target: prefix + '__input--target',

    holder: prefix + '__holder',

    frame: prefix + '__frame',
    wrap: prefix + '__wrap',

    box: prefix + '__box'
}

} //PickerConstructor.klasses

/**

*/ function isUsingDefaultTheme( element ) {

var theme,
    prop = 'position'

// For IE.
if ( element.currentStyle ) {
    theme = element.currentStyle[prop]
}

// For normal browsers.
else if ( window.getComputedStyle ) {
    theme = getComputedStyle( element )[prop]
}

return theme == 'fixed'

}

/**

*/ function getScrollbarWidth() {

if ( $html.height() <= $window.height() ) {
    return 0
}

var $outer = $( '<div style="visibility:hidden;width:100px" />' ).
    appendTo( 'body' )

// Get the width without scrollbars.
var widthWithoutScroll = $outer[0].offsetWidth

// Force adding scrollbars.
$outer.css( 'overflow', 'scroll' )

// Add the inner div.
var $inner = $( '<div style="width:100%" />' ).appendTo( $outer )

// Get the width with scrollbars.
var widthWithScroll = $inner[0].offsetWidth

// Remove the divs.
$outer.remove()

// Return the difference between the widths.
return widthWithoutScroll - widthWithScroll

}

/**

*/ function getRealEventTarget( event, ELEMENT ) {

var path = []

if ( event.path ) {
    path = event.path
}

if ( event.originalEvent && event.originalEvent.path ) {
    path = event.originalEvent.path
}

if ( path && path.length > 0 ) {
    if ( ELEMENT && path.indexOf( ELEMENT ) >= 0 ) {
        return ELEMENT
    } else {
        return path[0]
    }
}

return event.target

}

// taken from davidwalsh.name/javascript-debounce-function function debounce(func, wait, immediate) {

var timeout;
return function() {
    var context = this, args = arguments;
    var later = function() {
        timeout = null;
        if (!immediate) func.apply(context, args);
    };
    var callNow = immediate && !timeout;
    clearTimeout(timeout);
    timeout = setTimeout(later, wait);
    if (callNow) func.apply(context, args);
};

}

/**

*/ PickerConstructor._ = {

/**
 * Create a group of nodes. Expects:
 * `
    {
        min:    {Integer},
        max:    {Integer},
        i:      {Integer},
        node:   {String},
        item:   {Function}
    }
 * `
 */
group: function( groupObject ) {

    var
        // Scope for the looped object
        loopObjectScope,

        // Create the nodes list
        nodesList = '',

        // The counter starts from the `min`
        counter = PickerConstructor._.trigger( groupObject.min, groupObject )

    // Loop from the `min` to `max`, incrementing by `i`
    for ( ; counter <= PickerConstructor._.trigger( groupObject.max, groupObject, [ counter ] ); counter += groupObject.i ) {

        // Trigger the `item` function within scope of the object
        loopObjectScope = PickerConstructor._.trigger( groupObject.item, groupObject, [ counter ] )

        // Splice the subgroup and create nodes out of the sub nodes
        nodesList += PickerConstructor._.node(
            groupObject.node,
            loopObjectScope[ 0 ],   // the node
            loopObjectScope[ 1 ],   // the classes
            loopObjectScope[ 2 ]    // the attributes
        )
    }

    // Return the list of nodes
    return nodesList
}, //group

/**
 * Create a dom node string
 */
node: function( wrapper, item, klass, attribute ) {

    // If the item is false-y, just return an empty string
    if ( !item ) return ''

    // If the item is an array, do a join
    item = $.isArray( item ) ? item.join( '' ) : item

    // Check for the class
    klass = klass ? ' class="' + klass + '"' : ''

    // Check for any attributes
    attribute = attribute ? ' ' + attribute : ''

    // Return the wrapped item
    return '<' + wrapper + klass + attribute + '>' + item + '</' + wrapper + '>'
}, //node

/**
 * Lead numbers below 10 with a zero.
 */
lead: function( number ) {
    return ( number < 10 ? '0': '' ) + number
},

/**
 * Trigger a function otherwise return the value.
 */
trigger: function( callback, scope, args ) {
    return typeof callback == 'function' ? callback.apply( scope, args || [] ) : callback
},

/**
 * If the second character is a digit, length is 2 otherwise 1.
 */
digits: function( string ) {
    return ( /\d/ ).test( string[ 1 ] ) ? 2 : 1
},

/**
 * Tell if something is a date object.
 */
isDate: function( value ) {
    return {}.toString.call( value ).indexOf( 'Date' ) > -1 && this.isInteger( value.getDate() )
},

/**
 * Tell if something is an integer.
 */
isInteger: function( value ) {
    return {}.toString.call( value ).indexOf( 'Number' ) > -1 && value % 1 === 0
},

/**
 * Create ARIA attribute strings.
 */
ariaAttr: ariaAttr

} //PickerConstructor._

/**

*/ PickerConstructor.extend = function( name, Component ) {

// Extend jQuery.
$.fn[ name ] = function( options, action ) {

    // Grab the component data.
    var componentData = this.data( name )

    // If the picker is requested, return the data object.
    if ( options == 'picker' ) {
        return componentData
    }

    // If the component data exists and `options` is a string, carry out the action.
    if ( componentData && typeof options == 'string' ) {
        return PickerConstructor._.trigger( componentData[ options ], componentData, [ action ] )
    }

    // Otherwise go through each matched element and if the component
    // doesn’t exist, create a new picker using `this` element
    // and merging the defaults and options with a deep copy.
    return this.each( function() {
        var $this = $( this )
        if ( !$this.data( name ) ) {
            new PickerConstructor( this, name, Component, options )
        }
    })
}

// Set the defaults.
$.fn[ name ].defaults = Component.defaults

} //PickerConstructor.extend

function aria(element, attribute, value) {

if ( $.isPlainObject(attribute) ) {
    for ( var key in attribute ) {
        ariaSet(element, key, attribute[key])
    }
}
else {
    ariaSet(element, attribute, value)
}

} function ariaSet(element, attribute, value) {

element.setAttribute(
    (attribute == 'role' ? '' : 'aria-') + attribute,
    value
)

} function ariaAttr(attribute, data) {

if ( !$.isPlainObject(attribute) ) {
    attribute = { attribute: data }
}
data = ''
for ( var key in attribute ) {
    var attr = (key == 'role' ? '' : 'aria-') + key,
        attrVal = attribute[key]
    data += attrVal == null ? '' : attr + '="' + attribute[key] + '"'
}
return data

}

// IE8 bug throws an error for activeElements within iframes. function getActiveElement() {

try {
    return document.activeElement
} catch ( err ) { }

}

// Expose the picker constructor. return PickerConstructor

}));

/*!

* Date picker for pickadate.js v3.6.3
* http://amsul.github.io/pickadate.js/date.htm
*/

(function (factory) {

// AMD.
if (typeof define == 'function' && define.amd)
  define(['picker', 'jquery'], factory)

// Node.js/browserify.
else if (typeof exports == 'object')
  module.exports = factory(require('./picker.js'), require('jquery'))

// Browser globals.
else factory(Picker, jQuery)

}(function (Picker, $) {

/**
 * Globals and constants
 */
var DAYS_IN_WEEK = 7,
  WEEKS_IN_CALENDAR = 6,
  _ = Picker._

/**
 * The date picker constructor
 */
function DatePicker(picker, settings) {

  var calendar = this,
    element = picker.$node[0],
    elementValue = element.value,
    elementDataValue = picker.$node.data('value'),
    valueString = elementDataValue || elementValue,
    formatString = elementDataValue ? settings.formatSubmit : settings.format,
    isRTL = function () {

      return element.currentStyle ?

        // For IE.
        element.currentStyle.direction == 'rtl' :

        // For normal browsers.
        getComputedStyle(picker.$root[0]).direction == 'rtl'
    }

  calendar.settings = settings
  calendar.$node = picker.$node

  // The queue of methods that will be used to build item objects.
  calendar.queue = {
    min: 'measure create',
    max: 'measure create',
    now: 'now create',
    select: 'parse create validate',
    highlight: 'parse navigate create validate',
    view: 'parse create validate viewset',
    disable: 'deactivate',
    enable: 'activate'
  }

  // The component's item object.
  calendar.item = {}

  calendar.item.clear = null
  calendar.item.disable = (settings.disable || []).slice(0)
  calendar.item.enable = -(function (collectionDisabled) {
    return collectionDisabled[0] === true ? collectionDisabled.shift() : -1
  })(calendar.item.disable)

  calendar.
  set('min', settings.min).
  set('max', settings.max).
  set('now')

  // When there’s a value, set the `select`, which in turn
  // also sets the `highlight` and `view`.
  if (valueString) {
    calendar.set('select', valueString, {
      format: formatString,
      defaultValue: true
    })
  }

  // If there’s no value, default to highlighting “today”.
  else {
    calendar.
    set('select', null).
    set('highlight', calendar.item.now)
  }

  // The keycode to movement mapping.
  calendar.key = {
    40: 7, // Down
    38: -7, // Up
    39: function () {
      return isRTL() ? -1 : 1
    }, // Right
    37: function () {
      return isRTL() ? 1 : -1
    }, // Left
    go: function (timeChange) {
      var highlightedObject = calendar.item.highlight,
        targetDate = new Date(highlightedObject.year, highlightedObject.month, highlightedObject.date + timeChange)
      calendar.set(
        'highlight',
        targetDate, {
          interval: timeChange
        }
      )
      this.render()
    }
  }

  // Bind some picker events.
  picker.
  on('render', function () {
    picker.$root.find('.' + settings.klass.selectMonth).on('change', function () {
      var value = this.value
      if (value) {
        picker.set('highlight', [picker.get('view').year, value, picker.get('highlight').date])
        picker.$root.find('.' + settings.klass.selectMonth).trigger('focus')
      }
    })
    picker.$root.find('.' + settings.klass.selectYear).on('change', function () {
      var value = this.value
      if (value) {
        picker.set('highlight', [value, picker.get('view').month, picker.get('highlight').date])
        picker.$root.find('.' + settings.klass.selectYear).trigger('focus')
      }
    })
  }, 1).
  on('open', function () {
    var includeToday = ''
    if (calendar.disabled(calendar.get('now'))) {
      includeToday = ':not(.' + settings.klass.buttonToday + ')'
    }
    picker.$root.find('button' + includeToday + ', select').attr('disabled', false)
  }, 1).
  on('close', function () {
    picker.$root.find('button, select').attr('disabled', true)
  }, 1)

} //DatePicker

/**
 * Set a datepicker item object.
 */
DatePicker.prototype.set = function (type, value, options) {

  var calendar = this,
    calendarItem = calendar.item

  // If the value is `null` just set it immediately.
  if (value === null) {
    if (type == 'clear') type = 'select'
    calendarItem[type] = value
    return calendar
  }

  // Otherwise go through the queue of methods, and invoke the functions.
  // Update this as the time unit, and set the final value as this item.
  // * In the case of `enable`, keep the queue but set `disable` instead.
  //   And in the case of `flip`, keep the queue but set `enable` instead.
  calendarItem[(type == 'enable' ? 'disable' : type == 'flip' ? 'enable' : type)] = calendar.queue[type].split(' ').map(function (method) {
    value = calendar[method](type, value, options)
    return value
  }).pop()

  // Check if we need to cascade through more updates.
  if (type == 'select') {
    calendar.set('highlight', calendarItem.select, options)
  } else if (type == 'highlight') {
    calendar.set('view', calendarItem.highlight, options)
  } else if (type.match(/^(flip|min|max|disable|enable)$/)) {
    if (calendarItem.select && calendar.disabled(calendarItem.select)) {
      calendar.set('select', calendarItem.select, options)
    }
    if (calendarItem.highlight && calendar.disabled(calendarItem.highlight)) {
      calendar.set('highlight', calendarItem.highlight, options)
    }
  }

  return calendar
} //DatePicker.prototype.set

/**
 * Get a datepicker item object.
 */
DatePicker.prototype.get = function (type) {
  return this.item[type]
} //DatePicker.prototype.get

/**
 * Create a picker date object.
 */
DatePicker.prototype.create = function (type, value, options) {

  var isInfiniteValue,
    calendar = this

  // If there’s no value, use the type as the value.
  value = value === undefined ? type : value

  // If it’s infinity, update the value.
  if (value == -Infinity || value == Infinity) {
    isInfiniteValue = value
  }

  // If it’s an object, use the native date object.
  else if ($.isPlainObject(value) && _.isInteger(value.pick)) {
    value = value.obj
  }

  // If it’s an array, convert it into a date and make sure
  // that it’s a valid date – otherwise default to today.
  else if ($.isArray(value)) {
    value = new Date(value[0], value[1], value[2])
    value = _.isDate(value) ? value : calendar.create().obj
  }

  // If it’s a number or date object, make a normalized date.
  else if (_.isInteger(value) || _.isDate(value)) {
    value = calendar.normalize(new Date(value), options)
  }

  // If it’s a literal true or any other case, set it to now.
  else /*if ( value === true )*/ {
    value = calendar.now(type, value, options)
  }

  // Return the compiled object.
  return {
    year: isInfiniteValue || value.getFullYear(),
    month: isInfiniteValue || value.getMonth(),
    date: isInfiniteValue || value.getDate(),
    day: isInfiniteValue || value.getDay(),
    obj: isInfiniteValue || value,
    pick: isInfiniteValue || value.getTime()
  }
} //DatePicker.prototype.create

/**
 * Create a range limit object using an array, date object,
 * literal “true”, or integer relative to another time.
 */
DatePicker.prototype.createRange = function (from, to) {

  var calendar = this,
    createDate = function (date) {
      if (date === true || $.isArray(date) || _.isDate(date)) {
        return calendar.create(date)
      }
      return date
    }

  // Create objects if possible.
  if (!_.isInteger(from)) {
    from = createDate(from)
  }
  if (!_.isInteger(to)) {
    to = createDate(to)
  }

  // Create relative dates.
  if (_.isInteger(from) && $.isPlainObject(to)) {
    from = [to.year, to.month, to.date + from];
  } else if (_.isInteger(to) && $.isPlainObject(from)) {
    to = [from.year, from.month, from.date + to];
  }

  return {
    from: createDate(from),
    to: createDate(to)
  }
} //DatePicker.prototype.createRange

/**
 * Check if a date unit falls within a date range object.
 */
DatePicker.prototype.withinRange = function (range, dateUnit) {
  range = this.createRange(range.from, range.to)
  return dateUnit.pick >= range.from.pick && dateUnit.pick <= range.to.pick
}

/**
 * Check if two date range objects overlap.
 */
DatePicker.prototype.overlapRanges = function (one, two) {

  var calendar = this

  // Convert the ranges into comparable dates.
  one = calendar.createRange(one.from, one.to)
  two = calendar.createRange(two.from, two.to)

  return calendar.withinRange(one, two.from) || calendar.withinRange(one, two.to) ||
    calendar.withinRange(two, one.from) || calendar.withinRange(two, one.to)
}

/**
 * Get the date today.
 */
DatePicker.prototype.now = function (type, value, options) {
  value = new Date()
  if (options && options.rel) {
    value.setDate(value.getDate() + options.rel)
  }
  return this.normalize(value, options)
}

/**
 * Navigate to next/prev month.
 */
DatePicker.prototype.navigate = function (type, value, options) {

  var targetDateObject,
    targetYear,
    targetMonth,
    targetDate,
    isTargetArray = $.isArray(value),
    isTargetObject = $.isPlainObject(value),
    viewsetObject = this.item.view
  /*,
        safety = 100*/

  if (isTargetArray || isTargetObject) {

    if (isTargetObject) {
      targetYear = value.year
      targetMonth = value.month
      targetDate = value.date
    } else {
      targetYear = +value[0]
      targetMonth = +value[1]
      targetDate = +value[2]
    }

    // If we’re navigating months but the view is in a different
    // month, navigate to the view’s year and month.
    if (options && options.nav && viewsetObject && viewsetObject.month !== targetMonth) {
      targetYear = viewsetObject.year
      targetMonth = viewsetObject.month
    }

    // Figure out the expected target year and month.
    targetDateObject = new Date(targetYear, targetMonth + (options && options.nav ? options.nav : 0), 1)
    targetYear = targetDateObject.getFullYear()
    targetMonth = targetDateObject.getMonth()

    // If the month we’re going to doesn’t have enough days,
    // keep decreasing the date until we reach the month’s last date.
    while ( /*safety &&*/ new Date(targetYear, targetMonth, targetDate).getMonth() !== targetMonth) {
      targetDate -= 1
      /*safety -= 1
      if ( !safety ) {
          throw 'Fell into an infinite loop while navigating to ' + new Date( targetYear, targetMonth, targetDate ) + '.'
      }*/
    }

    value = [targetYear, targetMonth, targetDate]
  }

  return value
} //DatePicker.prototype.navigate

/**
 * Normalize a date by setting the hours to midnight.
 */
DatePicker.prototype.normalize = function (value /*, options*/ ) {
  value.setHours(0, 0, 0, 0)
  return value
}

/**
 * Measure the range of dates.
 */
DatePicker.prototype.measure = function (type, value /*, options*/ ) {

  var calendar = this

  // If it's an integer, get a date relative to today.
  if (_.isInteger(value)) {
    value = calendar.now(type, value, {
      rel: value
    })
  }

  // If it’s anything false-y, remove the limits.
  else if (!value) {
    value = type == 'min' ? -Infinity : Infinity
  }

  // If it’s a string, parse it.
  else if (typeof value == 'string') {
    value = calendar.parse(type, value)
  }

  return value
} ///DatePicker.prototype.measure

/**
 * Create a viewset object based on navigation.
 */
DatePicker.prototype.viewset = function (type, dateObject /*, options*/ ) {
  return this.create([dateObject.year, dateObject.month, 1])
}

/**
 * Validate a date as enabled and shift if needed.
 */
DatePicker.prototype.validate = function (type, dateObject, options) {

  var calendar = this,

    // Keep a reference to the original date.
    originalDateObject = dateObject,

    // Make sure we have an interval.
    interval = options && options.interval ? options.interval : 1,

    // Check if the calendar enabled dates are inverted.
    isFlippedBase = calendar.item.enable === -1,

    // Check if we have any enabled dates after/before now.
    hasEnabledBeforeTarget, hasEnabledAfterTarget,

    // The min & max limits.
    minLimitObject = calendar.item.min,
    maxLimitObject = calendar.item.max,

    // Check if we’ve reached the limit during shifting.
    reachedMin, reachedMax,

    // Check if the calendar is inverted and at least one weekday is enabled.
    hasEnabledWeekdays = isFlippedBase && calendar.item.disable.filter(function (value) {

      // If there’s a date, check where it is relative to the target.
      if ($.isArray(value)) {
        var dateTime = calendar.create(value).pick
        if (dateTime < dateObject.pick) hasEnabledBeforeTarget = true
        else if (dateTime > dateObject.pick) hasEnabledAfterTarget = true
      }

      // Return only integers for enabled weekdays.
      return _.isInteger(value)
    }).length
  /*,

        safety = 100*/

  // Cases to validate for:
  // [1] Not inverted and date disabled.
  // [2] Inverted and some dates enabled.
  // [3] Not inverted and out of range.
  //
  // Cases to **not** validate for:
  // • Navigating months.
  // • Not inverted and date enabled.
  // • Inverted and all dates disabled.
  // • ..and anything else.
  if (!options || (!options.nav && !options.defaultValue))
    if (
      /* 1 */
      (!isFlippedBase && calendar.disabled(dateObject)) ||
      /* 2 */
      (isFlippedBase && calendar.disabled(dateObject) && (hasEnabledWeekdays || hasEnabledBeforeTarget || hasEnabledAfterTarget)) ||
      /* 3 */
      (!isFlippedBase && (dateObject.pick <= minLimitObject.pick || dateObject.pick >= maxLimitObject.pick))
    ) {

      // When inverted, flip the direction if there aren’t any enabled weekdays
      // and there are no enabled dates in the direction of the interval.
      if (isFlippedBase && !hasEnabledWeekdays && ((!hasEnabledAfterTarget && interval > 0) || (!hasEnabledBeforeTarget && interval < 0))) {
        interval *= -1
      }

      // Keep looping until we reach an enabled date.
      while ( /*safety &&*/ calendar.disabled(dateObject)) {

        /*safety -= 1
        if ( !safety ) {
            throw 'Fell into an infinite loop while validating ' + dateObject.obj + '.'
        }*/

        // If we’ve looped into the next/prev month with a large interval, return to the original date and flatten the interval.
        if (Math.abs(interval) > 1 && (dateObject.month < originalDateObject.month || dateObject.month > originalDateObject.month)) {
          dateObject = originalDateObject
          interval = interval > 0 ? 1 : -1
        }

        // If we’ve reached the min/max limit, reverse the direction, flatten the interval and set it to the limit.
        if (dateObject.pick <= minLimitObject.pick) {
          reachedMin = true
          interval = 1
          dateObject = calendar.create([
            minLimitObject.year,
            minLimitObject.month,
            minLimitObject.date + (dateObject.pick === minLimitObject.pick ? 0 : -1)
          ])
        } else if (dateObject.pick >= maxLimitObject.pick) {
          reachedMax = true
          interval = -1
          dateObject = calendar.create([
            maxLimitObject.year,
            maxLimitObject.month,
            maxLimitObject.date + (dateObject.pick === maxLimitObject.pick ? 0 : 1)
          ])
        }

        // If we’ve reached both limits, just break out of the loop.
        if (reachedMin && reachedMax) {
          break
        }

        // Finally, create the shifted date using the interval and keep looping.
        dateObject = calendar.create([dateObject.year, dateObject.month, dateObject.date + interval])
      }

    } //endif

  // Return the date object settled on.
  return dateObject
} //DatePicker.prototype.validate

/**
 * Check if a date is disabled.
 */
DatePicker.prototype.disabled = function (dateToVerify) {

  var
    calendar = this,

    // Filter through the disabled dates to check if this is one.
    isDisabledMatch = calendar.item.disable.filter(function (dateToDisable) {

      // If the date is a number, match the weekday with 0index and `firstDay` check.
      if (_.isInteger(dateToDisable)) {
        return dateToVerify.day === (calendar.settings.firstDay ? dateToDisable : dateToDisable - 1) % 7
      }

      // If it’s an array or a native JS date, create and match the exact date.
      if ($.isArray(dateToDisable) || _.isDate(dateToDisable)) {
        return dateToVerify.pick === calendar.create(dateToDisable).pick
      }

      // If it’s an object, match a date within the “from” and “to” range.
      if ($.isPlainObject(dateToDisable)) {
        return calendar.withinRange(dateToDisable, dateToVerify)
      }
    })

  // If this date matches a disabled date, confirm it’s not inverted.
  isDisabledMatch = isDisabledMatch.length && !isDisabledMatch.filter(function (dateToDisable) {
    return $.isArray(dateToDisable) && dateToDisable[3] == 'inverted' ||
      $.isPlainObject(dateToDisable) && dateToDisable.inverted
  }).length

  // Check the calendar “enabled” flag and respectively flip the
  // disabled state. Then also check if it’s beyond the min/max limits.
  return calendar.item.enable === -1 ? !isDisabledMatch : isDisabledMatch ||
    dateToVerify.pick < calendar.item.min.pick ||
    dateToVerify.pick > calendar.item.max.pick

} //DatePicker.prototype.disabled

/**
 * Parse a string into a usable type.
 */
DatePicker.prototype.parse = function (type, value, options) {

  var calendar = this,
    parsingObject = {}

  // If it’s already parsed, we’re good.
  if (!value || typeof value != 'string') {
    return value
  }

  // We need a `.format` to parse the value with.
  if (!(options && options.format)) {
    options = options || {}
    options.format = calendar.settings.format
  }

  // Convert the format into an array and then map through it.
  calendar.formats.toArray(options.format).map(function (label) {

    var
      // Grab the formatting label.
      formattingLabel = calendar.formats[label],

      // The format length is from the formatting label function or the
      // label length without the escaping exclamation (!) mark.
      formatLength = formattingLabel ? _.trigger(formattingLabel, calendar, [value, parsingObject]) : label.replace(/^!/, '').length

    // If there's a format label, split the value up to the format length.
    // Then add it to the parsing object with appropriate label.
    if (formattingLabel) {
      parsingObject[label] = value.substr(0, formatLength)
    }

    // Update the value as the substring from format length to end.
    value = value.substr(formatLength)
  })

  // Compensate for month 0index.
  return [
    parsingObject.yyyy || parsingObject.yy,
    +(parsingObject.mm || parsingObject.m) - 1,
    parsingObject.dd || parsingObject.d
  ]
} //DatePicker.prototype.parse

/**
 * Various formats to display the object in.
 */
DatePicker.prototype.formats = (function () {

  // Return the length of the first word in a collection.
  function getWordLengthFromCollection(string, collection, dateObject) {

    // Grab the first word from the string.
    // Regex pattern from http://stackoverflow.com/q/150033
    var word = string.match(/[^\x00-\x7F]+|\w+/)[0]

    // If there's no month index, add it to the date object
    if (!dateObject.mm && !dateObject.m) {
      dateObject.m = collection.indexOf(word) + 1
    }

    // Return the length of the word.
    return word.length
  }

  // Get the length of the first word in a string.
  function getFirstWordLength(string) {
    return string.match(/\w+/)[0].length
  }

  return {

    d: function (string, dateObject) {

      // If there's string, then get the digits length.
      // Otherwise return the selected date.
      return string ? _.digits(string) : dateObject.date
    },
    dd: function (string, dateObject) {

      // If there's a string, then the length is always 2.
      // Otherwise return the selected date with a leading zero.
      return string ? 2 : _.lead(dateObject.date)
    },
    ddd: function (string, dateObject) {

      // If there's a string, then get the length of the first word.
      // Otherwise return the short selected weekday.
      return string ? getFirstWordLength(string) : this.settings.weekdaysShort[dateObject.day]
    },
    dddd: function (string, dateObject) {

      // If there's a string, then get the length of the first word.
      // Otherwise return the full selected weekday.
      return string ? getFirstWordLength(string) : this.settings.weekdaysFull[dateObject.day]
    },
    m: function (string, dateObject) {

      // If there's a string, then get the length of the digits
      // Otherwise return the selected month with 0index compensation.
      return string ? _.digits(string) : dateObject.month + 1
    },
    mm: function (string, dateObject) {

      // If there's a string, then the length is always 2.
      // Otherwise return the selected month with 0index and leading zero.
      return string ? 2 : _.lead(dateObject.month + 1)
    },
    mmm: function (string, dateObject) {

      var collection = this.settings.monthsShort

      // If there's a string, get length of the relevant month from the short
      // months collection. Otherwise return the selected month from that collection.
      return string ? getWordLengthFromCollection(string, collection, dateObject) : collection[dateObject.month]
    },
    mmmm: function (string, dateObject) {

      var collection = this.settings.monthsFull

      // If there's a string, get length of the relevant month from the full
      // months collection. Otherwise return the selected month from that collection.
      return string ? getWordLengthFromCollection(string, collection, dateObject) : collection[dateObject.month]
    },
    yy: function (string, dateObject) {

      // If there's a string, then the length is always 2.
      // Otherwise return the selected year by slicing out the first 2 digits.
      return string ? 2 : ('' + dateObject.year).slice(2)
    },
    yyyy: function (string, dateObject) {

      // If there's a string, then the length is always 4.
      // Otherwise return the selected year.
      return string ? 4 : dateObject.year
    },

    // Create an array by splitting the formatting string passed.
    toArray: function (formatString) {
      return formatString.split(/(d{1,4}|m{1,4}|y{4}|yy|!.)/g)
    },

    // Format an object into a string using the formatting options.
    toString: function (formatString, itemObject) {
      var calendar = this
      return calendar.formats.toArray(formatString).map(function (label) {
        return _.trigger(calendar.formats[label], calendar, [0, itemObject]) || label.replace(/^!/, '')
      }).join('')
    }
  }
})() //DatePicker.prototype.formats

/**
 * Check if two date units are the exact.
 */
DatePicker.prototype.isDateExact = function (one, two) {

  var calendar = this

  // When we’re working with weekdays, do a direct comparison.
  if (
    (_.isInteger(one) && _.isInteger(two)) ||
    (typeof one == 'boolean' && typeof two == 'boolean')
  ) {
    return one === two
  }

  // When we’re working with date representations, compare the “pick” value.
  if (
    (_.isDate(one) || $.isArray(one)) &&
    (_.isDate(two) || $.isArray(two))
  ) {
    return calendar.create(one).pick === calendar.create(two).pick
  }

  // When we’re working with range objects, compare the “from” and “to”.
  if ($.isPlainObject(one) && $.isPlainObject(two)) {
    return calendar.isDateExact(one.from, two.from) && calendar.isDateExact(one.to, two.to)
  }

  return false
}

/**
 * Check if two date units overlap.
 */
DatePicker.prototype.isDateOverlap = function (one, two) {

  var calendar = this,
    firstDay = calendar.settings.firstDay ? 1 : 0

  // When we’re working with a weekday index, compare the days.
  if (_.isInteger(one) && (_.isDate(two) || $.isArray(two))) {
    one = one % 7 + firstDay
    return one === calendar.create(two).day + 1
  }
  if (_.isInteger(two) && (_.isDate(one) || $.isArray(one))) {
    two = two % 7 + firstDay
    return two === calendar.create(one).day + 1
  }

  // When we’re working with range objects, check if the ranges overlap.
  if ($.isPlainObject(one) && $.isPlainObject(two)) {
    return calendar.overlapRanges(one, two)
  }

  return false
}

/**
 * Flip the “enabled” state.
 */
DatePicker.prototype.flipEnable = function (val) {
  var itemObject = this.item
  itemObject.enable = val || (itemObject.enable == -1 ? 1 : -1)
}

/**
 * Mark a collection of dates as “disabled”.
 */
DatePicker.prototype.deactivate = function (type, datesToDisable) {

  var calendar = this,
    disabledItems = calendar.item.disable.slice(0)

  // If we’re flipping, that’s all we need to do.
  if (datesToDisable == 'flip') {
    calendar.flipEnable()
  } else if (datesToDisable === false) {
    calendar.flipEnable(1)
    disabledItems = []
  } else if (datesToDisable === true) {
    calendar.flipEnable(-1)
    disabledItems = []
  }

  // Otherwise go through the dates to disable.
  else {

    datesToDisable.map(function (unitToDisable) {

      var matchFound

      // When we have disabled items, check for matches.
      // If something is matched, immediately break out.
      for (var index = 0; index < disabledItems.length; index += 1) {
        if (calendar.isDateExact(unitToDisable, disabledItems[index])) {
          matchFound = true
          break
        }
      }

      // If nothing was found, add the validated unit to the collection.
      if (!matchFound) {
        if (
          _.isInteger(unitToDisable) ||
          _.isDate(unitToDisable) ||
          $.isArray(unitToDisable) ||
          ($.isPlainObject(unitToDisable) && unitToDisable.from && unitToDisable.to)
        ) {
          disabledItems.push(unitToDisable)
        }
      }
    })
  }

  // Return the updated collection.
  return disabledItems
} //DatePicker.prototype.deactivate

/**
 * Mark a collection of dates as “enabled”.
 */
DatePicker.prototype.activate = function (type, datesToEnable) {

  var calendar = this,
    disabledItems = calendar.item.disable,
    disabledItemsCount = disabledItems.length

  // If we’re flipping, that’s all we need to do.
  if (datesToEnable == 'flip') {
    calendar.flipEnable()
  } else if (datesToEnable === true) {
    calendar.flipEnable(1)
    disabledItems = []
  } else if (datesToEnable === false) {
    calendar.flipEnable(-1)
    disabledItems = []
  }

  // Otherwise go through the disabled dates.
  else {

    datesToEnable.map(function (unitToEnable) {

      var matchFound,
        disabledUnit,
        index,
        isExactRange

      // Go through the disabled items and try to find a match.
      for (index = 0; index < disabledItemsCount; index += 1) {

        disabledUnit = disabledItems[index]

        // When an exact match is found, remove it from the collection.
        if (calendar.isDateExact(disabledUnit, unitToEnable)) {
          matchFound = disabledItems[index] = null
          isExactRange = true
          break
        }

        // When an overlapped match is found, add the “inverted” state to it.
        else if (calendar.isDateOverlap(disabledUnit, unitToEnable)) {
          if ($.isPlainObject(unitToEnable)) {
            unitToEnable.inverted = true
            matchFound = unitToEnable
          } else if ($.isArray(unitToEnable)) {
            matchFound = unitToEnable
            if (!matchFound[3]) matchFound.push('inverted')
          } else if (_.isDate(unitToEnable)) {
            matchFound = [unitToEnable.getFullYear(), unitToEnable.getMonth(), unitToEnable.getDate(), 'inverted']
          }
          break
        }
      }

      // If a match was found, remove a previous duplicate entry.
      if (matchFound)
        for (index = 0; index < disabledItemsCount; index += 1) {
          if (calendar.isDateExact(disabledItems[index], unitToEnable)) {
            disabledItems[index] = null
            break
          }
        }

      // In the event that we’re dealing with an exact range of dates,
      // make sure there are no “inverted” dates because of it.
      if (isExactRange)
        for (index = 0; index < disabledItemsCount; index += 1) {
          if (calendar.isDateOverlap(disabledItems[index], unitToEnable)) {
            disabledItems[index] = null
            break
          }
        }

      // If something is still matched, add it into the collection.
      if (matchFound) {
        disabledItems.push(matchFound)
      }
    })
  }

  // Return the updated collection.
  return disabledItems.filter(function (val) {
    return val != null
  })
} //DatePicker.prototype.activate

/**
 * Create a string for the nodes in the picker.
 */
DatePicker.prototype.nodes = function (isOpen) {

  var
    calendar = this,
    settings = calendar.settings,
    calendarItem = calendar.item,
    nowObject = calendarItem.now,
    selectedObject = calendarItem.select,
    highlightedObject = calendarItem.highlight,
    viewsetObject = calendarItem.view,
    disabledCollection = calendarItem.disable,
    minLimitObject = calendarItem.min,
    maxLimitObject = calendarItem.max,

    // Create the calendar table head using a copy of weekday labels collection.
    // * We do a copy so we don't mutate the original array.
    tableHead = (function (collection, fullCollection) {

      // If the first day should be Monday, move Sunday to the end.
      if (settings.firstDay) {
        collection.push(collection.shift())
        fullCollection.push(fullCollection.shift())
      }

      // Create and return the table head group.
      return _.node(
        'thead',
        _.node(
          'tr',
          _.group({
            min: 0,
            max: DAYS_IN_WEEK - 1,
            i: 1,
            node: 'th',
            item: function (counter) {
              return [
                collection[counter],
                settings.klass.weekdays,
                'scope=col title="' + fullCollection[counter] + '"'
              ]
            }
          })
        )
      ) //endreturn
    })((settings.showWeekdaysFull ? settings.weekdaysFull : settings.weekdaysShort).slice(0), settings.weekdaysFull.slice(0)), //tableHead

    // Create the nav for next/prev month.
    createMonthNav = function (next) {

      // Otherwise, return the created month tag.
      return _.node(
        'button',
        ' ',
        settings.klass['nav' + (next ? 'Next' : 'Prev')] + (

          // If the focused month is outside the range, disabled the button.
          (next && viewsetObject.year >= maxLimitObject.year && viewsetObject.month >= maxLimitObject.month) ||
          (!next && viewsetObject.year <= minLimitObject.year && viewsetObject.month <= minLimitObject.month) ?
          ' ' + settings.klass.navDisabled : ''
        ),
        'data-nav=' + (next || -1) + ' ' +
        _.ariaAttr({
          role: 'button',

          controls: calendar.$node[0].id + '_table'
        }) + ' ' +
        'title="' + (next ? settings.labelMonthNext : settings.labelMonthPrev) + '"'
      ) //endreturn
    }, //createMonthNav

    // Create the month label.
    createMonthLabel = function () {

      var monthsCollection = settings.showMonthsShort ? settings.monthsShort : settings.monthsFull

      // If there are months to select, add a dropdown menu.
      if (settings.selectMonths) {

        return _.node('select',
          _.group({
            min: 0,
            max: 11,
            i: 1,
            node: 'option',
            item: function (loopedMonth) {

              return [

                // The looped month and no classes.
                monthsCollection[loopedMonth], 0,

                // Set the value and selected index.
                'value=' + loopedMonth +
                (viewsetObject.month == loopedMonth ? ' selected' : '') +
                (
                  (
                    (viewsetObject.year == minLimitObject.year && loopedMonth < minLimitObject.month) ||
                    (viewsetObject.year == maxLimitObject.year && loopedMonth > maxLimitObject.month)
                  ) ?
                  ' disabled' : ''
                )
              ]
            }
          }),
          settings.klass.selectMonth,
          (isOpen ? '' : 'disabled') + ' ' +
          _.ariaAttr({
            controls: calendar.$node[0].id + '_table'
          }) + ' ' +
          'title="' + settings.labelMonthSelect + '"'
        )
      }

      // If there's a need for a month selector
      return _.node('div', monthsCollection[viewsetObject.month], settings.klass.month)
    }, //createMonthLabel

    // Create the year label.
    createYearLabel = function () {

      var focusedYear = viewsetObject.year,

        // If years selector is set to a literal "true", set it to 5. Otherwise
        // divide in half to get half before and half after focused year.
        numberYears = settings.selectYears === true ? 5 : ~~(settings.selectYears / 2)

      // If there are years to select, add a dropdown menu.
      if (numberYears) {

        var
          minYear = minLimitObject.year,
          maxYear = maxLimitObject.year,
          lowestYear = focusedYear - numberYears,
          highestYear = focusedYear + numberYears

        // If the min year is greater than the lowest year, increase the highest year
        // by the difference and set the lowest year to the min year.
        if (minYear > lowestYear) {
          highestYear += minYear - lowestYear
          lowestYear = minYear
        }

        // If the max year is less than the highest year, decrease the lowest year
        // by the lower of the two: available and needed years. Then set the
        // highest year to the max year.
        if (maxYear < highestYear) {

          var availableYears = lowestYear - minYear,
            neededYears = highestYear - maxYear

          lowestYear -= availableYears > neededYears ? neededYears : availableYears
          highestYear = maxYear
        }

        return _.node('select',
          _.group({
            min: lowestYear,
            max: highestYear,
            i: 1,
            node: 'option',
            item: function (loopedYear) {
              return [

                // The looped year and no classes.
                loopedYear, 0,

                // Set the value and selected index.
                'value=' + loopedYear + (focusedYear == loopedYear ? ' selected' : '')
              ]
            }
          }),
          settings.klass.selectYear,
          (isOpen ? '' : 'disabled') + ' ' + _.ariaAttr({
            controls: calendar.$node[0].id + '_table'
          }) + ' ' +
          'title="' + settings.labelYearSelect + '"'
        )
      }

      // Otherwise just return the year focused
      return _.node('div', focusedYear, settings.klass.year)
    } //createYearLabel

  // Create and return the entire calendar.
  return _.node(
      'div',
      (settings.selectYears ? createYearLabel() + createMonthLabel() : createMonthLabel() + createYearLabel()) +
      createMonthNav() + createMonthNav(1),
      settings.klass.header
    ) + _.node(
      'table',
      tableHead +
      _.node(
        'tbody',
        _.group({
          min: 0,
          max: WEEKS_IN_CALENDAR - 1,
          i: 1,
          node: 'tr',
          item: function (rowCounter) {

            // If Monday is the first day and the month starts on Sunday, shift the date back a week.
            var shiftDateBy = settings.firstDay && calendar.create([viewsetObject.year, viewsetObject.month, 1]).day === 0 ? -7 : 0

            return [
              _.group({
                min: DAYS_IN_WEEK * rowCounter - viewsetObject.day + shiftDateBy + 1, // Add 1 for weekday 0index
                max: function () {
                  return this.min + DAYS_IN_WEEK - 1
                },
                i: 1,
                node: 'td',
                item: function (targetDate) {

                  // Convert the time date from a relative date to a target date.
                  targetDate = calendar.create([viewsetObject.year, viewsetObject.month, targetDate + (settings.firstDay ? 1 : 0)])

                  var isSelected = selectedObject && selectedObject.pick == targetDate.pick,
                    isHighlighted = highlightedObject && highlightedObject.pick == targetDate.pick,
                    isDisabled = disabledCollection && calendar.disabled(targetDate) || targetDate.pick < minLimitObject.pick || targetDate.pick > maxLimitObject.pick,
                    formattedDate = _.trigger(calendar.formats.toString, calendar, [settings.format, targetDate])

                  return [
                    _.node(
                      'div',
                      targetDate.date,
                      (function (klasses) {

                        // Add the `infocus` or `outfocus` classes based on month in view.
                        klasses.push(viewsetObject.month == targetDate.month ? settings.klass.infocus : settings.klass.outfocus)

                        // Add the `today` class if needed.
                        if (nowObject.pick == targetDate.pick) {
                          klasses.push(settings.klass.now)
                        }

                        // Add the `selected` class if something's selected and the time matches.
                        if (isSelected) {
                          klasses.push(settings.klass.selected)
                        }

                        // Add the `highlighted` class if something's highlighted and the time matches.
                        if (isHighlighted) {
                          klasses.push(settings.klass.highlighted)
                        }

                        // Add the `disabled` class if something's disabled and the object matches.
                        if (isDisabled) {
                          klasses.push(settings.klass.disabled)
                        }

                        return klasses.join(' ')
                      })([settings.klass.day]),
                      'data-pick=' + targetDate.pick + ' ' + _.ariaAttr({
                        role: 'gridcell',
                        label: formattedDate,
                        selected: isSelected && calendar.$node.val() === formattedDate ? true : null,
                        activedescendant: isHighlighted ? true : null,
                        disabled: isDisabled ? true : null
                      })
                    ),
                    '',
                    _.ariaAttr({
                      role: 'presentation'
                    })
                  ] //endreturn
                }
              })
            ] //endreturn
          }
        })
      ),
      settings.klass.table,
      'id="' + calendar.$node[0].id + '_table' + '" ' + _.ariaAttr({
        role: 'grid',
        controls: calendar.$node[0].id,
        readonly: true
      })
    ) +

    // * For Firefox forms to submit, make sure to set the buttons’ `type` attributes as “button”.
    _.node(
      'div',
      _.node('button', settings.today, settings.klass.buttonToday,
        'type=button data-pick=' + nowObject.pick +
        (isOpen && !calendar.disabled(nowObject) ? '' : ' disabled') + ' ' +
        _.ariaAttr({
          controls: calendar.$node[0].id
        })) +
      _.node('button', settings.clear, settings.klass.buttonClear,
        'type=button data-clear=1' +
        (isOpen ? '' : ' disabled') + ' ' +
        _.ariaAttr({
          controls: calendar.$node[0].id
        })) +
      _.node('button', settings.close, settings.klass.buttonClose,
        'type=button data-close=true ' +
        (isOpen ? '' : ' disabled') + ' ' +
        _.ariaAttr({
          controls: calendar.$node[0].id
        })),
      settings.klass.footer
    ) //endreturn
} //DatePicker.prototype.nodes

/**
 * The date picker defaults.
 */
DatePicker.defaults = (function (prefix) {

  return {

    // The title label to use for the month nav buttons
    labelMonthNext: 'Next month',
    labelMonthPrev: 'Previous month',

    // The title label to use for the dropdown selectors
    labelMonthSelect: 'Select a month',
    labelYearSelect: 'Select a year',

    // Months and weekdays
    monthsFull: ['January', 'February', 'March', 'April', 'May', 'June', 'July', 'August', 'September', 'October', 'November', 'December'],
    monthsShort: ['Jan', 'Feb', 'Mar', 'Apr', 'May', 'Jun', 'Jul', 'Aug', 'Sep', 'Oct', 'Nov', 'Dec'],
    weekdaysFull: ['Sunday', 'Monday', 'Tuesday', 'Wednesday', 'Thursday', 'Friday', 'Saturday'],
    weekdaysShort: ['Sun', 'Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat'],

    // Today and clear
    today: 'Today',
    clear: 'Clear',
    close: 'Close',

    // Picker close behavior
    closeOnSelect: true,
    closeOnClear: true,

    // Update input value on select/clear
    updateInput: true,

    // The format to show on the `input` element
    format: 'd mmmm, yyyy',

    // Classes
    klass: {

      table: prefix + 'table',

      header: prefix + 'header',

      navPrev: prefix + 'nav--prev btn btn-flat',
      navNext: prefix + 'nav--next btn btn-flat',
      navDisabled: prefix + 'nav--disabled',

      month: prefix + 'month',
      year: prefix + 'year',

      selectMonth: prefix + 'select--month',
      selectYear: prefix + 'select--year',

      weekdays: prefix + 'weekday',

      day: prefix + 'day',
      disabled: prefix + 'day--disabled',
      selected: prefix + 'day--selected',
      highlighted: prefix + 'day--highlighted',
      now: prefix + 'day--today',
      infocus: prefix + 'day--infocus',
      outfocus: prefix + 'day--outfocus',

      footer: prefix + 'footer',

      buttonClear: prefix + 'button--clear',
      buttonToday: prefix + 'button--today',
      buttonClose: prefix + 'button--close'
    }
  }
})(Picker.klasses().picker + '__')

/**
 * Extend the picker to add the date picker.
 */
Picker.extend('pickadate', DatePicker)

}));

$.extend($.fn.pickadate.defaults, {

selectMonths: true, // Creates a dropdown to control month
selectYears: 15, // Creates a dropdown of 15 years to control year,

onRender: function () {
  var $pickerInstance = this.$root;

  var year = this.get('highlight', 'yyyy');
  var day = this.get('highlight', 'dd');
  var month = this.get('highlight', 'mmm');
  var labeldayFirstThreeLetters = this.get('highlight', 'dddd').slice(0, 3);
  var monthFirstUC = month.charAt(0).toUpperCase() + month.slice(1)

  $pickerInstance.find('.picker__header').prepend('<div class="picker__date-display"><div class="picker__weekday-display">' + labeldayFirstThreeLetters + ', </div><div class="picker__month-display"><div>' + monthFirstUC + '</div></div><div class="picker__day-display"><div>' + day + '</div></div><div    class="picker__year-display"><div>' + year + '</div></div></div>');
}

});

/*!

* ClockPicker v0.0.7 (http://weareoutman.github.io/clockpicker/)
* Copyright 2014 Wang Shenwei.
* Licensed under MIT (https://github.com/weareoutman/clockpicker/blob/gh-pages/LICENSE)
*
* Further modified
* Copyright 2015 Ching Yaw Hao.
*/

;(function(){

      var $ = window.jQuery,
                      $win = $(window),
                      $doc = $(document);

      // Can I use inline svg ?
      var svgNS = 'http://www.w3.org/2000/svg',
                svgSupported = 'SVGAngle' in window && (function() {
                        var supported,
                              el = document.createElement('div');
                              el.innerHTML = '<svg/>';
                              supported = (el.firstChild && el.firstChild.namespaceURI) == svgNS;
                              el.innerHTML = '';
                              return supported;
                      })();

      // Can I use transition ?
      var transitionSupported = (function() {
              var style = document.createElement('div').style;
              return 'transition' in style ||
                                       'WebkitTransition' in style ||
                                 'MozTransition' in style ||
                                       'msTransition' in style ||
                                       'OTransition' in style;
      })();

      // Listen touch events in touch screen device, instead of mouse events in desktop.
      var touchSupported = 'ontouchstart' in window,
                      mousedownEvent = 'mousedown' + ( touchSupported ? ' touchstart' : ''),
                      mousemoveEvent = 'mousemove.clockpicker' + ( touchSupported ? ' touchmove.clockpicker' : ''),
                      mouseupEvent = 'mouseup.clockpicker' + ( touchSupported ? ' touchend.clockpicker' : '');

      // Vibrate the device if supported
      var vibrate = navigator.vibrate ? 'vibrate' : navigator.webkitVibrate ? 'webkitVibrate' : null;

      function createSvgElement(name) {
              return document.createElementNS(svgNS, name);
      }

function debounce(func, wait, immediate) {
  var timeout;
  return function() {
      var context = this, args = arguments;
      var later = function() {
          timeout = null;
          if (!immediate) func.apply(context, args);
      };
      var callNow = immediate && !timeout;
      clearTimeout(timeout);
      timeout = setTimeout(later, wait);
      if (callNow) func.apply(context, args);
  };

}

      function leadingZero(num) {
              return (num < 10 ? '0' : '') + num;
      }

      // Get a unique id
      var idCounter = 0;
      function uniqueId(prefix) {
              var id = ++idCounter + '';
              return prefix ? prefix + id : id;
      }

      // Clock size
      var dialRadius = 135,
                      outerRadius = 110,
                      // innerRadius = 80 on 12 hour clock
                      innerRadius = 80,
                      tickRadius = 20,
                      diameter = dialRadius * 2,
                      duration = transitionSupported ? 350 : 1;

      // Popover template
      var tpl = [
              '<div class="clockpicker picker">',
                      '<div class="picker__holder">',
                              '<div class="picker__frame">',
                                      '<div class="picker__wrap">',
                                              '<div class="picker__box">',
                                                      '<div class="picker__date-display">',
                                                              '<div class="clockpicker-display">',
                                                                      '<div class="clockpicker-display-column">',
                                                                              '<span class="clockpicker-span-hours text-primary"></span>',
                                                                              ':',
                                                                              '<span class="clockpicker-span-minutes"></span>',
                                                                      '</div>',
                                                                      '<div class="clockpicker-display-column clockpicker-display-am-pm">',
                                                                              '<div class="clockpicker-span-am-pm"></div>',
                                                                      '</div>',
                                                              '</div>',
                                                      '</div>',
                                                      '<div class="picker__calendar-container">',
                                                              '<div class="clockpicker-plate">',
                                                                      '<div class="clockpicker-canvas"></div>',
                                                                      '<div class="clockpicker-dial clockpicker-hours"></div>',
                                                                      '<div class="clockpicker-dial clockpicker-minutes clockpicker-dial-out"></div>',
                                                              '</div>',
                                                              '<div class="clockpicker-am-pm-block">',
                                                              '</div>',
                                                      '</div>',
                                                      '<div class="picker__footer">',
                                                      '</div>',
                                              '</div>',
                                      '</div>',
                              '</div>',
                      '</div>',
              '</div>'
      ].join('');

      // ClockPicker
      function ClockPicker(element, options) {
              var popover = $(tpl),
                              plate = popover.find('.clockpicker-plate'),
                              holder = popover.find('.picker__holder'),
                              hoursView = popover.find('.clockpicker-hours'),
                              minutesView = popover.find('.clockpicker-minutes'),
                              amPmBlock = popover.find('.clockpicker-am-pm-block'),
                              isInput = element.prop('tagName') === 'INPUT',
      input = isInput ? element : element.find('input'),
      isHTML5 = input.prop('type') === 'time',
                              label = $("label[for=" + input.attr("id") + "]"),
                              self = this,
                              timer;

              this.id = uniqueId('cp');
              this.element = element;
              this.holder = holder;
              this.options = options;
              this.isAppended = false;
              this.isShown = false;
              this.currentView = 'hours';
              this.isInput = isInput;
              this.input = input;
              this.label = label;
              this.popover = popover;
              this.plate = plate;
              this.hoursView = hoursView;
              this.minutesView = minutesView;
              this.amPmBlock = amPmBlock;
              this.spanHours = popover.find('.clockpicker-span-hours');
              this.spanMinutes = popover.find('.clockpicker-span-minutes');
              this.spanAmPm = popover.find('.clockpicker-span-am-pm');
              this.footer = popover.find('.picker__footer');
              this.amOrPm = "";

              // Setup for for 12 hour clock if option is selected
              if (options.twelvehour) {
                      var  amPmButtonsTemplate = [
                              '<div class="clockpicker-am-pm-block">',
                                      '<button type="button" class="btn-floating btn-flat clockpicker-button clockpicker-am-button">',
                                              'AM',
                                      '</button>',
                                      '<button type="button" class="btn-floating btn-flat clockpicker-button clockpicker-pm-button">',
                                              'PM',
                                      '</button>',
                              '</div>'
                      ].join('');

                      var amPmButtons = $(amPmButtonsTemplate);

                      if (!options.ampmclickable) {
                              $('<button type="button" class="btn-floating btn-flat clockpicker-button am-button" tabindex="1">' + "AM" + '</button>').on("click", function() {
                                      self.amOrPm = "AM";
                                      self.amPmBlock.children('.pm-button').removeClass('active');
                                      self.amPmBlock.children('.am-button').addClass('active');
                                      self.spanAmPm.empty().append('AM');
                              }).appendTo(this.amPmBlock);
                              $('<button type="button" class="btn-floating btn-flat clockpicker-button pm-button" tabindex="2">' + "PM" + '</button>').on("click", function() {
                                      self.amOrPm = 'PM';
                                      self.amPmBlock.children('.am-button').removeClass('active');
                                      self.amPmBlock.children('.pm-button').addClass('active');
                                      self.spanAmPm.empty().append('PM');
                              }).appendTo(this.amPmBlock);
                      }
                      else {
                              this.spanAmPm.empty();
                              $('<div id="click-am">AM</div>').on("click", function() {
                                      self.spanAmPm.children('#click-am').addClass("text-primary");
                                      self.spanAmPm.children('#click-pm').removeClass("text-primary");
                                      self.amOrPm = "AM";
                              }).appendTo(this.spanAmPm);
                              $('<div id="click-pm">PM</div>').on("click", function() {
                                      self.spanAmPm.children('#click-pm').addClass("text-primary");
                                      self.spanAmPm.children('#click-am').removeClass("text-primary");
                                      self.amOrPm = 'PM';
                              }).appendTo(this.spanAmPm);
                      }
              }

              if(options.darktheme)
                      popover.addClass('darktheme');

                      // If autoclose is not setted, append a button
              $('<button type="button" class="btn btn-flat clockpicker-button" tabindex="' + (options.twelvehour? '3' : '1') + '">' + options.donetext + '</button>').click($.proxy(this.done, this)).appendTo(this.footer);

              $('<button type="button" class="btn btn-flat clockpicker-button" tabindex="' + (options.twelvehour? '4' : '2') + '">' + options.cleartext + '</button>').click($.proxy(this.clearInput, this)).appendTo(this.footer);
              this.spanHours.click($.proxy(this.toggleView, this, 'hours'));
              this.spanMinutes.click($.proxy(this.toggleView, this, 'minutes'));

              // Show or toggle
              input.on('focus.clockpicker click.clockpicker', debounce( $.proxy(this.show, this), 100));

              // Build ticks
              var tickTpl = $('<div class="clockpicker-tick"></div>'),
                              i, tick, radian, radius;

              // Hours view
  if (options.twelvehour) {
    for (i = 0; i < 12; i += options.hourstep) {
        tick = tickTpl.clone();
        radian = i / 6 * Math.PI;
        radius = outerRadius;
        tick.css('font-size', '140%');
        tick.css({
            left: dialRadius + Math.sin(radian) * radius - tickRadius,
            top: dialRadius - Math.cos(radian) * radius - tickRadius
        });
        tick.html(i === 0 ? 12 : i);
        hoursView.append(tick);
        tick.on(mousedownEvent, mousedown);
    }
              } else {
    for (i = 0; i < 24; i += options.hourstep) {
      tick = tickTpl.clone();
      radian = i / 6 * Math.PI;
      var inner = i > 0 && i < 13;
      radius = inner ? innerRadius : outerRadius;
      tick.css({
          left: dialRadius + Math.sin(radian) * radius - tickRadius,
          top: dialRadius - Math.cos(radian) * radius - tickRadius
      });
      if (inner) {
          tick.css('font-size', '120%');
      }
      tick.html(i === 0 ? '00' : i);
      hoursView.append(tick);
      tick.on(mousedownEvent, mousedown);
                      }
              }

  // Minutes view
  var incrementValue = Math.max(options.minutestep, 5);
  for (i = 0; i < 60; i += incrementValue) {
    for (i = 0; i < 60; i += 5) {
      tick = tickTpl.clone();
      radian = i / 30 * Math.PI;
      tick.css({
        left: dialRadius + Math.sin(radian) * outerRadius - tickRadius,
        top: dialRadius - Math.cos(radian) * outerRadius - tickRadius
      });
      tick.css('font-size', '140%');
      tick.html(leadingZero(i));
      minutesView.append(tick);
      tick.on(mousedownEvent, mousedown);
    }
  }

              // Clicking on minutes view space
              plate.on(mousedownEvent, function(e) {
                      if ($(e.target).closest('.clockpicker-tick').length === 0)
                              mousedown(e, true);
              });

              // Mousedown or touchstart
              function mousedown(e, space) {
                      var offset = plate.offset(),
                                      isTouch = /^touch/.test(e.type),
                                      x0 = offset.left + dialRadius,
                                      y0 = offset.top + dialRadius,
                                      dx = (isTouch ? e.originalEvent.touches[0] : e).pageX - x0,
                                      dy = (isTouch ? e.originalEvent.touches[0] : e).pageY - y0,
                                      z = Math.sqrt(dx * dx + dy * dy),
                                      moved = false;

                      // When clicking on minutes view space, check the mouse position
                      if (space && (z < outerRadius - tickRadius || z > outerRadius + tickRadius))
                              return;
                      e.preventDefault();

                      // Set cursor style of body after 200ms
                      var movingTimer = setTimeout(function(){
                              self.popover.addClass('clockpicker-moving');
                      }, 200);

                      // Place the canvas to top
                      if (svgSupported)
                              plate.append(self.canvas);

                      // Clock
                      self.setHand(dx, dy, !space, true);

                      // Mousemove on document
                      $doc.off(mousemoveEvent).on(mousemoveEvent, function(e){
                              e.preventDefault();
                              var isTouch = /^touch/.test(e.type),
                                              x = (isTouch ? e.originalEvent.touches[0] : e).pageX - x0,
                                              y = (isTouch ? e.originalEvent.touches[0] : e).pageY - y0;
                              if (! moved && x === dx && y === dy)
                                      // Clicking in chrome on windows will trigger a mousemove event
                                      return;
                              moved = true;
                              self.setHand(x, y, false, true);
                      });

                      // Mouseup on document
                      $doc.off(mouseupEvent).on(mouseupEvent, function(e) {
                              $doc.off(mouseupEvent);
                              e.preventDefault();
                              var isTouch = /^touch/.test(e.type),
                                              x = (isTouch ? e.originalEvent.changedTouches[0] : e).pageX - x0,
                                              y = (isTouch ? e.originalEvent.changedTouches[0] : e).pageY - y0;
                              if ((space || moved) && x === dx && y === dy)
                                      self.setHand(x, y);
                              if (self.currentView === 'hours')
                                      self.toggleView('minutes', duration / 2);
                              else
                                      if (options.autoclose) {
                                              self.minutesView.addClass('clockpicker-dial-out');
                                              setTimeout(function(){
                                                      self.done();
                                              }, duration / 2);
                                      }
                              plate.prepend(canvas);

                              // Reset cursor style of body
                              clearTimeout(movingTimer);
                              self.popover.removeClass('clockpicker-moving');

                              // Unbind mousemove event
                              $doc.off(mousemoveEvent);
                      });
              }

              if (svgSupported) {
                      // Draw clock hands and others
                      var canvas = popover.find('.clockpicker-canvas'),
                                      svg = createSvgElement('svg');
                      svg.setAttribute('class', 'clockpicker-svg');
                      svg.setAttribute('width', diameter);
                      svg.setAttribute('height', diameter);
                      var g = createSvgElement('g');
                      g.setAttribute('transform', 'translate(' + dialRadius + ',' + dialRadius + ')');
                      var bearing = createSvgElement('circle');
                      bearing.setAttribute('class', 'clockpicker-canvas-bearing');
                      bearing.setAttribute('cx', 0);
                      bearing.setAttribute('cy', 0);
                      bearing.setAttribute('r', 2);
                      var hand = createSvgElement('line');
                      hand.setAttribute('x1', 0);
    hand.setAttribute('y1', 0);
                      var bg = createSvgElement('circle');
                      bg.setAttribute('class', 'clockpicker-canvas-bg');
                      bg.setAttribute('r', tickRadius);
                      var fg = createSvgElement('circle');
                      fg.setAttribute('class', 'clockpicker-canvas-fg');
                      fg.setAttribute('r', 5);
                      g.appendChild(hand);
                      g.appendChild(bg);
                      g.appendChild(fg);
                      g.appendChild(bearing);
                      svg.appendChild(g);
                      canvas.append(svg);

                      this.hand = hand;
                      this.bg = bg;
                      this.fg = fg;
                      this.bearing = bearing;
                      this.g = g;
                      this.canvas = canvas;
              }

              raiseCallback(this.options.init);
      }

      function raiseCallback(callbackFunction) {
              if(callbackFunction && typeof callbackFunction === "function")
                      callbackFunction();
      }

      // Default options
      ClockPicker.DEFAULTS = {
              'default': '',         // default time, 'now' or '13:14' e.g.
              fromnow: 0,            // set default time to * milliseconds from now (using with default = 'now')
  donetext: 'Done',      // done button text
  cleartext: 'Clear',    // clear button text
              autoclose: false,      // auto close when minute is selected
              ampmclickable: false,  // set am/pm button on itself
              darktheme: false,                        // set to dark theme
              twelvehour: false,     // change to 12 hour AM/PM clock from 24 hour
  vibrate: true,         // vibrate the device when dragging clock hand
  hourstep: 1,           // allow to multi increment the hour
  minutestep: 1,         // allow to multi increment the minute
  ampmSubmit: false,     // allow submit with AM and PM buttons instead of the minute selection/picker
      };

      // Show or hide popover
      ClockPicker.prototype.toggle = function() {
              this[this.isShown ? 'hide' : 'show']();
      };

      // Set popover position
      ClockPicker.prototype.locate = function() {
              var element = this.element,
                              popover = this.popover,
                              offset = element.offset(),
                              width = element.outerWidth(),
                              height = element.outerHeight(),
                              align = this.options.align,
                              self = this;

              popover.show();
};

  // The input can be changed by the user
  // So before we can use this.hours/this.minutes we must update it

ClockPicker.prototype.parseInputValue = function(){

var value = this.input.prop('value') || this.options['default'] || '';

if (value === 'now') {
    value = new Date(+ new Date() + this.options.fromnow);
}
if (value instanceof Date) {
    value = value.getHours() + ':' + value.getMinutes();
}

value = value.split(':');

// Minutes can have AM/PM that needs to be removed
this.hours = + value[0] || 0;
this.minutes = + (value[1] + '').replace(/\D/g, '') || 0;

this.hours = Math.round(this.hours / this.options.hourstep) * this.options.hourstep;
this.minutes = Math.round(this.minutes / this.options.minutestep) * this.options.minutestep;

if (this.options.twelvehour) {
    var period = (value[1] + '').replace(/\d+/g, '').toLowerCase();
    this.amOrPm = this.hours > 12 || period === 'pm' ? 'PM' : 'AM';
}

};

      // Show popover
      ClockPicker.prototype.show = function(e){
              // Not show again
              if (this.isShown) {
                      return;
              }
              raiseCallback(this.options.beforeShow);
              $(':input').each(function() {
                      $(this).attr('tabindex', -1);
              })
              var self = this;
              // Initialize
              this.input.blur();
              this.popover.addClass('picker--opened');
              this.input.addClass('picker__input picker__input--active');
              $(document.body).css('overflow', 'hidden');
              if (!this.isAppended) {
                      // Append popover to body
                      this.popover.insertAfter(this.input);
                      if(this.options.twelvehour) {
                              this.amOrPm = 'PM';
                              if(!this.options.ampmclickable) {
                                      this.amPmBlock.children('.am-button').removeClass('active');
                                      this.amPmBlock.children('.pm-button').addClass('active');
                                      this.spanAmPm.empty().append('PM');
                              }
                              else {
                                      this.spanAmPm.children('#click-pm').addClass("text-primary");
                                      this.spanAmPm.children('#click-am').removeClass("text-primary");
                              }
                      }
                      // Reset position when resize
                      $win.on('resize.clockpicker' + this.id, function() {
                              if (self.isShown) {
                                      self.locate();
                              }
                      });
                      this.isAppended = true;
              }
              // Get the time
              this.parseInputValue();
              this.spanHours.html(leadingZero(this.hours));
  this.spanMinutes.html(leadingZero(this.minutes));

  if (this.options.twelvehour) {
    this.spanAmPm.empty().append(this.amOrPm);
  }

              // Toggle to hours view
              this.toggleView('hours');
              // Set position
              this.locate();
              this.isShown = true;
              // Hide when clicking or tabbing on any element except the clock and input
              $doc.on('click.clockpicker.' + this.id + ' focusin.clockpicker.' + this.id, debounce(function(e) {
                      var target = $(e.target);
                      if (target.closest(self.popover.find('.picker__wrap')).length === 0 && target.closest(self.input).length === 0)
                              self.hide();
              }, 100));
              // Hide when ESC is pressed
              $doc.on('keyup.clockpicker.' + this.id, debounce( function(e){
                      if (e.keyCode === 27)
                              self.hide();
              },100));
              raiseCallback(this.options.afterShow);
      };
      // Hide popover
      ClockPicker.prototype.hide = function() {
              raiseCallback(this.options.beforeHide);
              this.input.removeClass('picker__input picker__input--active');
              this.popover.removeClass('picker--opened');
              $(document.body).css('overflow', 'visible');
              this.isShown = false;
              $(':input').each(function(index) {
                      $(this).attr('tabindex', index + 1);
              });
              // Unbinding events on document
              $doc.off('click.clockpicker.' + this.id + ' focusin.clockpicker.' + this.id);
              $doc.off('keyup.clockpicker.' + this.id);
              this.popover.hide();
              raiseCallback(this.options.afterHide);
      };
      // Toggle to hours or minutes view
      ClockPicker.prototype.toggleView = function(view, delay) {
              var raiseAfterHourSelect = false;
              if (view === 'minutes' && $(this.hoursView).css("visibility") === "visible") {
                      raiseCallback(this.options.beforeHourSelect);
                      raiseAfterHourSelect = true;
              }
              var isHours = view === 'hours',
                              nextView = isHours ? this.hoursView : this.minutesView,
                              hideView = isHours ? this.minutesView : this.hoursView;
              this.currentView = view;

              this.spanHours.toggleClass('text-primary', isHours);
              this.spanMinutes.toggleClass('text-primary', ! isHours);

              // Let's make transitions
              hideView.addClass('clockpicker-dial-out');
              nextView.css('visibility', 'visible').removeClass('clockpicker-dial-out');

              // Reset clock hand
              this.resetClock(delay);

              // After transitions ended
              clearTimeout(this.toggleViewTimer);
              this.toggleViewTimer = setTimeout(function() {
                      hideView.css('visibility', 'hidden');
              }, duration);

              if (raiseAfterHourSelect)
                      raiseCallback(this.options.afterHourSelect);
      };

      // Reset clock hand
      ClockPicker.prototype.resetClock = function(delay) {
              var view = this.currentView,
                              value = this[view],
                              isHours = view === 'hours',
                              unit = Math.PI / (isHours ? 6 : 30),
                              radian = value * unit,
                              radius = isHours && value > 0 && value < 13 ? innerRadius : outerRadius,
                              x = Math.sin(radian) * radius,
                              y = - Math.cos(radian) * radius,
                              self = this;

              if(svgSupported && delay) {
                      self.canvas.addClass('clockpicker-canvas-out');
                      setTimeout(function(){
                              self.canvas.removeClass('clockpicker-canvas-out');
                              self.setHand(x, y);
                      }, delay);
              } else
                      this.setHand(x, y);
      };

      // Set clock hand to (x, y)
      ClockPicker.prototype.setHand = function(x, y, roundBy5, dragging) {
              var radian = Math.atan2(x, - y),
                              isHours = this.currentView === 'hours',
                              z = Math.sqrt(x * x + y * y),
                              options = this.options,
                              inner = isHours && z < (outerRadius + innerRadius) / 2,
                              radius = inner ? innerRadius : outerRadius,
                              unit,
      value;

      // Calculate the unit
      if (isHours) {
          unit = options.hourstep / 6 * Math.PI
      } else {
          unit = options.minutestep / 30 * Math.PI
      }

              if (options.twelvehour)
                      radius = outerRadius;

              // Radian should in range [0, 2PI]
              if (radian < 0)
                      radian = Math.PI * 2 + radian;

              // Get the round value
              value = Math.round(radian / unit);

              // Get the round radian
              radian = value * unit;

              // Correct the hours or minutes
  if (isHours) {
    value *= options.hourstep;
    if (! options.twelvehour && (!inner)==(value>0)) {
        value += 12;
    }
    if (options.twelvehour && value === 0) {
        value = 12;
    }
    if (value === 24) {
        value = 0;
    }
  } else {
    value *= options.minutestep;
    if (value === 60) {
        value = 0;
    }
  }
              if (isHours)
                      this.fg.setAttribute('class', 'clockpicker-canvas-fg');
              else {
                      if(value % 5 == 0)
                              this.fg.setAttribute('class', 'clockpicker-canvas-fg');
                      else
                              this.fg.setAttribute('class', 'clockpicker-canvas-fg active');
              }

              // Once hours or minutes changed, vibrate the device
              if (this[this.currentView] !== value)
                      if (vibrate && this.options.vibrate)
                              // Do not vibrate too frequently
                              if (! this.vibrateTimer) {
                                      navigator[vibrate](10);
                                      this.vibrateTimer = setTimeout($.proxy(function(){
                                              this.vibrateTimer = null;
                                      }, this), 100);
                              }

              this[this.currentView] = value;
              this[isHours ? 'spanHours' : 'spanMinutes'].html(leadingZero(value));

              // If svg is not supported, just add an active class to the tick
              if (! svgSupported) {
                      this[isHours ? 'hoursView' : 'minutesView'].find('.clockpicker-tick').each(function(){
                              var tick = $(this);
                              tick.toggleClass('active', value === + tick.html());
                      });
                      return;
              }

              // Place clock hand at the top when dragging
              if (dragging || (! isHours && value % 5)) {
                      this.g.insertBefore(this.hand, this.bearing);
                      this.g.insertBefore(this.bg, this.fg);
                      this.bg.setAttribute('class', 'clockpicker-canvas-bg clockpicker-canvas-bg-trans');
              } else {
                      // Or place it at the bottom
                      this.g.insertBefore(this.hand, this.bg);
                      this.g.insertBefore(this.fg, this.bg);
                      this.bg.setAttribute('class', 'clockpicker-canvas-bg');
              }

              // Set clock hand and others' position
  var cx = Math.sin(radian) * radius,
    cy = - Math.cos(radian) * radius;
  this.hand.setAttribute('x2', cx);
  this.hand.setAttribute('y2', cy);
  this.bg.setAttribute('cx', cx);
  this.bg.setAttribute('cy', cy);
  this.fg.setAttribute('cx', cx);
  this.fg.setAttribute('cy', cy);
};

      // Clear clock text
ClockPicker.prototype.clearInput = function() {
              this.input.val('');
              this.hide();

              if(this.options.afterDone && typeof this.options.afterDone === 'function')
                      this.options.afterDone(this.input, null);
      };

  // Allow user to get time as Date object
  ClockPicker.prototype.getTime = function(callback) {
    this.parseInputValue();

    var hours = this.hours;
    if (this.options.twelvehour && hours < 12 && this.amOrPm === 'PM') {
        hours += 12;
    }

    var selectedTime = new Date();
    selectedTime.setMinutes(this.minutes)
    selectedTime.setHours(hours);
    selectedTime.setSeconds(0);

    return callback && callback.apply(this.element, selectedTime) || selectedTime;
}

      // Hours and minutes are selected
      ClockPicker.prototype.done = function() {
              raiseCallback(this.options.beforeDone);
              this.hide();
              this.label.addClass('active');

              var last = this.input.prop('value'),
    outHours = this.hours,
    value = ':' + leadingZero(this.minutes);

  if (this.isHTML5 && this.options.twelvehour) {
      if (this.hours < 12 && this.amOrPm === 'PM') {
          outHours += 12;
      }
      if (this.hours === 12 && this.amOrPm === 'AM') {
          outHours = 0;
      }
  }

  value = leadingZero(outHours) + value;

  if (!this.isHTML5 && this.options.twelvehour) {
        value = value + this.amOrPm;
  }

              this.input.prop('value', value);
              if(value !== last) {
                      this.input.trigger('change');
                      if(!this.isInput)
                              this.element.trigger('change');
              }

              if(this.options.autoclose)
                      this.input.trigger('blur');

              raiseCallback(this.options.afterDone);
      };

      // Remove clockpicker from input
      ClockPicker.prototype.remove = function() {
              this.element.removeData('clockpicker');
              this.input.off('focus.clockpicker click.clockpicker');
              if (this.isShown)
                      this.hide();
              if (this.isAppended) {
                      $win.off('resize.clockpicker' + this.id);
                      this.popover.remove();
              }
      };

      // Extends $.fn.clockpicker
      $.fn.pickatime = function(option){
              var args = Array.prototype.slice.call(arguments, 1);
              function handleClockPickerRequest(){
                      var $this = $(this),
                                      data = $this.data('clockpicker');
                      if (!data) {
                              var options = $.extend({}, ClockPicker.DEFAULTS, $this.data(), typeof option == 'object' && option);
                              $this.data('clockpicker', new ClockPicker($this, options));
                      } else {
                              // Manual operations. show, hide, remove, e.g.
                              if (typeof data[option] === 'function')
                                      data[option].apply(data, args);
                      }
  }
  // If we explicitly do a call on a single element then we can return the value (if needed)
  // This allows us, for example, to return the value of getTime
  if (this.length == 1) {
    var returnValue = handleClockPickerRequest.apply(this[0]);

    // If we do not have any return value then return the object itself so you can chain
    return returnValue !== undefined ? returnValue : this;
  }

  // If we do have a list then we do not care about return values
  return this.each(handleClockPickerRequest);
  };

}());

/*! PhotoSwipe - v4.1.1 - 2015-12-24

* http://photoswipe.com
* Copyright (c) 2015 Dmitry Semenov; */

! function (a, b) {

"function" == typeof define && define.amd ? define(b) : "object" == typeof exports ? module.exports = b() : a.PhotoSwipe = b()

}(this, function () {

"use strict";
var a = function (a, b, c, d) {
    var e = {
        features: null,
        bind: function (a, b, c, d) {
            var e = (d ? "remove" : "add") + "EventListener";
            b = b.split(" ");
            for (var f = 0; f < b.length; f++) b[f] && a[e](b[f], c, !1)
        },
        isArray: function (a) {
            return a instanceof Array
        },
        createEl: function (a, b) {
            var c = document.createElement(b || "div");
            return a && (c.className = a), c
        },
        getScrollY: function () {
            var a = window.pageYOffset;
            return void 0 !== a ? a : document.documentElement.scrollTop
        },
        unbind: function (a, b, c) {
            e.bind(a, b, c, !0)
        },
        removeClass: function (a, b) {
            var c = new RegExp("(\\s|^)" + b + "(\\s|$)");
            a.className = a.className.replace(c, " ").replace(/^\s\s*/, "").replace(/\s\s*$/, "")
        },
        addClass: function (a, b) {
            e.hasClass(a, b) || (a.className += (a.className ? " " : "") + b)
        },
        hasClass: function (a, b) {
            return a.className && new RegExp("(^|\\s)" + b + "(\\s|$)").test(a.className)
        },
        getChildByClass: function (a, b) {
            for (var c = a.firstChild; c;) {
                if (e.hasClass(c, b)) return c;
                c = c.nextSibling
            }
        },
        arraySearch: function (a, b, c) {
            for (var d = a.length; d--;)
                if (a[d][c] === b) return d;
            return -1
        },
        extend: function (a, b, c) {
            for (var d in b)
                if (b.hasOwnProperty(d)) {
                    if (c && a.hasOwnProperty(d)) continue;
                    a[d] = b[d]
                }
        },
        easing: {
            sine: {
                out: function (a) {
                    return Math.sin(a * (Math.PI / 2))
                },
                inOut: function (a) {
                    return -(Math.cos(Math.PI * a) - 1) / 2
                }
            },
            cubic: {
                out: function (a) {
                    return --a * a * a + 1
                }
            }
        },
        detectFeatures: function () {
            if (e.features) return e.features;
            var a = e.createEl(),
                b = a.style,
                c = "",
                d = {};
            if (d.oldIE = document.all && !document.addEventListener, d.touch = "ontouchstart" in window, window.requestAnimationFrame && (d.raf = window.requestAnimationFrame, d.caf = window.cancelAnimationFrame), d.pointerEvent = navigator.pointerEnabled || navigator.msPointerEnabled, !d.pointerEvent) {
                var f = navigator.userAgent;
                if (/iP(hone|od)/.test(navigator.platform)) {
                    var g = navigator.appVersion.match(/OS (\d+)_(\d+)_?(\d+)?/);
                    g && g.length > 0 && (g = parseInt(g[1], 10), g >= 1 && 8 > g && (d.isOldIOSPhone = !0))
                }
                var h = f.match(/Android\s([0-9\.]*)/),
                    i = h ? h[1] : 0;
                i = parseFloat(i), i >= 1 && (4.4 > i && (d.isOldAndroid = !0), d.androidVersion = i), d.isMobileOpera = /opera mini|opera mobi/i.test(f)
            }
            for (var j, k, l = ["transform", "perspective", "animationName"], m = ["", "webkit", "Moz", "ms", "O"], n = 0; 4 > n; n++) {
                c = m[n];
                for (var o = 0; 3 > o; o++) j = l[o], k = c + (c ? j.charAt(0).toUpperCase() + j.slice(1) : j), !d[j] && k in b && (d[j] = k);
                c && !d.raf && (c = c.toLowerCase(), d.raf = window[c + "RequestAnimationFrame"], d.raf && (d.caf = window[c + "CancelAnimationFrame"] || window[c + "CancelRequestAnimationFrame"]))
            }
            if (!d.raf) {
                var p = 0;
                d.raf = function (a) {
                    var b = (new Date).getTime(),
                        c = Math.max(0, 16 - (b - p)),
                        d = window.setTimeout(function () {
                            a(b + c)
                        }, c);
                    return p = b + c, d
                }, d.caf = function (a) {
                    clearTimeout(a)
                }
            }
            return d.svg = !!document.createElementNS && !!document.createElementNS("http://www.w3.org/2000/svg", "svg").createSVGRect, e.features = d, d
        }
    };
    e.detectFeatures(), e.features.oldIE && (e.bind = function (a, b, c, d) {
        b = b.split(" ");
        for (var e, f = (d ? "detach" : "attach") + "Event", g = function () {
                c.handleEvent.call(c)
            }, h = 0; h < b.length; h++)
            if (e = b[h])
                if ("object" == typeof c && c.handleEvent) {
                    if (d) {
                        if (!c["oldIE" + e]) return !1
                    } else c["oldIE" + e] = g;
                    a[f]("on" + e, c["oldIE" + e])
                } else a[f]("on" + e, c)
    });
    var f = this,
        g = 25,
        h = 3,
        i = {
            allowPanToNext: !0,
            spacing: .12,
            bgOpacity: 1,
            mouseUsed: !1,
            loop: !0,
            pinchToClose: !0,
            closeOnScroll: !0,
            closeOnVerticalDrag: !0,
            verticalDragRange: .75,
            hideAnimationDuration: 333,
            showAnimationDuration: 333,
            showHideOpacity: !1,
            focus: !0,
            escKey: !0,
            arrowKeys: !0,
            mainScrollEndFriction: .35,
            panEndFriction: .35,
            isClickableElement: function (a) {
                return "A" === a.tagName
            },
            getDoubleTapZoom: function (a, b) {
                return a ? 1 : b.initialZoomLevel < .7 ? 1 : 1.33
            },
            maxSpreadZoom: 1.33,
            modal: !0,
            scaleMode: "fit"
        };
    e.extend(i, d);
    var j, k, l, m, n, o, p, q, r, s, t, u, v, w, x, y, z, A, B, C, D, E, F, G, H, I, J, K, L, M, N, O, P, Q, R, S, T, U, V, W, X, Y, Z, $, _, aa, ba, ca, da, ea, fa, ga, ha, ia, ja, ka, la = function () {
            return {
                x: 0,
                y: 0
            }
        },
        ma = la(),
        na = la(),
        oa = la(),
        pa = {},
        qa = 0,
        ra = {},
        sa = la(),
        ta = 0,
        ua = !0,
        va = [],
        wa = {},
        xa = !1,
        ya = function (a, b) {
            e.extend(f, b.publicMethods), va.push(a)
        },
        za = function (a) {
            var b = _b();
            return a > b - 1 ? a - b : 0 > a ? b + a : a
        },
        Aa = {},
        Ba = function (a, b) {
            return Aa[a] || (Aa[a] = []), Aa[a].push(b)
        },
        Ca = function (a) {
            var b = Aa[a];
            if (b) {
                var c = Array.prototype.slice.call(arguments);
                c.shift();
                for (var d = 0; d < b.length; d++) b[d].apply(f, c)
            }
        },
        Da = function () {
            return (new Date).getTime()
        },
        Ea = function (a) {
            ia = a, f.bg.style.opacity = a * i.bgOpacity
        },
        Fa = function (a, b, c, d, e) {
            (!xa || e && e !== f.currItem) && (d /= e ? e.fitRatio : f.currItem.fitRatio), a[E] = u + b + "px, " + c + "px" + v + " scale(" + d + ")"
        },
        Ga = function (a) {
            da && (a && (s > f.currItem.fitRatio ? xa || (lc(f.currItem, !1, !0), xa = !0) : xa && (lc(f.currItem), xa = !1)), Fa(da, oa.x, oa.y, s))
        },
        Ha = function (a) {
            a.container && Fa(a.container.style, a.initialPosition.x, a.initialPosition.y, a.initialZoomLevel, a)
        },
        Ia = function (a, b) {
            b[E] = u + a + "px, 0px" + v
        },
        Ja = function (a, b) {
            if (!i.loop && b) {
                var c = m + (sa.x * qa - a) / sa.x,
                    d = Math.round(a - sb.x);
                (0 > c && d > 0 || c >= _b() - 1 && 0 > d) && (a = sb.x + d * i.mainScrollEndFriction)
            }
            sb.x = a, Ia(a, n)
        },
        Ka = function (a, b) {
            var c = tb[a] - ra[a];
            return na[a] + ma[a] + c - c * (b / t)
        },
        La = function (a, b) {
            a.x = b.x, a.y = b.y, b.id && (a.id = b.id)
        },
        Ma = function (a) {
            a.x = Math.round(a.x), a.y = Math.round(a.y)
        },
        Na = null,
        Oa = function () {
            Na && (e.unbind(document, "mousemove", Oa), e.addClass(a, "pswp--has_mouse"), i.mouseUsed = !0, Ca("mouseUsed")), Na = setTimeout(function () {
                Na = null
            }, 100)
        },
        Pa = function () {
            e.bind(document, "keydown", f), N.transform && e.bind(f.scrollWrap, "click", f), i.mouseUsed || e.bind(document, "mousemove", Oa), e.bind(window, "resize scroll", f), Ca("bindEvents")
        },
        Qa = function () {
            e.unbind(window, "resize", f), e.unbind(window, "scroll", r.scroll), e.unbind(document, "keydown", f), e.unbind(document, "mousemove", Oa), N.transform && e.unbind(f.scrollWrap, "click", f), U && e.unbind(window, p, f), Ca("unbindEvents")
        },
        Ra = function (a, b) {
            var c = hc(f.currItem, pa, a);
            return b && (ca = c), c
        },
        Sa = function (a) {
            return a || (a = f.currItem), a.initialZoomLevel
        },
        Ta = function (a) {
            return a || (a = f.currItem), a.w > 0 ? i.maxSpreadZoom : 1
        },
        Ua = function (a, b, c, d) {
            return d === f.currItem.initialZoomLevel ? (c[a] = f.currItem.initialPosition[a], !0) : (c[a] = Ka(a, d), c[a] > b.min[a] ? (c[a] = b.min[a], !0) : c[a] < b.max[a] ? (c[a] = b.max[a], !0) : !1)
        },
        Va = function () {
            if (E) {
                var b = N.perspective && !G;
                return u = "translate" + (b ? "3d(" : "("), void(v = N.perspective ? ", 0px)" : ")")
            }
            E = "left", e.addClass(a, "pswp--ie"), Ia = function (a, b) {
                b.left = a + "px"
            }, Ha = function (a) {
                var b = a.fitRatio > 1 ? 1 : a.fitRatio,
                    c = a.container.style,
                    d = b * a.w,
                    e = b * a.h;
                c.width = d + "px", c.height = e + "px", c.left = a.initialPosition.x + "px", c.top = a.initialPosition.y + "px"
            }, Ga = function () {
                if (da) {
                    var a = da,
                        b = f.currItem,
                        c = b.fitRatio > 1 ? 1 : b.fitRatio,
                        d = c * b.w,
                        e = c * b.h;
                    a.width = d + "px", a.height = e + "px", a.left = oa.x + "px", a.top = oa.y + "px"
                }
            }
        },
        Wa = function (a) {
            var b = "";
            i.escKey && 27 === a.keyCode ? b = "close" : i.arrowKeys && (37 === a.keyCode ? b = "prev" : 39 === a.keyCode && (b = "next")), b && (a.ctrlKey || a.altKey || a.shiftKey || a.metaKey || (a.preventDefault ? a.preventDefault() : a.returnValue = !1, f[b]()))
        },
        Xa = function (a) {
            a && (X || W || ea || S) && (a.preventDefault(), a.stopPropagation())
        },
        Ya = function () {
            f.setScrollOffset(0, e.getScrollY())
        },
        Za = {},
        $a = 0,
        _a = function (a) {
            Za[a] && (Za[a].raf && I(Za[a].raf), $a--, delete Za[a])
        },
        ab = function (a) {
            Za[a] && _a(a), Za[a] || ($a++, Za[a] = {})
        },
        bb = function () {
            for (var a in Za) Za.hasOwnProperty(a) && _a(a)
        },
        cb = function (a, b, c, d, e, f, g) {
            var h, i = Da();
            ab(a);
            var j = function () {
                if (Za[a]) {
                    if (h = Da() - i, h >= d) return _a(a), f(c), void(g && g());
                    f((c - b) * e(h / d) + b), Za[a].raf = H(j)
                }
            };
            j()
        },
        db = {
            shout: Ca,
            listen: Ba,
            viewportSize: pa,
            options: i,
            isMainScrollAnimating: function () {
                return ea
            },
            getZoomLevel: function () {
                return s
            },
            getCurrentIndex: function () {
                return m
            },
            isDragging: function () {
                return U
            },
            isZooming: function () {
                return _
            },
            setScrollOffset: function (a, b) {
                ra.x = a, M = ra.y = b, Ca("updateScrollOffset", ra)
            },
            applyZoomPan: function (a, b, c, d) {
                oa.x = b, oa.y = c, s = a, Ga(d)
            },
            init: function () {
                if (!j && !k) {
                    var c;
                    f.framework = e, f.template = a, f.bg = e.getChildByClass(a, "pswp__bg"), J = a.className, j = !0, N = e.detectFeatures(), H = N.raf, I = N.caf, E = N.transform, L = N.oldIE, f.scrollWrap = e.getChildByClass(a, "pswp__scroll-wrap"), f.container = e.getChildByClass(f.scrollWrap, "pswp__container"), n = f.container.style, f.itemHolders = y = [{
                        el: f.container.children[0],
                        wrap: 0,
                        index: -1
                    }, {
                        el: f.container.children[1],
                        wrap: 0,
                        index: -1
                    }, {
                        el: f.container.children[2],
                        wrap: 0,
                        index: -1
                    }], y[0].el.style.display = y[2].el.style.display = "none", Va(), r = {
                        resize: f.updateSize,
                        scroll: Ya,
                        keydown: Wa,
                        click: Xa
                    };
                    var d = N.isOldIOSPhone || N.isOldAndroid || N.isMobileOpera;
                    for (N.animationName && N.transform && !d || (i.showAnimationDuration = i.hideAnimationDuration = 0), c = 0; c < va.length; c++) f["init" + va[c]]();
                    if (b) {
                        var g = f.ui = new b(f, e);
                        g.init()
                    }
                    Ca("firstUpdate"), m = m || i.index || 0, (isNaN(m) || 0 > m || m >= _b()) && (m = 0), f.currItem = $b(m), (N.isOldIOSPhone || N.isOldAndroid) && (ua = !1), a.setAttribute("aria-hidden", "false"), i.modal && (ua ? a.style.position = "fixed" : (a.style.position = "absolute", a.style.top = e.getScrollY() + "px")), void 0 === M && (Ca("initialLayout"), M = K = e.getScrollY());
                    var l = "pswp--open ";
                    for (i.mainClass && (l += i.mainClass + " "), i.showHideOpacity && (l += "pswp--animate_opacity "), l += G ? "pswp--touch" : "pswp--notouch", l += N.animationName ? " pswp--css_animation" : "", l += N.svg ? " pswp--svg" : "", e.addClass(a, l), f.updateSize(), o = -1, ta = null, c = 0; h > c; c++) Ia((c + o) * sa.x, y[c].el.style);
                    L || e.bind(f.scrollWrap, q, f), Ba("initialZoomInEnd", function () {
                        f.setContent(y[0], m - 1), f.setContent(y[2], m + 1), y[0].el.style.display = y[2].el.style.display = "block", i.focus && a.focus(), Pa()
                    }), f.setContent(y[1], m), f.updateCurrItem(), Ca("afterInit"), ua || (w = setInterval(function () {
                        $a || U || _ || s !== f.currItem.initialZoomLevel || f.updateSize()
                    }, 1e3)), e.addClass(a, "pswp--visible")
                }
            },
            close: function () {
                j && (j = !1, k = !0, Ca("close"), Qa(), bc(f.currItem, null, !0, f.destroy))
            },
            destroy: function () {
                Ca("destroy"), Wb && clearTimeout(Wb), a.setAttribute("aria-hidden", "true"), a.className = J, w && clearInterval(w), e.unbind(f.scrollWrap, q, f), e.unbind(window, "scroll", f), yb(), bb(), Aa = null
            },
            panTo: function (a, b, c) {
                c || (a > ca.min.x ? a = ca.min.x : a < ca.max.x && (a = ca.max.x), b > ca.min.y ? b = ca.min.y : b < ca.max.y && (b = ca.max.y)), oa.x = a, oa.y = b, Ga()
            },
            handleEvent: function (a) {
                a = a || window.event, r[a.type] && r[a.type](a)
            },
            goTo: function (a) {
                a = za(a);
                var b = a - m;
                ta = b, m = a, f.currItem = $b(m), qa -= b, Ja(sa.x * qa), bb(), ea = !1, f.updateCurrItem()
            },
            next: function () {
                f.goTo(m + 1)
            },
            prev: function () {
                f.goTo(m - 1)
            },
            updateCurrZoomItem: function (a) {
                if (a && Ca("beforeChange", 0), y[1].el.children.length) {
                    var b = y[1].el.children[0];
                    da = e.hasClass(b, "pswp__zoom-wrap") ? b.style : null
                } else da = null;
                ca = f.currItem.bounds, t = s = f.currItem.initialZoomLevel, oa.x = ca.center.x, oa.y = ca.center.y, a && Ca("afterChange")
            },
            invalidateCurrItems: function () {
                x = !0;
                for (var a = 0; h > a; a++) y[a].item && (y[a].item.needsUpdate = !0)
            },
            updateCurrItem: function (a) {
                if (0 !== ta) {
                    var b, c = Math.abs(ta);
                    if (!(a && 2 > c)) {
                        f.currItem = $b(m), xa = !1, Ca("beforeChange", ta), c >= h && (o += ta + (ta > 0 ? -h : h), c = h);
                        for (var d = 0; c > d; d++) ta > 0 ? (b = y.shift(), y[h - 1] = b, o++, Ia((o + 2) * sa.x, b.el.style), f.setContent(b, m - c + d + 1 + 1)) : (b = y.pop(), y.unshift(b), o--, Ia(o * sa.x, b.el.style), f.setContent(b, m + c - d - 1 - 1));
                        if (da && 1 === Math.abs(ta)) {
                            var e = $b(z);
                            e.initialZoomLevel !== s && (hc(e, pa), lc(e), Ha(e))
                        }
                        ta = 0, f.updateCurrZoomItem(), z = m, Ca("afterChange")
                    }
                }
            },
            updateSize: function (b) {
                if (!ua && i.modal) {
                    var c = e.getScrollY();
                    if (M !== c && (a.style.top = c + "px", M = c), !b && wa.x === window.innerWidth && wa.y === window.innerHeight) return;
                    wa.x = window.innerWidth, wa.y = window.innerHeight, a.style.height = wa.y + "px"
                }
                if (pa.x = f.scrollWrap.clientWidth, pa.y = f.scrollWrap.clientHeight, Ya(), sa.x = pa.x + Math.round(pa.x * i.spacing), sa.y = pa.y, Ja(sa.x * qa), Ca("beforeResize"), void 0 !== o) {
                    for (var d, g, j, k = 0; h > k; k++) d = y[k], Ia((k + o) * sa.x, d.el.style), j = m + k - 1, i.loop && _b() > 2 && (j = za(j)), g = $b(j), g && (x || g.needsUpdate || !g.bounds) ? (f.cleanSlide(g), f.setContent(d, j), 1 === k && (f.currItem = g, f.updateCurrZoomItem(!0)), g.needsUpdate = !1) : -1 === d.index && j >= 0 && f.setContent(d, j), g && g.container && (hc(g, pa), lc(g), Ha(g));
                    x = !1
                }
                t = s = f.currItem.initialZoomLevel, ca = f.currItem.bounds, ca && (oa.x = ca.center.x, oa.y = ca.center.y, Ga(!0)), Ca("resize")
            },
            zoomTo: function (a, b, c, d, f) {
                b && (t = s, tb.x = Math.abs(b.x) - oa.x, tb.y = Math.abs(b.y) - oa.y, La(na, oa));
                var g = Ra(a, !1),
                    h = {};
                Ua("x", g, h, a), Ua("y", g, h, a);
                var i = s,
                    j = {
                        x: oa.x,
                        y: oa.y
                    };
                Ma(h);
                var k = function (b) {
                    1 === b ? (s = a, oa.x = h.x, oa.y = h.y) : (s = (a - i) * b + i, oa.x = (h.x - j.x) * b + j.x, oa.y = (h.y - j.y) * b + j.y), f && f(b), Ga(1 === b)
                };
                c ? cb("customZoomTo", 0, 1, c, d || e.easing.sine.inOut, k) : k(1)
            }
        },
        eb = 30,
        fb = 10,
        gb = {},
        hb = {},
        ib = {},
        jb = {},
        kb = {},
        lb = [],
        mb = {},
        nb = [],
        ob = {},
        pb = 0,
        qb = la(),
        rb = 0,
        sb = la(),
        tb = la(),
        ub = la(),
        vb = function (a, b) {
            return a.x === b.x && a.y === b.y
        },
        wb = function (a, b) {
            return Math.abs(a.x - b.x) < g && Math.abs(a.y - b.y) < g
        },
        xb = function (a, b) {
            return ob.x = Math.abs(a.x - b.x), ob.y = Math.abs(a.y - b.y), Math.sqrt(ob.x * ob.x + ob.y * ob.y)
        },
        yb = function () {
            Y && (I(Y), Y = null)
        },
        zb = function () {
            U && (Y = H(zb), Pb())
        },
        Ab = function () {
            return !("fit" === i.scaleMode && s === f.currItem.initialZoomLevel)
        },
        Bb = function (a, b) {
            return a && a !== document ? a.getAttribute("class") && a.getAttribute("class").indexOf("pswp__scroll-wrap") > -1 ? !1 : b(a) ? a : Bb(a.parentNode, b) : !1
        },
        Cb = {},
        Db = function (a, b) {
            return Cb.prevent = !Bb(a.target, i.isClickableElement), Ca("preventDragEvent", a, b, Cb), Cb.prevent
        },
        Eb = function (a, b) {
            return b.x = a.pageX, b.y = a.pageY, b.id = a.identifier, b
        },
        Fb = function (a, b, c) {
            c.x = .5 * (a.x + b.x), c.y = .5 * (a.y + b.y)
        },
        Gb = function (a, b, c) {
            if (a - P > 50) {
                var d = nb.length > 2 ? nb.shift() : {};
                d.x = b, d.y = c, nb.push(d), P = a
            }
        },
        Hb = function () {
            var a = oa.y - f.currItem.initialPosition.y;
            return 1 - Math.abs(a / (pa.y / 2))
        },
        Ib = {},
        Jb = {},
        Kb = [],
        Lb = function (a) {
            for (; Kb.length > 0;) Kb.pop();
            return F ? (ka = 0, lb.forEach(function (a) {
                0 === ka ? Kb[0] = a : 1 === ka && (Kb[1] = a), ka++
            })) : a.type.indexOf("touch") > -1 ? a.touches && a.touches.length > 0 && (Kb[0] = Eb(a.touches[0], Ib), a.touches.length > 1 && (Kb[1] = Eb(a.touches[1], Jb))) : (Ib.x = a.pageX, Ib.y = a.pageY, Ib.id = "", Kb[0] = Ib), Kb
        },
        Mb = function (a, b) {
            var c, d, e, g, h = 0,
                j = oa[a] + b[a],
                k = b[a] > 0,
                l = sb.x + b.x,
                m = sb.x - mb.x;
            return c = j > ca.min[a] || j < ca.max[a] ? i.panEndFriction : 1, j = oa[a] + b[a] * c, !i.allowPanToNext && s !== f.currItem.initialZoomLevel || (da ? "h" !== fa || "x" !== a || W || (k ? (j > ca.min[a] && (c = i.panEndFriction, h = ca.min[a] - j, d = ca.min[a] - na[a]), (0 >= d || 0 > m) && _b() > 1 ? (g = l, 0 > m && l > mb.x && (g = mb.x)) : ca.min.x !== ca.max.x && (e = j)) : (j < ca.max[a] && (c = i.panEndFriction, h = j - ca.max[a], d = na[a] - ca.max[a]), (0 >= d || m > 0) && _b() > 1 ? (g = l, m > 0 && l < mb.x && (g = mb.x)) : ca.min.x !== ca.max.x && (e = j))) : g = l, "x" !== a) ? void(ea || Z || s > f.currItem.fitRatio && (oa[a] += b[a] * c)) : (void 0 !== g && (Ja(g, !0), Z = g === mb.x ? !1 : !0), ca.min.x !== ca.max.x && (void 0 !== e ? oa.x = e : Z || (oa.x += b.x * c)), void 0 !== g)
        },
        Nb = function (a) {
            if (!("mousedown" === a.type && a.button > 0)) {
                if (Zb) return void a.preventDefault();
                if (!T || "mousedown" !== a.type) {
                    if (Db(a, !0) && a.preventDefault(), Ca("pointerDown"), F) {
                        var b = e.arraySearch(lb, a.pointerId, "id");
                        0 > b && (b = lb.length), lb[b] = {
                            x: a.pageX,
                            y: a.pageY,
                            id: a.pointerId
                        }
                    }
                    var c = Lb(a),
                        d = c.length;
                    $ = null, bb(), U && 1 !== d || (U = ga = !0, e.bind(window, p, f), R = ja = ha = S = Z = X = V = W = !1, fa = null, Ca("firstTouchStart", c), La(na, oa), ma.x = ma.y = 0, La(jb, c[0]), La(kb, jb), mb.x = sa.x * qa, nb = [{
                        x: jb.x,
                        y: jb.y
                    }], P = O = Da(), Ra(s, !0), yb(), zb()), !_ && d > 1 && !ea && !Z && (t = s, W = !1, _ = V = !0, ma.y = ma.x = 0, La(na, oa), La(gb, c[0]), La(hb, c[1]), Fb(gb, hb, ub), tb.x = Math.abs(ub.x) - oa.x, tb.y = Math.abs(ub.y) - oa.y, aa = ba = xb(gb, hb))
                }
            }
        },
        Ob = function (a) {
            if (a.preventDefault(), F) {
                var b = e.arraySearch(lb, a.pointerId, "id");
                if (b > -1) {
                    var c = lb[b];
                    c.x = a.pageX, c.y = a.pageY
                }
            }
            if (U) {
                var d = Lb(a);
                if (fa || X || _) $ = d;
                else if (sb.x !== sa.x * qa) fa = "h";
                else {
                    var f = Math.abs(d[0].x - jb.x) - Math.abs(d[0].y - jb.y);
                    Math.abs(f) >= fb && (fa = f > 0 ? "h" : "v", $ = d)
                }
            }
        },
        Pb = function () {
            if ($) {
                var a = $.length;
                if (0 !== a)
                    if (La(gb, $[0]), ib.x = gb.x - jb.x, ib.y = gb.y - jb.y, _ && a > 1) {
                        if (jb.x = gb.x, jb.y = gb.y, !ib.x && !ib.y && vb($[1], hb)) return;
                        La(hb, $[1]), W || (W = !0, Ca("zoomGestureStarted"));
                        var b = xb(gb, hb),
                            c = Ub(b);
                        c > f.currItem.initialZoomLevel + f.currItem.initialZoomLevel / 15 && (ja = !0);
                        var d = 1,
                            e = Sa(),
                            g = Ta();
                        if (e > c)
                            if (i.pinchToClose && !ja && t <= f.currItem.initialZoomLevel) {
                                var h = e - c,
                                    j = 1 - h / (e / 1.2);
                                Ea(j), Ca("onPinchClose", j), ha = !0
                            } else d = (e - c) / e, d > 1 && (d = 1), c = e - d * (e / 3);
                        else c > g && (d = (c - g) / (6 * e), d > 1 && (d = 1), c = g + d * e);
                        0 > d && (d = 0), aa = b, Fb(gb, hb, qb), ma.x += qb.x - ub.x, ma.y += qb.y - ub.y, La(ub, qb), oa.x = Ka("x", c), oa.y = Ka("y", c), R = c > s, s = c, Ga()
                    } else {
                        if (!fa) return;
                        if (ga && (ga = !1, Math.abs(ib.x) >= fb && (ib.x -= $[0].x - kb.x), Math.abs(ib.y) >= fb && (ib.y -= $[0].y - kb.y)), jb.x = gb.x, jb.y = gb.y, 0 === ib.x && 0 === ib.y) return;
                        if ("v" === fa && i.closeOnVerticalDrag && !Ab()) {
                            ma.y += ib.y, oa.y += ib.y;
                            var k = Hb();
                            return S = !0, Ca("onVerticalDrag", k), Ea(k), void Ga()
                        }
                        Gb(Da(), gb.x, gb.y), X = !0, ca = f.currItem.bounds;
                        var l = Mb("x", ib);
                        l || (Mb("y", ib), Ma(oa), Ga())
                    }
            }
        },
        Qb = function (a) {
            if (N.isOldAndroid) {
                if (T && "mouseup" === a.type) return;
                a.type.indexOf("touch") > -1 && (clearTimeout(T), T = setTimeout(function () {
                    T = 0
                }, 600))
            }
            Ca("pointerUp"), Db(a, !1) && a.preventDefault();
            var b;
            if (F) {
                var c = e.arraySearch(lb, a.pointerId, "id");
                if (c > -1)
                    if (b = lb.splice(c, 1)[0], navigator.pointerEnabled) b.type = a.pointerType || "mouse";
                    else {
                        var d = {
                            4: "mouse",
                            2: "touch",
                            3: "pen"
                        };
                        b.type = d[a.pointerType], b.type || (b.type = a.pointerType || "mouse")
                    }
            }
            var g, h = Lb(a),
                j = h.length;
            if ("mouseup" === a.type && (j = 0), 2 === j) return $ = null, !0;
            1 === j && La(kb, h[0]), 0 !== j || fa || ea || (b || ("mouseup" === a.type ? b = {
                x: a.pageX,
                y: a.pageY,
                type: "mouse"
            } : a.changedTouches && a.changedTouches[0] && (b = {
                x: a.changedTouches[0].pageX,
                y: a.changedTouches[0].pageY,
                type: "touch"
            })), Ca("touchRelease", a, b));
            var k = -1;
            if (0 === j && (U = !1, e.unbind(window, p, f), yb(), _ ? k = 0 : -1 !== rb && (k = Da() - rb)), rb = 1 === j ? Da() : -1, g = -1 !== k && 150 > k ? "zoom" : "swipe", _ && 2 > j && (_ = !1, 1 === j && (g = "zoomPointerUp"), Ca("zoomGestureEnded")), $ = null, X || W || ea || S)
                if (bb(), Q || (Q = Rb()), Q.calculateSwipeSpeed("x"), S) {
                    var l = Hb();
                    if (l < i.verticalDragRange) f.close();
                    else {
                        var m = oa.y,
                            n = ia;
                        cb("verticalDrag", 0, 1, 300, e.easing.cubic.out, function (a) {
                            oa.y = (f.currItem.initialPosition.y - m) * a + m, Ea((1 - n) * a + n), Ga()
                        }), Ca("onVerticalDrag", 1)
                    }
                } else {
                    if ((Z || ea) && 0 === j) {
                        var o = Tb(g, Q);
                        if (o) return;
                        g = "zoomPointerUp"
                    }
                    if (!ea) return "swipe" !== g ? void Vb() : void(!Z && s > f.currItem.fitRatio && Sb(Q))
                }
        },
        Rb = function () {
            var a, b, c = {
                lastFlickOffset: {},
                lastFlickDist: {},
                lastFlickSpeed: {},
                slowDownRatio: {},
                slowDownRatioReverse: {},
                speedDecelerationRatio: {},
                speedDecelerationRatioAbs: {},
                distanceOffset: {},
                backAnimDestination: {},
                backAnimStarted: {},
                calculateSwipeSpeed: function (d) {
                    nb.length > 1 ? (a = Da() - P + 50, b = nb[nb.length - 2][d]) : (a = Da() - O, b = kb[d]), c.lastFlickOffset[d] = jb[d] - b, c.lastFlickDist[d] = Math.abs(c.lastFlickOffset[d]), c.lastFlickDist[d] > 20 ? c.lastFlickSpeed[d] = c.lastFlickOffset[d] / a : c.lastFlickSpeed[d] = 0, Math.abs(c.lastFlickSpeed[d]) < .1 && (c.lastFlickSpeed[d] = 0), c.slowDownRatio[d] = .95, c.slowDownRatioReverse[d] = 1 - c.slowDownRatio[d], c.speedDecelerationRatio[d] = 1
                },
                calculateOverBoundsAnimOffset: function (a, b) {
                    c.backAnimStarted[a] || (oa[a] > ca.min[a] ? c.backAnimDestination[a] = ca.min[a] : oa[a] < ca.max[a] && (c.backAnimDestination[a] = ca.max[a]), void 0 !== c.backAnimDestination[a] && (c.slowDownRatio[a] = .7, c.slowDownRatioReverse[a] = 1 - c.slowDownRatio[a], c.speedDecelerationRatioAbs[a] < .05 && (c.lastFlickSpeed[a] = 0, c.backAnimStarted[a] = !0, cb("bounceZoomPan" + a, oa[a], c.backAnimDestination[a], b || 300, e.easing.sine.out, function (b) {
                        oa[a] = b, Ga()
                    }))))
                },
                calculateAnimOffset: function (a) {
                    c.backAnimStarted[a] || (c.speedDecelerationRatio[a] = c.speedDecelerationRatio[a] * (c.slowDownRatio[a] + c.slowDownRatioReverse[a] - c.slowDownRatioReverse[a] * c.timeDiff / 10), c.speedDecelerationRatioAbs[a] = Math.abs(c.lastFlickSpeed[a] * c.speedDecelerationRatio[a]), c.distanceOffset[a] = c.lastFlickSpeed[a] * c.speedDecelerationRatio[a] * c.timeDiff, oa[a] += c.distanceOffset[a])
                },
                panAnimLoop: function () {
                    return Za.zoomPan && (Za.zoomPan.raf = H(c.panAnimLoop), c.now = Da(), c.timeDiff = c.now - c.lastNow, c.lastNow = c.now, c.calculateAnimOffset("x"), c.calculateAnimOffset("y"), Ga(), c.calculateOverBoundsAnimOffset("x"), c.calculateOverBoundsAnimOffset("y"), c.speedDecelerationRatioAbs.x < .05 && c.speedDecelerationRatioAbs.y < .05) ? (oa.x = Math.round(oa.x), oa.y = Math.round(oa.y), Ga(), void _a("zoomPan")) : void 0
                }
            };
            return c
        },
        Sb = function (a) {
            return a.calculateSwipeSpeed("y"), ca = f.currItem.bounds, a.backAnimDestination = {}, a.backAnimStarted = {}, Math.abs(a.lastFlickSpeed.x) <= .05 && Math.abs(a.lastFlickSpeed.y) <= .05 ? (a.speedDecelerationRatioAbs.x = a.speedDecelerationRatioAbs.y = 0, a.calculateOverBoundsAnimOffset("x"), a.calculateOverBoundsAnimOffset("y"), !0) : (ab("zoomPan"), a.lastNow = Da(), void a.panAnimLoop())
        },
        Tb = function (a, b) {
            var c;
            ea || (pb = m);
            var d;
            if ("swipe" === a) {
                var g = jb.x - kb.x,
                    h = b.lastFlickDist.x < 10;
                g > eb && (h || b.lastFlickOffset.x > 20) ? d = -1 : -eb > g && (h || b.lastFlickOffset.x < -20) && (d = 1)
            }
            var j;
            d && (m += d, 0 > m ? (m = i.loop ? _b() - 1 : 0, j = !0) : m >= _b() && (m = i.loop ? 0 : _b() - 1, j = !0), (!j || i.loop) && (ta += d, qa -= d, c = !0));
            var k, l = sa.x * qa,
                n = Math.abs(l - sb.x);
            return c || l > sb.x == b.lastFlickSpeed.x > 0 ? (k = Math.abs(b.lastFlickSpeed.x) > 0 ? n / Math.abs(b.lastFlickSpeed.x) : 333, k = Math.min(k, 400), k = Math.max(k, 250)) : k = 333, pb === m && (c = !1), ea = !0, Ca("mainScrollAnimStart"), cb("mainScroll", sb.x, l, k, e.easing.cubic.out, Ja, function () {
                bb(), ea = !1, pb = -1, (c || pb !== m) && f.updateCurrItem(), Ca("mainScrollAnimComplete")
            }), c && f.updateCurrItem(!0), c
        },
        Ub = function (a) {
            return 1 / ba * a * t
        },
        Vb = function () {
            var a = s,
                b = Sa(),
                c = Ta();
            b > s ? a = b : s > c && (a = c);
            var d, g = 1,
                h = ia;
            return ha && !R && !ja && b > s ? (f.close(), !0) : (ha && (d = function (a) {
                Ea((g - h) * a + h)
            }), f.zoomTo(a, 0, 200, e.easing.cubic.out, d), !0)
        };
    ya("Gestures", {
        publicMethods: {
            initGestures: function () {
                var a = function (a, b, c, d, e) {
                    A = a + b, B = a + c, C = a + d, D = e ? a + e : ""
                };
                F = N.pointerEvent, F && N.touch && (N.touch = !1), F ? navigator.pointerEnabled ? a("pointer", "down", "move", "up", "cancel") : a("MSPointer", "Down", "Move", "Up", "Cancel") : N.touch ? (a("touch", "start", "move", "end", "cancel"), G = !0) : a("mouse", "down", "move", "up"), p = B + " " + C + " " + D, q = A, F && !G && (G = navigator.maxTouchPoints > 1 || navigator.msMaxTouchPoints > 1), f.likelyTouchDevice = G, r[A] = Nb, r[B] = Ob, r[C] = Qb, D && (r[D] = r[C]), N.touch && (q += " mousedown", p += " mousemove mouseup", r.mousedown = r[A], r.mousemove = r[B], r.mouseup = r[C]), G || (i.allowPanToNext = !1)
            }
        }
    });
    var Wb, Xb, Yb, Zb, $b, _b, ac, bc = function (b, c, d, g) {
            Wb && clearTimeout(Wb), Zb = !0, Yb = !0;
            var h;
            b.initialLayout ? (h = b.initialLayout, b.initialLayout = null) : h = i.getThumbBoundsFn && i.getThumbBoundsFn(m);
            var j = d ? i.hideAnimationDuration : i.showAnimationDuration,
                k = function () {
                    _a("initialZoom"), d ? (f.template.removeAttribute("style"), f.bg.removeAttribute("style")) : (Ea(1), c && (c.style.display = "block"), e.addClass(a, "pswp--animated-in"), Ca("initialZoom" + (d ? "OutEnd" : "InEnd"))), g && g(), Zb = !1
                };
            if (!j || !h || void 0 === h.x) return Ca("initialZoom" + (d ? "Out" : "In")), s = b.initialZoomLevel, La(oa, b.initialPosition), Ga(), a.style.opacity = d ? 0 : 1, Ea(1), void(j ? setTimeout(function () {
                k()
            }, j) : k());
            var n = function () {
                var c = l,
                    g = !f.currItem.src || f.currItem.loadError || i.showHideOpacity;
                b.miniImg && (b.miniImg.style.webkitBackfaceVisibility = "hidden"), d || (s = h.w / b.w, oa.x = h.x, oa.y = h.y - K, f[g ? "template" : "bg"].style.opacity = .001, Ga()), ab("initialZoom"), d && !c && e.removeClass(a, "pswp--animated-in"), g && (d ? e[(c ? "remove" : "add") + "Class"](a, "pswp--animate_opacity") : setTimeout(function () {
                    e.addClass(a, "pswp--animate_opacity")
                }, 30)), Wb = setTimeout(function () {
                    if (Ca("initialZoom" + (d ? "Out" : "In")), d) {
                        var f = h.w / b.w,
                            i = {
                                x: oa.x,
                                y: oa.y
                            },
                            l = s,
                            m = ia,
                            n = function (b) {
                                1 === b ? (s = f, oa.x = h.x, oa.y = h.y - M) : (s = (f - l) * b + l, oa.x = (h.x - i.x) * b + i.x, oa.y = (h.y - M - i.y) * b + i.y), Ga(), g ? a.style.opacity = 1 - b : Ea(m - b * m)
                            };
                        c ? cb("initialZoom", 0, 1, j, e.easing.cubic.out, n, k) : (n(1), Wb = setTimeout(k, j + 20))
                    } else s = b.initialZoomLevel, La(oa, b.initialPosition), Ga(), Ea(1), g ? a.style.opacity = 1 : Ea(1), Wb = setTimeout(k, j + 20)
                }, d ? 25 : 90)
            };
            n()
        },
        cc = {},
        dc = [],
        ec = {
            index: 0,
            errorMsg: '<div class="pswp__error-msg"><a href="%url%" target="_blank">The image</a> could not be loaded.</div>',
            forceProgressiveLoading: !1,
            preload: [1, 1],
            getNumItemsFn: function () {
                return Xb.length
            }
        },
        fc = function () {
            return {
                center: {
                    x: 0,
                    y: 0
                },
                max: {
                    x: 0,
                    y: 0
                },
                min: {
                    x: 0,
                    y: 0
                }
            }
        },
        gc = function (a, b, c) {
            var d = a.bounds;
            d.center.x = Math.round((cc.x - b) / 2), d.center.y = Math.round((cc.y - c) / 2) + a.vGap.top, d.max.x = b > cc.x ? Math.round(cc.x - b) : d.center.x, d.max.y = c > cc.y ? Math.round(cc.y - c) + a.vGap.top : d.center.y, d.min.x = b > cc.x ? 0 : d.center.x, d.min.y = c > cc.y ? a.vGap.top : d.center.y
        },
        hc = function (a, b, c) {
            if (a.src && !a.loadError) {
                var d = !c;
                if (d && (a.vGap || (a.vGap = {
                        top: 0,
                        bottom: 0
                    }), Ca("parseVerticalMargin", a)), cc.x = b.x, cc.y = b.y - a.vGap.top - a.vGap.bottom, d) {
                    var e = cc.x / a.w,
                        f = cc.y / a.h;
                    a.fitRatio = f > e ? e : f;
                    var g = i.scaleMode;
                    "orig" === g ? c = 1 : "fit" === g && (c = a.fitRatio), c > 1 && (c = 1), a.initialZoomLevel = c, a.bounds || (a.bounds = fc())
                }
                if (!c) return;
                return gc(a, a.w * c, a.h * c), d && c === a.initialZoomLevel && (a.initialPosition = a.bounds.center), a.bounds
            }
            return a.w = a.h = 0, a.initialZoomLevel = a.fitRatio = 1, a.bounds = fc(), a.initialPosition = a.bounds.center, a.bounds
        },
        ic = function (a, b, c, d, e, g) {
            b.loadError || d && (b.imageAppended = !0, lc(b, d, b === f.currItem && xa), c.appendChild(d), g && setTimeout(function () {
                b && b.loaded && b.placeholder && (b.placeholder.style.display = "none", b.placeholder = null)
            }, 500))
        },
        jc = function (a) {
            a.loading = !0, a.loaded = !1;
            var b = a.img = e.createEl("pswp__img", "img"),
                c = function () {
                    a.loading = !1, a.loaded = !0, a.loadComplete ? a.loadComplete(a) : a.img = null, b.onload = b.onerror = null, b = null
                };
            return b.onload = c, b.onerror = function () {
                a.loadError = !0, c()
            }, b.src = a.src, b
        },
        kc = function (a, b) {
            return a.src && a.loadError && a.container ? (b && (a.container.innerHTML = ""), a.container.innerHTML = i.errorMsg.replace("%url%", a.src), !0) : void 0
        },
        lc = function (a, b, c) {
            if (a.src) {
                b || (b = a.container.lastChild);
                var d = c ? a.w : Math.round(a.w * a.fitRatio),
                    e = c ? a.h : Math.round(a.h * a.fitRatio);
                a.placeholder && !a.loaded && (a.placeholder.style.width = d + "px", a.placeholder.style.height = e + "px"), b.style.width = d + "px", b.style.height = e + "px"
            }
        },
        mc = function () {
            if (dc.length) {
                for (var a, b = 0; b < dc.length; b++) a = dc[b], a.holder.index === a.index && ic(a.index, a.item, a.baseDiv, a.img, !1, a.clearPlaceholder);
                dc = []
            }
        };
    ya("Controller", {
        publicMethods: {
            lazyLoadItem: function (a) {
                a = za(a);
                var b = $b(a);
                b && (!b.loaded && !b.loading || x) && (Ca("gettingData", a, b), b.src && jc(b))
            },
            initController: function () {
                e.extend(i, ec, !0), f.items = Xb = c, $b = f.getItemAt, _b = i.getNumItemsFn, ac = i.loop, _b() < 3 && (i.loop = !1), Ba("beforeChange", function (a) {
                    var b, c = i.preload,
                        d = null === a ? !0 : a >= 0,
                        e = Math.min(c[0], _b()),
                        g = Math.min(c[1], _b());
                    for (b = 1;
                        (d ? g : e) >= b; b++) f.lazyLoadItem(m + b);
                    for (b = 1;
                        (d ? e : g) >= b; b++) f.lazyLoadItem(m - b)
                }), Ba("initialLayout", function () {
                    f.currItem.initialLayout = i.getThumbBoundsFn && i.getThumbBoundsFn(m)
                }), Ba("mainScrollAnimComplete", mc), Ba("initialZoomInEnd", mc), Ba("destroy", function () {
                    for (var a, b = 0; b < Xb.length; b++) a = Xb[b], a.container && (a.container = null), a.placeholder && (a.placeholder = null), a.img && (a.img = null), a.preloader && (a.preloader = null), a.loadError && (a.loaded = a.loadError = !1);
                    dc = null
                })
            },
            getItemAt: function (a) {
                return a >= 0 && void 0 !== Xb[a] ? Xb[a] : !1
            },
            allowProgressiveImg: function () {
                return i.forceProgressiveLoading || !G || i.mouseUsed || screen.width > 1200
            },
            setContent: function (a, b) {
                i.loop && (b = za(b));
                var c = f.getItemAt(a.index);
                c && (c.container = null);
                var d, g = f.getItemAt(b);
                if (!g) return void(a.el.innerHTML = "");
                Ca("gettingData", b, g), a.index = b, a.item = g;
                var h = g.container = e.createEl("pswp__zoom-wrap");
                if (!g.src && g.html && (g.html.tagName ? h.appendChild(g.html) : h.innerHTML = g.html), kc(g), hc(g, pa), !g.src || g.loadError || g.loaded) g.src && !g.loadError && (d = e.createEl("pswp__img", "img"), d.style.opacity = 1, d.src = g.src, lc(g, d), ic(b, g, h, d, !0));
                else {
                    if (g.loadComplete = function (c) {
                            if (j) {
                                if (a && a.index === b) {
                                    if (kc(c, !0)) return c.loadComplete = c.img = null, hc(c, pa), Ha(c), void(a.index === m && f.updateCurrZoomItem());
                                    c.imageAppended ? !Zb && c.placeholder && (c.placeholder.style.display = "none", c.placeholder = null) : N.transform && (ea || Zb) ? dc.push({
                                        item: c,
                                        baseDiv: h,
                                        img: c.img,
                                        index: b,
                                        holder: a,
                                        clearPlaceholder: !0
                                    }) : ic(b, c, h, c.img, ea || Zb, !0)
                                }
                                c.loadComplete = null, c.img = null, Ca("imageLoadComplete", b, c)
                            }
                        }, e.features.transform) {
                        var k = "pswp__img pswp__img--placeholder";
                        k += g.msrc ? "" : " pswp__img--placeholder--blank";
                        var l = e.createEl(k, g.msrc ? "img" : "");
                        g.msrc && (l.src = g.msrc), lc(g, l), h.appendChild(l), g.placeholder = l
                    }
                    g.loading || jc(g), f.allowProgressiveImg() && (!Yb && N.transform ? dc.push({
                        item: g,
                        baseDiv: h,
                        img: g.img,
                        index: b,
                        holder: a
                    }) : ic(b, g, h, g.img, !0, !0))
                }
                Yb || b !== m ? Ha(g) : (da = h.style, bc(g, d || g.img)), a.el.innerHTML = "", a.el.appendChild(h)
            },
            cleanSlide: function (a) {
                a.img && (a.img.onload = a.img.onerror = null), a.loaded = a.loading = a.img = a.imageAppended = !1
            }
        }
    });
    var nc, oc = {},
        pc = function (a, b, c) {
            var d = document.createEvent("CustomEvent"),
                e = {
                    origEvent: a,
                    target: a.target,
                    releasePoint: b,
                    pointerType: c || "touch"
                };
            d.initCustomEvent("pswpTap", !0, !0, e), a.target.dispatchEvent(d)
        };
    ya("Tap", {
        publicMethods: {
            initTap: function () {
                Ba("firstTouchStart", f.onTapStart), Ba("touchRelease", f.onTapRelease), Ba("destroy", function () {
                    oc = {}, nc = null
                })
            },
            onTapStart: function (a) {
                a.length > 1 && (clearTimeout(nc), nc = null)
            },
            onTapRelease: function (a, b) {
                if (b && !X && !V && !$a) {
                    var c = b;
                    if (nc && (clearTimeout(nc), nc = null, wb(c, oc))) return void Ca("doubleTap", c);
                    if ("mouse" === b.type) return void pc(a, b, "mouse");
                    var d = a.target.tagName.toUpperCase();
                    if ("BUTTON" === d || e.hasClass(a.target, "pswp__single-tap")) return void pc(a, b);
                    La(oc, c), nc = setTimeout(function () {
                        pc(a, b), nc = null
                    }, 300)
                }
            }
        }
    });
    var qc;
    ya("DesktopZoom", {
        publicMethods: {
            initDesktopZoom: function () {
                L || (G ? Ba("mouseUsed", function () {
                    f.setupDesktopZoom()
                }) : f.setupDesktopZoom(!0))
            },
            setupDesktopZoom: function (b) {
                qc = {};
                var c = "wheel mousewheel DOMMouseScroll";
                Ba("bindEvents", function () {
                    e.bind(a, c, f.handleMouseWheel)
                }), Ba("unbindEvents", function () {
                    qc && e.unbind(a, c, f.handleMouseWheel)
                }), f.mouseZoomedIn = !1;
                var d, g = function () {
                        f.mouseZoomedIn && (e.removeClass(a, "pswp--zoomed-in"), f.mouseZoomedIn = !1), 1 > s ? e.addClass(a, "pswp--zoom-allowed") : e.removeClass(a, "pswp--zoom-allowed"), h()
                    },
                    h = function () {
                        d && (e.removeClass(a, "pswp--dragging"), d = !1)
                    };
                Ba("resize", g), Ba("afterChange", g), Ba("pointerDown", function () {
                    f.mouseZoomedIn && (d = !0, e.addClass(a, "pswp--dragging"))
                }), Ba("pointerUp", h), b || g()
            },
            handleMouseWheel: function (a) {
                if (s <= f.currItem.fitRatio) return i.modal && (!i.closeOnScroll || $a || U ? a.preventDefault() : E && Math.abs(a.deltaY) > 2 && (l = !0, f.close())), !0;
                if (a.stopPropagation(), qc.x = 0, "deltaX" in a) 1 === a.deltaMode ? (qc.x = 18 * a.deltaX, qc.y = 18 * a.deltaY) : (qc.x = a.deltaX, qc.y = a.deltaY);
                else if ("wheelDelta" in a) a.wheelDeltaX && (qc.x = -.16 * a.wheelDeltaX), a.wheelDeltaY ? qc.y = -.16 * a.wheelDeltaY : qc.y = -.16 * a.wheelDelta;
                else {
                    if (!("detail" in a)) return;
                    qc.y = a.detail
                }
                Ra(s, !0);
                var b = oa.x - qc.x,
                    c = oa.y - qc.y;
                (i.modal || b <= ca.min.x && b >= ca.max.x && c <= ca.min.y && c >= ca.max.y) && a.preventDefault(), f.panTo(b, c)
            },
            toggleDesktopZoom: function (b) {
                b = b || {
                    x: pa.x / 2 + ra.x,
                    y: pa.y / 2 + ra.y
                };
                var c = i.getDoubleTapZoom(!0, f.currItem),
                    d = s === c;
                f.mouseZoomedIn = !d, f.zoomTo(d ? f.currItem.initialZoomLevel : c, b, 333), e[(d ? "remove" : "add") + "Class"](a, "pswp--zoomed-in")
            }
        }
    });
    var rc, sc, tc, uc, vc, wc, xc, yc, zc, Ac, Bc, Cc, Dc = {
            history: !0,
            galleryUID: 1
        },
        Ec = function () {
            return Bc.hash.substring(1)
        },
        Fc = function () {
            rc && clearTimeout(rc), tc && clearTimeout(tc)
        },
        Gc = function () {
            var a = Ec(),
                b = {};
            if (a.length < 5) return b;
            var c, d = a.split("&");
            for (c = 0; c < d.length; c++)
                if (d[c]) {
                    var e = d[c].split("=");
                    e.length < 2 || (b[e[0]] = e[1])
                }
            if (i.galleryPIDs) {
                var f = b.pid;
                for (b.pid = 0, c = 0; c < Xb.length; c++)
                    if (Xb[c].pid === f) {
                        b.pid = c;
                        break
                    }
            } else b.pid = parseInt(b.pid, 10) - 1;
            return b.pid < 0 && (b.pid = 0), b
        },
        Hc = function () {
            if (tc && clearTimeout(tc), $a || U) return void(tc = setTimeout(Hc, 500));
            uc ? clearTimeout(sc) : uc = !0;
            var a = m + 1,
                b = $b(m);
            b.hasOwnProperty("pid") && (a = b.pid);
            var c = xc + "&gid=" + i.galleryUID + "&pid=" + a;
            yc || -1 === Bc.hash.indexOf(c) && (Ac = !0);
            var d = Bc.href.split("#")[0] + "#" + c;
            Cc ? "#" + c !== window.location.hash && history[yc ? "replaceState" : "pushState"]("", document.title, d) : yc ? Bc.replace(d) : Bc.hash = c, yc = !0, sc = setTimeout(function () {
                uc = !1
            }, 60)
        };
    ya("History", {
        publicMethods: {
            initHistory: function () {
                if (e.extend(i, Dc, !0), i.history) {
                    Bc = window.location, Ac = !1, zc = !1, yc = !1, xc = Ec(), Cc = "pushState" in history, xc.indexOf("gid=") > -1 && (xc = xc.split("&gid=")[0], xc = xc.split("?gid=")[0]), Ba("afterChange", f.updateURL), Ba("unbindEvents", function () {
                        e.unbind(window, "hashchange", f.onHashChange)
                    });
                    var a = function () {
                        wc = !0, zc || (Ac ? history.back() : xc ? Bc.hash = xc : Cc ? history.pushState("", document.title, Bc.pathname + Bc.search) : Bc.hash = ""), Fc()
                    };
                    Ba("unbindEvents", function () {
                        l && a()
                    }), Ba("destroy", function () {
                        wc || a()
                    }), Ba("firstUpdate", function () {
                        m = Gc().pid
                    });
                    var b = xc.indexOf("pid=");
                    b > -1 && (xc = xc.substring(0, b), "&" === xc.slice(-1) && (xc = xc.slice(0, -1))), setTimeout(function () {
                        j && e.bind(window, "hashchange", f.onHashChange)
                    }, 40)
                }
            },
            onHashChange: function () {
                return Ec() === xc ? (zc = !0, void f.close()) : void(uc || (vc = !0, f.goTo(Gc().pid), vc = !1))
            },
            updateURL: function () {
                Fc(), vc || (yc ? rc = setTimeout(Hc, 800) : Hc())
            }
        }
    }), e.extend(f, db)
};
return a

});

/*! PhotoSwipe Default UI - 4.1.1 - 2015-12-24

* http://photoswipe.com
* Copyright (c) 2015 Dmitry Semenov; */

! function (a, b) {

"function" == typeof define && define.amd ? define(b) : "object" == typeof exports ? module.exports = b() : a.PhotoSwipeUI_Default = b()

}(this, function () {

"use strict";
var a = function (a, b) {
    var c, d, e, f, g, h, i, j, k, l, m, n, o, p, q, r, s, t, u, v = this,
        w = !1,
        x = !0,
        y = !0,
        z = {
            barsSize: {
                top: 44,
                bottom: "auto"
            },
            closeElClasses: ["item", "caption", "zoom-wrap", "ui", "top-bar"],
            timeToIdle: 4e3,
            timeToIdleOutside: 1e3,
            loadingIndicatorDelay: 1e3,
            addCaptionHTMLFn: function (a, b) {
                return a.title ? (b.children[0].innerHTML = a.title, !0) : (b.children[0].innerHTML = "", !1)
            },
            closeEl: !0,
            captionEl: !0,
            fullscreenEl: !0,
            zoomEl: !0,
            shareEl: !0,
            counterEl: !0,
            arrowEl: !0,
            preloaderEl: !0,
            tapToClose: !1,
            tapToToggleControls: !0,
            clickToCloseNonZoomable: !0,
            shareButtons: [{
                id: "facebook",
                label: "Share on Facebook",
                url: "https://www.facebook.com/sharer/sharer.php?u={{url}}"
            }, {
                id: "twitter",
                label: "Tweet",
                url: "https://twitter.com/intent/tweet?text={{text}}&url={{url}}"
            }, {
                id: "pinterest",
                label: "Pin it",
                url: "http://www.pinterest.com/pin/create/button/?url={{url}}&media={{image_url}}&description={{text}}"
            }, {
                id: "download",
                label: "Download image",
                url: "{{raw_image_url}}",
                download: !0
            }],
            getImageURLForShare: function () {
                return a.currItem.src || ""
            },
            getPageURLForShare: function () {
                return window.location.href
            },
            getTextForShare: function () {
                return a.currItem.title || ""
            },
            indexIndicatorSep: " / ",
            fitControlsWidth: 1200
        },
        A = function (a) {
            if (r) return !0;
            a = a || window.event, q.timeToIdle && q.mouseUsed && !k && K();
            for (var c, d, e = a.target || a.srcElement, f = e.getAttribute("class") || "", g = 0; g < S.length; g++) c = S[g], c.onTap && f.indexOf("pswp__" + c.name) > -1 && (c.onTap(), d = !0);
            if (d) {
                a.stopPropagation && a.stopPropagation(), r = !0;
                var h = b.features.isOldAndroid ? 600 : 30;
                s = setTimeout(function () {
                    r = !1
                }, h)
            }
        },
        B = function () {
            return !a.likelyTouchDevice || q.mouseUsed || screen.width > q.fitControlsWidth
        },
        C = function (a, c, d) {
            b[(d ? "add" : "remove") + "Class"](a, "pswp__" + c)
        },
        D = function () {
            var a = 1 === q.getNumItemsFn();
            a !== p && (C(d, "ui--one-slide", a), p = a)
        },
        E = function () {
            C(i, "share-modal--hidden", y)
        },
        F = function () {
            return y = !y, y ? (b.removeClass(i, "pswp__share-modal--fade-in"), setTimeout(function () {
                y && E()
            }, 300)) : (E(), setTimeout(function () {
                y || b.addClass(i, "pswp__share-modal--fade-in")
            }, 30)), y || H(), !1
        },
        G = function (b) {
            b = b || window.event;
            var c = b.target || b.srcElement;
            return a.shout("shareLinkClick", b, c), c.href ? c.hasAttribute("download") ? !0 : (window.open(c.href, "pswp_share", "scrollbars=yes,resizable=yes,toolbar=no,location=yes,width=550,height=420,top=100,left=" + (window.screen ? Math.round(screen.width / 2 - 275) : 100)), y || F(), !1) : !1
        },
        H = function () {
            for (var a, b, c, d, e, f = "", g = 0; g < q.shareButtons.length; g++) a = q.shareButtons[g], c = q.getImageURLForShare(a), d = q.getPageURLForShare(a), e = q.getTextForShare(a), b = a.url.replace("{{url}}", encodeURIComponent(d)).replace("{{image_url}}", encodeURIComponent(c)).replace("{{raw_image_url}}", c).replace("{{text}}", encodeURIComponent(e)), f += '<a href="' + b + '" target="_blank" class="pswp__share--' + a.id + '"' + (a.download ? "download" : "") + ">" + a.label + "</a>", q.parseShareButtonOut && (f = q.parseShareButtonOut(a, f));
            i.children[0].innerHTML = f, i.children[0].onclick = G
        },
        I = function (a) {
            for (var c = 0; c < q.closeElClasses.length; c++)
                if (b.hasClass(a, "pswp__" + q.closeElClasses[c])) return !0
        },
        J = 0,
        K = function () {
            clearTimeout(u), J = 0, k && v.setIdle(!1)
        },
        L = function (a) {
            a = a ? a : window.event;
            var b = a.relatedTarget || a.toElement;
            b && "HTML" !== b.nodeName || (clearTimeout(u), u = setTimeout(function () {
                v.setIdle(!0)
            }, q.timeToIdleOutside))
        },
        M = function () {
            q.fullscreenEl && !b.features.isOldAndroid && (c || (c = v.getFullscreenAPI()), c ? (b.bind(document, c.eventK, v.updateFullscreen), v.updateFullscreen(), b.addClass(a.template, "pswp--supports-fs")) : b.removeClass(a.template, "pswp--supports-fs"))
        },
        N = function () {
            q.preloaderEl && (O(!0), l("beforeChange", function () {
                clearTimeout(o), o = setTimeout(function () {
                    a.currItem && a.currItem.loading ? (!a.allowProgressiveImg() || a.currItem.img && !a.currItem.img.naturalWidth) && O(!1) : O(!0)
                }, q.loadingIndicatorDelay)
            }), l("imageLoadComplete", function (b, c) {
                a.currItem === c && O(!0)
            }))
        },
        O = function (a) {
            n !== a && (C(m, "preloader--active", !a), n = a)
        },
        P = function (a) {
            var c = a.vGap;
            if (B()) {
                var g = q.barsSize;
                if (q.captionEl && "auto" === g.bottom)
                    if (f || (f = b.createEl("pswp__caption pswp__caption--fake"), f.appendChild(b.createEl("pswp__caption__center")), d.insertBefore(f, e), b.addClass(d, "pswp__ui--fit")), q.addCaptionHTMLFn(a, f, !0)) {
                        var h = f.clientHeight;
                        c.bottom = parseInt(h, 10) || 44
                    } else c.bottom = g.top;
                else c.bottom = "auto" === g.bottom ? 0 : g.bottom;
                c.top = g.top
            } else c.top = c.bottom = 0
        },
        Q = function () {
            q.timeToIdle && l("mouseUsed", function () {
                b.bind(document, "mousemove", K), b.bind(document, "mouseout", L), t = setInterval(function () {
                    J++, 2 === J && v.setIdle(!0)
                }, q.timeToIdle / 2)
            })
        },
        R = function () {
            l("onVerticalDrag", function (a) {
                x && .95 > a ? v.hideControls() : !x && a >= .95 && v.showControls()
            });
            var a;
            l("onPinchClose", function (b) {
                x && .9 > b ? (v.hideControls(), a = !0) : a && !x && b > .9 && v.showControls()
            }), l("zoomGestureEnded", function () {
                a = !1, a && !x && v.showControls()
            })
        },
        S = [{
            name: "caption",
            option: "captionEl",
            onInit: function (a) {
                e = a
            }
        }, {
            name: "share-modal",
            option: "shareEl",
            onInit: function (a) {
                i = a
            },
            onTap: function () {
                F()
            }
        }, {
            name: "button--share",
            option: "shareEl",
            onInit: function (a) {
                h = a
            },
            onTap: function () {
                F()
            }
        }, {
            name: "button--zoom",
            option: "zoomEl",
            onTap: a.toggleDesktopZoom
        }, {
            name: "counter",
            option: "counterEl",
            onInit: function (a) {
                g = a
            }
        }, {
            name: "button--close",
            option: "closeEl",
            onTap: a.close
        }, {
            name: "button--arrow--left",
            option: "arrowEl",
            onTap: a.prev
        }, {
            name: "button--arrow--right",
            option: "arrowEl",
            onTap: a.next
        }, {
            name: "button--fs",
            option: "fullscreenEl",
            onTap: function () {
                c.isFullscreen() ? c.exit() : c.enter()
            }
        }, {
            name: "preloader",
            option: "preloaderEl",
            onInit: function (a) {
                m = a
            }
        }],
        T = function () {
            var a, c, e, f = function (d) {
                if (d)
                    for (var f = d.length, g = 0; f > g; g++) {
                        a = d[g], c = a.className;
                        for (var h = 0; h < S.length; h++) e = S[h], c.indexOf("pswp__" + e.name) > -1 && (q[e.option] ? (b.removeClass(a, "pswp__element--disabled"), e.onInit && e.onInit(a)) : b.addClass(a, "pswp__element--disabled"))
                    }
            };
            f(d.children);
            var g = b.getChildByClass(d, "pswp__top-bar");
            g && f(g.children)
        };
    v.init = function () {
        b.extend(a.options, z, !0), q = a.options, d = b.getChildByClass(a.scrollWrap, "pswp__ui"), l = a.listen, R(), l("beforeChange", v.update), l("doubleTap", function (b) {
            var c = a.currItem.initialZoomLevel;
            a.getZoomLevel() !== c ? a.zoomTo(c, b, 333) : a.zoomTo(q.getDoubleTapZoom(!1, a.currItem), b, 333)
        }), l("preventDragEvent", function (a, b, c) {
            var d = a.target || a.srcElement;
            d && d.getAttribute("class") && a.type.indexOf("mouse") > -1 && (d.getAttribute("class").indexOf("__caption") > 0 || /(SMALL|STRONG|EM)/i.test(d.tagName)) && (c.prevent = !1)
        }), l("bindEvents", function () {
            b.bind(d, "pswpTap click", A), b.bind(a.scrollWrap, "pswpTap", v.onGlobalTap), a.likelyTouchDevice || b.bind(a.scrollWrap, "mouseover", v.onMouseOver)
        }), l("unbindEvents", function () {
            y || F(), t && clearInterval(t), b.unbind(document, "mouseout", L), b.unbind(document, "mousemove", K), b.unbind(d, "pswpTap click", A), b.unbind(a.scrollWrap, "pswpTap", v.onGlobalTap), b.unbind(a.scrollWrap, "mouseover", v.onMouseOver), c && (b.unbind(document, c.eventK, v.updateFullscreen), c.isFullscreen() && (q.hideAnimationDuration = 0, c.exit()), c = null)
        }), l("destroy", function () {
            q.captionEl && (f && d.removeChild(f), b.removeClass(e, "pswp__caption--empty")), i && (i.children[0].onclick = null), b.removeClass(d, "pswp__ui--over-close"), b.addClass(d, "pswp__ui--hidden"), v.setIdle(!1)
        }), q.showAnimationDuration || b.removeClass(d, "pswp__ui--hidden"), l("initialZoomIn", function () {
            q.showAnimationDuration && b.removeClass(d, "pswp__ui--hidden")
        }), l("initialZoomOut", function () {
            b.addClass(d, "pswp__ui--hidden")
        }), l("parseVerticalMargin", P), T(), q.shareEl && h && i && (y = !0), D(), Q(), M(), N()
    }, v.setIdle = function (a) {
        k = a, C(d, "ui--idle", a)
    }, v.update = function () {
        x && a.currItem ? (v.updateIndexIndicator(), q.captionEl && (q.addCaptionHTMLFn(a.currItem, e), C(e, "caption--empty", !a.currItem.title)), w = !0) : w = !1, y || F(), D()
    }, v.updateFullscreen = function (d) {
        d && setTimeout(function () {
            a.setScrollOffset(0, b.getScrollY())
        }, 50), b[(c.isFullscreen() ? "add" : "remove") + "Class"](a.template, "pswp--fs")
    }, v.updateIndexIndicator = function () {
        q.counterEl && (g.innerHTML = a.getCurrentIndex() + 1 + q.indexIndicatorSep + q.getNumItemsFn())
    }, v.onGlobalTap = function (c) {
        c = c || window.event;
        var d = c.target || c.srcElement;
        if (!r)
            if (c.detail && "mouse" === c.detail.pointerType) {
                if (I(d)) return void a.close();
                b.hasClass(d, "pswp__img") && (1 === a.getZoomLevel() && a.getZoomLevel() <= a.currItem.fitRatio ? q.clickToCloseNonZoomable && a.close() : a.toggleDesktopZoom(c.detail.releasePoint))
            } else if (q.tapToToggleControls && (x ? v.hideControls() : v.showControls()), q.tapToClose && (b.hasClass(d, "pswp__img") || I(d))) return void a.close()
    }, v.onMouseOver = function (a) {
        a = a || window.event;
        var b = a.target || a.srcElement;
        C(d, "ui--over-close", I(b))
    }, v.hideControls = function () {
        b.addClass(d, "pswp__ui--hidden"), x = !1
    }, v.showControls = function () {
        x = !0, w || v.update(), b.removeClass(d, "pswp__ui--hidden")
    }, v.supportsFullscreen = function () {
        var a = document;
        return !!(a.exitFullscreen || a.mozCancelFullScreen || a.webkitExitFullscreen || a.msExitFullscreen)
    }, v.getFullscreenAPI = function () {
        var b, c = document.documentElement,
            d = "fullscreenchange";
        return c.requestFullscreen ? b = {
            enterK: "requestFullscreen",
            exitK: "exitFullscreen",
            elementK: "fullscreenElement",
            eventK: d
        } : c.mozRequestFullScreen ? b = {
            enterK: "mozRequestFullScreen",
            exitK: "mozCancelFullScreen",
            elementK: "mozFullScreenElement",
            eventK: "moz" + d
        } : c.webkitRequestFullscreen ? b = {
            enterK: "webkitRequestFullscreen",
            exitK: "webkitExitFullscreen",
            elementK: "webkitFullscreenElement",
            eventK: "webkit" + d
        } : c.msRequestFullscreen && (b = {
            enterK: "msRequestFullscreen",
            exitK: "msExitFullscreen",
            elementK: "msFullscreenElement",
            eventK: "MSFullscreenChange"
        }), b && (b.enter = function () {
            return j = q.closeOnScroll, q.closeOnScroll = !1, "webkitRequestFullscreen" !== this.enterK ? a.template[this.enterK]() : void a.template[this.enterK](Element.ALLOW_KEYBOARD_INPUT)
        }, b.exit = function () {
            return q.closeOnScroll = j, document[this.exitK]()
        }, b.isFullscreen = function () {
            return document[this.elementK]
        }), b
    }
};
return a

});

var initPhotoSwipeFromDOM = function (gallerySelector) {

// parse slide data (url, title, size ...) from DOM elements 
// (children of gallerySelector)
var parseThumbnailElements = function (el) {
    var thumbElements = el.childNodes,
        numNodes = thumbElements.length,
        items = [],
        figureEl,
        linkEl,
        size,
        item;

    for (var i = 0; i < numNodes; i++) {

        figureEl = thumbElements[i]; // <figure> element

        // include only element nodes 
        if (figureEl.nodeType !== 1) {
            continue;
        }

        linkEl = figureEl.children[0]; // <a> element

        size = linkEl.getAttribute('data-size').split('x');

        // create slide object
        item = {
            src: linkEl.getAttribute('href'),
            w: parseInt(size[0], 10),
            h: parseInt(size[1], 10)
        };

        if (figureEl.children.length > 1) {
            // <figcaption> content
            item.title = figureEl.children[1].innerHTML;
        }

        if (linkEl.children.length > 0) {
            // <img> thumbnail element, retrieving thumbnail url
            item.msrc = linkEl.children[0].getAttribute('src');
        }

        item.el = figureEl; // save link to element for getThumbBoundsFn
        items.push(item);
    }

    return items;
};

// find nearest parent element
var closest = function closest(el, fn) {
    return el && (fn(el) ? el : closest(el.parentNode, fn));
};

// triggers when user clicks on thumbnail
var onThumbnailsClick = function (e) {
    e = e || window.event;
    e.preventDefault ? e.preventDefault() : e.returnValue = false;

    var eTarget = e.target || e.srcElement;

    // find root element of slide
    var clickedListItem = closest(eTarget, function (el) {
        return (el.tagName && el.tagName.toUpperCase() === 'FIGURE');
    });

    if (!clickedListItem) {
        return;
    }

    // find index of clicked item by looping through all child nodes
    // alternatively, you may define index via data- attribute
    var clickedGallery = clickedListItem.parentNode,
        childNodes = clickedListItem.parentNode.childNodes,
        numChildNodes = childNodes.length,
        nodeIndex = 0,
        index;

    for (var i = 0; i < numChildNodes; i++) {
        if (childNodes[i].nodeType !== 1) {
            continue;
        }

        if (childNodes[i] === clickedListItem) {
            index = nodeIndex;
            break;
        }
        nodeIndex++;
    }

    if (index >= 0) {
        // open PhotoSwipe if valid index found
        openPhotoSwipe(index, clickedGallery);
    }
    return false;
};

// parse picture index and gallery index from URL (#&pid=1&gid=2)
var photoswipeParseHash = function () {
    var hash = window.location.hash.substring(1),
        params = {};

    if (hash.length < 5) {
        return params;
    }

    var vars = hash.split('&');
    for (var i = 0; i < vars.length; i++) {
        if (!vars[i]) {
            continue;
        }
        var pair = vars[i].split('=');
        if (pair.length < 2) {
            continue;
        }
        params[pair[0]] = pair[1];
    }

    if (params.gid) {
        params.gid = parseInt(params.gid, 10);
    }

    return params;
};

var openPhotoSwipe = function (index, galleryElement, disableAnimation, fromURL) {
    var pswpElement = document.querySelectorAll('.pswp')[0],
        gallery,
        options,
        items;

    items = parseThumbnailElements(galleryElement);

    // define options (if needed)
    options = {

        // define gallery index (for URL)
        galleryUID: galleryElement.getAttribute('data-pswp-uid'),

        getThumbBoundsFn: function (index) {
            // See Options -> getThumbBoundsFn section of documentation for more info
            var thumbnail = items[index].el.getElementsByTagName('img')[0], // find thumbnail
                pageYScroll = window.pageYOffset || document.documentElement.scrollTop,
                rect = thumbnail.getBoundingClientRect();

            return {
                x: rect.left,
                y: rect.top + pageYScroll,
                w: rect.width
            };
        }

    };

    // PhotoSwipe opened from URL
    if (fromURL) {
        if (options.galleryPIDs) {
            // parse real index when custom PIDs are used 
            // http://photoswipe.com/documentation/faq.html#custom-pid-in-url
            for (var j = 0; j < items.length; j++) {
                if (items[j].pid == index) {
                    options.index = j;
                    break;
                }
            }
        } else {
            // in URL indexes start from 1
            options.index = parseInt(index, 10) - 1;
        }
    } else {
        options.index = parseInt(index, 10);
    }

    // exit if index not found
    if (isNaN(options.index)) {
        return;
    }

    if (disableAnimation) {
        options.showAnimationDuration = 0;
    }

    // Pass data to PhotoSwipe and initialize it
    gallery = new PhotoSwipe(pswpElement, PhotoSwipeUI_Default, items, options);
    gallery.init();
};

// loop through all gallery elements and bind events
var galleryElements = document.querySelectorAll(gallerySelector);

for (var i = 0, l = galleryElements.length; i < l; i++) {
    galleryElements[i].setAttribute('data-pswp-uid', i + 1);
    galleryElements[i].onclick = onThumbnailsClick;
}

// Parse URL and open gallery if it contains #&pid=3&gid=1
var hashData = photoswipeParseHash();
if (hashData.pid && hashData.gid) {
    openPhotoSwipe(hashData.pid, galleryElements[hashData.gid - 1], true, true);
}

};

// execute above function initPhotoSwipeFromDOM('.mdb-lightbox'); /* jSticky Plugin

* =============
* Author: Andrew Henderson (@AndrewHenderson)
* Contributor: Mike Street (@mikestreety)
* Date: 9/7/2012
* Update: 09/20/2016
* Website: http://github.com/andrewhenderson/jsticky/
* Description: A jQuery plugin that keeps select DOM
* element(s) in view while scrolling the page.
*/

;(function($) {

$.fn.sticky = function(options) {
  var defaults = {
    topSpacing: 0, // No spacing by default
    zIndex: '', // No default z-index
    stopper: '.sticky-stopper', // Default stopper class, also accepts number value
    stickyClass: false // Class applied to element when it's stuck
  };
  var settings = $.extend({}, defaults, options); // Accepts custom stopper id or class

  // Checks if custom z-index was defined
  function checkIndex() {
    if (typeof settings.zIndex == 'number') {
      return true;
    } else {
      return false;
    }
  }

  var hasIndex = checkIndex(); // True or false

  // Checks if a stopper exists in the DOM or number defined
  function checkStopper() {
    if (0 < $(settings.stopper).length || typeof settings.stopper === 'number') {
      return true;
    } else {
      return false;
    }
  }
  var hasStopper = checkStopper(); // True or false

  return this.each(function() {

    var $this = $(this);
    var thisHeight = $this.outerHeight();
    var thisWidth = $this.outerWidth();
    var topSpacing = settings.topSpacing;
    var zIndex = settings.zIndex;
    var pushPoint = $this.offset().top - topSpacing; // Point at which the sticky element starts pushing
    var placeholder = $('<div></div>').width(thisWidth).height(thisHeight).addClass('sticky-placeholder'); // Cache a clone sticky element
    var stopper = settings.stopper;
    var $window = $(window);

    function stickyScroll() {

      var windowTop  = $window.scrollTop(); // Check window's scroll position
      var stopPoint = stopper;
      var parentWidth = $this.parent().width();

      placeholder.width(parentWidth)

      if ( hasStopper && typeof stopper === 'string' ) {
        var stopperTop = $(stopper).offset().top;
        stopPoint  = (stopperTop - thisHeight) - topSpacing;
      }

      if (pushPoint < windowTop) {
        // Create a placeholder for sticky element to occupy vertical real estate
        if(settings.stickyClass)
          $this.addClass(settings.stickyClass);

        $this.after(placeholder).css({
          position: 'fixed',
          top: topSpacing,
          width: parentWidth
        });

        if (hasIndex) {
          $this.css({
            zIndex: zIndex
          });
        }

        if (hasStopper) {
          if (stopPoint < windowTop) {
            var diff = (stopPoint - windowTop) + topSpacing;
            $this.css({
              top: diff
            });
          }
        }
      } else {
        if(settings.stickyClass)
          $this.removeClass(settings.stickyClass);

        $this.css({
          position: 'static',
          top: null,
          left: null,
          width: 'auto'
        });

        placeholder.remove();
      }
    }

    if($window.innerHeight() > thisHeight) {

      $window.bind('scroll', stickyScroll);
      $window.bind('load', stickyScroll);
      $window.bind('resize', stickyScroll);
    }
  });
};

})(jQuery); /*!

* perfect-scrollbar v1.4.0
* (c) 2018 Hyunje Jun
* @license MIT
*/

!function(t,e){“object”==typeof exports&&“undefined”!=typeof module?module.exports=e():“function”==typeof define&&define.amd?define(e):t.PerfectScrollbar=e()}(this,function(){“use strict”;function t(t){return getComputedStyle(t)}function e(t,e){for(var i in e){var r=e;“number”==typeof r&&(r+=“px”),t.style=r}return t}function i(t){var e=document.createElement(“div”);return e.className=t,e}function r(t,e){if(!v)throw new Error(“No element matching method supported”);return v.call(t,e)}function l(t){t.remove?t.remove():t.parentNode&&t.parentNode.removeChild(t)}function n(t,e){return Array.prototype.filter.call(t.children,function(t){return r(t,e)})}function o(t,e){var i=t.element.classList,r=m.state.scrolling(e);i.contains®?clearTimeout(Y):i.add®}function s(t,e){Y=setTimeout(function(){return t.isAlive&&t.element.classList.remove(m.state.scrolling(e))},t.settings.scrollingThreshold)}function a(t,e){o(t,e),s(t,e)}function c(t){if(“function”==typeof window.CustomEvent)return new CustomEvent(t);var e=document.createEvent(“CustomEvent”);return e.initCustomEvent(t,!1,!1,void 0),e}function h(t,e,i,r,l){var n=i,o=i,s=i,h=i,u=i,d=i;void 0===r&&(r=!0),void 0===l&&(l=!1);var f=t.element;t.reach=null,f<1&&(t.reach=“start”),f>t-t-1&&(t.reach=“end”),e&&(f.dispatchEvent(c(“ps-scroll-”+h)),e<0?f.dispatchEvent(c("ps-scroll-"+u)):e>0&&f.dispatchEvent(c(“ps-scroll-”+d)),r&&a(t,h)),t.reach&&(e||l)&&f.dispatchEvent(c(“ps-”h“-reach-”+t.reach))}function u(t){return parseInt(t,10)||0}function d(t){return r(t,“input,”)||r(t,“select,”)||r(t,“textarea,”)||r(t,“button,”)}function f(e){var i=t(e);return u(i.width)+u(i.paddingLeft)+u(i.paddingRight)+u(i.borderLeftWidth)+u(i.borderRightWidth)}function p(t,e){return t.settings.minScrollbarLength&&(e=Math.max(e,t.settings.minScrollbarLength)),t.settings.maxScrollbarLength&&(e=Math.min(e,t.settings.maxScrollbarLength)),e}function b(t,i){var r={width:i.railXWidth},l=Math.floor(t.scrollTop);i.isRtl?r.left=i.negativeScrollAdjustment+t.scrollLeft+i.containerWidth-i.contentWidth:r.left=t.scrollLeft,i.isScrollbarXUsingBottom?r.bottom=i.scrollbarXBottom-l:r.top=i.scrollbarXTop+l,e(i.scrollbarXRail,r);var n={top:l,height:i.railYHeight};i.isScrollbarYUsingRight?i.isRtl?n.right=i.contentWidth-(i.negativeScrollAdjustment+t.scrollLeft)-i.scrollbarYRight-i.scrollbarYOuterWidth:n.right=i.scrollbarYRight-t.scrollLeft:i.isRtl?n.left=i.negativeScrollAdjustment+t.scrollLeft+2*i.containerWidth-i.contentWidth-i.scrollbarYLeft-i.scrollbarYOuterWidth:n.left=i.scrollbarYLeft+t.scrollLeft,e(i.scrollbarYRail,n),e(i.scrollbarX,{left:i.scrollbarXLeft,width:i.scrollbarXWidth-i.railBorderXWidth}),e(i.scrollbarY,{top:i.scrollbarYTop,height:i.scrollbarYHeight-i.railBorderYWidth})}function g(t,e){function i(e){b=g+Y*(e-v),o(t,f),R(t),e.stopPropagation(),e.preventDefault()}function r(){s(t,f),t.classList.remove(m.state.clicking),t.event.unbind(t.ownerDocument,“mousemove”,i)}var l=e,n=e,a=e,c=e,h=e,u=e,d=e,f=e,p=e,b=t.element,g=null,v=null,Y=null;t.event.bind(t,“mousedown”,function(e){g=b,v=e,Y=(t-t)/(t-t),t.event.bind(t.ownerDocument,“mousemove”,i),t.event.once(t.ownerDocument,“mouseup”,r),t.classList.add(m.state.clicking),e.stopPropagation(),e.preventDefault()})}var v=“undefined”!=typeof Element&&(Element.prototype.matches||Element.prototype.webkitMatchesSelector||Element.prototype.mozMatchesSelector||Element.prototype.msMatchesSelector),m={main:“ps”,element:{thumb:function(t){return“ps__thumb-”+t},rail:function(t){return“ps__rail-”+t},consuming:“ps__child–consume”},state:{focus:“ps–focus”,clicking:“ps–clicking”,active:function(t){return“ps–active-”+t},scrolling:function(t){return“ps–scrolling-”+t}}},Y={x:null,y:null},X=function(t){this.element=t,this.handlers={}},w={isEmpty:{configurable:!0}};X.prototype.bind=function(t,e){void 0===this.handlers&&(this.handlers=[]),this.handlers.push(e),this.element.addEventListener(t,e,!1)},X.prototype.unbind=function(t,e){var i=this;this.handlers=this.handlers.filter(function®{return!(!e||r===e)||(i.element.removeEventListener(t,r,!1),!1)})},X.prototype.unbindAll=function(){var t=this;for(var e in t.handlers)t.unbind(e)},w.isEmpty.get=function(){var t=this;return Object.keys(this.handlers).every(function(e){return 0===t.handlers.length})},Object.defineProperties(X.prototype,w);var y=function(){this.eventElements=[]};y.prototype.eventElement=function(t){var e=this.eventElements.filter(function(e){return e.element===t})[0];return e||(e=new X(t),this.eventElements.push(e)),e},y.prototype.bind=function(t,e,i){this.eventElement(t).bind(e,i)},y.prototype.unbind=function(t,e,i){var r=this.eventElement(t);r.unbind(e,i),r.isEmpty&&this.eventElements.splice(this.eventElements.indexOf®,1)},y.prototype.unbindAll=function(){this.eventElements.forEach(function(t){return t.unbindAll()}),this.eventElements=[]},y.prototype.once=function(t,e,i){var r=this.eventElement(t),l=function(t){r.unbind(e,l),i(t)};r.bind(e,l)};var W=function(t,e,i,r,l){void 0===r&&(r=!0),void 0===l&&(l=!1);var n;if(“top”===e)n=;else{if(“left”!==e)throw new Error(“A proper axis should be provided”);n=}h(t,i,n,r,l)},L={isWebKit:“undefined”!=typeof document&&“WebkitAppearance”in document.documentElement.style,supportsTouch:“undefined”!=typeof window&&(“ontouchstart”in window||window.DocumentTouch&&document instanceof window.DocumentTouch),supportsIePointer:“undefined”!=typeof navigator&&navigator.msMaxTouchPoints,isChrome:“undefined”!=typeof navigator&&/Chrome/i.test(navigator&&navigator.userAgent)},R=function(t){var e=t.element,i=Math.floor(e.scrollTop);t.containerWidth=e.clientWidth,t.containerHeight=e.clientHeight,t.contentWidth=e.scrollWidth,t.contentHeight=e.scrollHeight,e.contains(t.scrollbarXRail)||(n(e,m.element.rail(“x”)).forEach(function(t){return l(t)}),e.appendChild(t.scrollbarXRail)),e.contains(t.scrollbarYRail)||(n(e,m.element.rail(“y”)).forEach(function(t){return l(t)}),e.appendChild(t.scrollbarYRail)),!t.settings.suppressScrollX&&t.containerWidth+t.settings.scrollXMarginOffset<t.contentWidth?(t.scrollbarXActive=!0,t.railXWidth=t.containerWidth-t.railXMarginWidth,t.railXRatio=t.containerWidth/t.railXWidth,t.scrollbarXWidth=p(t,u(t.railXWidth*t.containerWidth/t.contentWidth)),t.scrollbarXLeft=u((t.negativeScrollAdjustment+e.scrollLeft)*(t.railXWidth-t.scrollbarXWidth)/(t.contentWidth-t.containerWidth))):t.scrollbarXActive=!1,!t.settings.suppressScrollY&&t.containerHeight+t.settings.scrollYMarginOffset<t.contentHeight?(t.scrollbarYActive=!0,t.railYHeight=t.containerHeight-t.railYMarginHeight,t.railYRatio=t.containerHeight/t.railYHeight,t.scrollbarYHeight=p(t,u(t.railYHeight*t.containerHeight/t.contentHeight)),t.scrollbarYTop=u(i*(t.railYHeight-t.scrollbarYHeight)/(t.contentHeight-t.containerHeight))):t.scrollbarYActive=!1,t.scrollbarXLeft>=t.railXWidth-t.scrollbarXWidth&&(t.scrollbarXLeft=t.railXWidth-t.scrollbarXWidth),t.scrollbarYTop>=t.railYHeight-t.scrollbarYHeight&&(t.scrollbarYTop=t.railYHeight-t.scrollbarYHeight),b(e,t),t.scrollbarXActive?e.classList.add(m.state.active(“x”)):(e.classList.remove(m.state.active(“x”)),t.scrollbarXWidth=0,t.scrollbarXLeft=0,e.scrollLeft=0),t.scrollbarYActive?e.classList.add(m.state.active(“y”)):(e.classList.remove(m.state.active(“y”)),t.scrollbarYHeight=0,t.scrollbarYTop=0,e.scrollTop=0)},T={“click-rail”:function(t){t.event.bind(t.scrollbarY,“mousedown”,function(t){return t.stopPropagation()}),t.event.bind(t.scrollbarYRail,“mousedown”,function(e){var i=e.pageY-window.pageYOffset-t.scrollbarYRail.getBoundingClientRect().top>t.scrollbarYTop?1:-1;t.element.scrollTop+=i*t.containerHeight,R(t),e.stopPropagation()}),t.event.bind(t.scrollbarX,“mousedown”,function(t){return t.stopPropagation()}),t.event.bind(t.scrollbarXRail,“mousedown”,function(e){var i=e.pageX-window.pageXOffset-t.scrollbarXRail.getBoundingClientRect().left>t.scrollbarXLeft?1:-1;t.element.scrollLeft+=i*t.containerWidth,R(t),e.stopPropagation()})},“drag-thumb”:function(t){g(t,),g(t,)},keyboard:function(t){function e(e,r){var l=Math.floor(i.scrollTop);if(0===e){if(!t.scrollbarYActive)return!1;if(0===l&&r>0||l>=t.contentHeight-t.containerHeight&&r<0)return!t.settings.wheelPropagation}var n=i.scrollLeft;if(0===r){if(!t.scrollbarXActive)return!1;if(0===n&&e<0||n>=t.contentWidth-t.containerWidth&&e>0)return!t.settings.wheelPropagation}return!0}var i=t.element,l=function(){return r(i,“:hover”)},n=function(){return r(t.scrollbarX,“:focus”)||r(t.scrollbarY,“:focus”)};t.event.bind(t.ownerDocument,“keydown”,function®{if(!(r.isDefaultPrevented&&r.isDefaultPrevented()||r.defaultPrevented)&&(l()||n())){var o=document.activeElement?document.activeElement:t.ownerDocument.activeElement;if(o){if(“IFRAME”===o.tagName)o=o.contentDocument.activeElement;else for(;o.shadowRoot;)o=o.shadowRoot.activeElement;if(d(o))return}var s=0,a=0;switch(r.which){case 37:s=r.metaKey?-t.contentWidth:r.altKey?-t.containerWidth:-30;break;case 38:a=r.metaKey?t.contentHeight:r.altKey?t.containerHeight:30;break;case 39:s=r.metaKey?t.contentWidth:r.altKey?t.containerWidth:30;break;case 40:a=r.metaKey?-t.contentHeight:r.altKey?-t.containerHeight:-30;break;case 32:a=r.shiftKey?t.containerHeight:-t.containerHeight;break;case 33:a=t.containerHeight;break;case 34:a=-t.containerHeight;break;case 36:a=t.contentHeight;break;case 35:a=-t.contentHeight;break;default:return}t.settings.suppressScrollX&&0!==s||t.settings.suppressScrollY&&0!==a||(i.scrollTop-=a,i.scrollLeft+=s,R(t),e(s,a)&&r.preventDefault())}})},wheel:function(e){function i(t,i){var r=Math.floor(o.scrollTop),l=0===o.scrollTop,n=r+o.offsetHeight===o.scrollHeight,s=0===o.scrollLeft,a=o.scrollLeft+o.offsetWidth===o.scrollWidth;return!(Math.abs(i)>Math.abs(t)?l||n:s||a)||!e.settings.wheelPropagation}function r(t){var e=t.deltaX,i=-1*t.deltaY;return void 0!==e&&void 0!==i||(e=-1*t.wheelDeltaX/6,i=t.wheelDeltaY/6),t.deltaMode&&1===t.deltaMode&&(e*=10,i*=10),e!==e&&i!==i&&(e=0,i=t.wheelDelta),t.shiftKey?:[e,i]}function l(e,i,r){if(!L.isWebKit&&o.querySelector(“select:focus”))return!0;if(!o.contains(e))return!1;for(var l=e;l&&l!==o;){if(l.classList.contains(m.element.consuming))return!0;var n=t(l);if(.join(“”).match(/(scroll|auto)/)){var s=l.scrollHeight-l.clientHeight;if(s>0&&!(0===l.scrollTop&&r>0||l.scrollTop===s&&r<0))return!0;var a=l.scrollWidth-l.clientWidth;if(a>0&&!(0===l.scrollLeft&&i<0||l.scrollLeft===a&&i>0))return!0}l=l.parentNode}return!1}function n(t){var n=r(t),s=n,a=n;if(!l(t.target,s,a)){var c=!1;e.settings.useBothWheelAxes?e.scrollbarYActive&&!e.scrollbarXActive?(a?o.scrollTop-=a*e.settings.wheelSpeed:o.scrollTop+=s*e.settings.wheelSpeed,c=!0):e.scrollbarXActive&&!e.scrollbarYActive&&(s?o.scrollLeft+=s*e.settings.wheelSpeed:o.scrollLeft-=a*e.settings.wheelSpeed,c=!0):(o.scrollTop-=a*e.settings.wheelSpeed,o.scrollLeft+=s*e.settings.wheelSpeed),R(e),(c=c||i(s,a))&&!t.ctrlKey&&(t.stopPropagation(),t.preventDefault())}}var o=e.element;void 0!==window.onwheel?e.event.bind(o,“wheel”,n):void 0!==window.onmousewheel&&e.event.bind(o,“mousewheel”,n)},touch:function(e){function i(t,i){var r=Math.floor(h.scrollTop),l=h.scrollLeft,n=Math.abs(t),o=Math.abs(i);if(o>n){if(i<0&&r===e.contentHeight-e.containerHeight||i>0&&0===r)return 0===window.scrollY&&i>0&&L.isChrome}else if(n>o&&(t<0&&l===e.contentWidth-e.containerWidth||t>0&&0===l))return!0;return!0}function r(t,i){h.scrollTop-=i,h.scrollLeft-=t,R(e)}function l(t){return t.targetTouches?t.targetTouches:t}function n(t){return!(t.pointerType&&“pen”===t.pointerType&&0===t.buttons||(!t.targetTouches||1!==t.targetTouches.length)&&(!t.pointerType||“mouse”===t.pointerType||t.pointerType===t.MSPOINTER_TYPE_MOUSE))}function o(t){if(n(t)){var e=l(t);u.pageX=e.pageX,u.pageY=e.pageY,d=(new Date).getTime(),null!==p&&clearInterval(p)}}function s(e,i,r){if(!h.contains(e))return!1;for(var l=e;l&&l!==h;){if(l.classList.contains(m.element.consuming))return!0;var n=t(l);if(.join(“”).match(/(scroll|auto)/)){var o=l.scrollHeight-l.clientHeight;if(o>0&&!(0===l.scrollTop&&r>0||l.scrollTop===o&&r<0))return!0;var s=l.scrollLeft-l.clientWidth;if(s>0&&!(0===l.scrollLeft&&i<0||l.scrollLeft===s&&i>0))return!0}l=l.parentNode}return!1}function a(t){if(n(t)){var e=l(t),o={pageX:e.pageX,pageY:e.pageY},a=o.pageX-u.pageX,c=o.pageY-u.pageY;if(s(t.target,a,c))return;r(a,c),u=o;var h=(new Date).getTime(),p=h-d;p>0&&(f.x=a/p,f.y=c/p,d=h),i(a,c)&&t.preventDefault()}}function c(){e.settings.swipeEasing&&(clearInterval(p),p=setInterval(function(){e.isInitialized?clearInterval(p):f.x||f.y?Math.abs(f.x)<.01&&Math.abs(f.y)<.01?clearInterval(p):(r(30*f.x,30*f.y),f.x*=.8,f.y*=.8):clearInterval(p)},10))}if(L.supportsTouch||L.supportsIePointer){var h=e.element,u={},d=0,f={},p=null;L.supportsTouch?(e.event.bind(h,“touchstart”,o),e.event.bind(h,“touchmove”,a),e.event.bind(h,“touchend”,c)):L.supportsIePointer&&(window.PointerEvent?(e.event.bind(h,“pointerdown”,o),e.event.bind(h,“pointermove”,a),e.event.bind(h,“pointerup”,c)):window.MSPointerEvent&&(e.event.bind(h,“MSPointerDown”,o),e.event.bind(h,“MSPointerMove”,a),e.event.bind(h,“MSPointerUp”,c)))}}},H=function(r,l){var n=this;if(void 0===l&&(l={}),“string”==typeof r&&(r=document.querySelector®),!r||!r.nodeName)throw new Error(“no element is specified to initialize PerfectScrollbar”);this.element=r,r.classList.add(m.main),this.settings={handlers:,maxScrollbarLength:null,minScrollbarLength:null,scrollingThreshold:1e3,scrollXMarginOffset:0,scrollYMarginOffset:0,suppressScrollX:!1,suppressScrollY:!1,swipeEasing:!0,useBothWheelAxes:!1,wheelPropagation:!0,wheelSpeed:1};for(var o in l)n.settings=l;this.containerWidth=null,this.containerHeight=null,this.contentWidth=null,this.contentHeight=null;var s=function(){return r.classList.add(m.state.focus)},a=function(){return r.classList.remove(m.state.focus)};this.isRtl=“rtl”===t®.direction,this.isNegativeScroll=function(){var t=r.scrollLeft,e=null;return r.scrollLeft=-1,e=r.scrollLeft<0,r.scrollLeft=t,e}(),this.negativeScrollAdjustment=this.isNegativeScroll?r.scrollWidth-r.clientWidth:0,this.event=new y,this.ownerDocument=r.ownerDocument||document,this.scrollbarXRail=i(m.element.rail(“x”)),r.appendChild(this.scrollbarXRail),this.scrollbarX=i(m.element.thumb(“x”)),this.scrollbarXRail.appendChild(this.scrollbarX),this.scrollbarX.setAttribute(“tabindex”,0),this.event.bind(this.scrollbarX,“focus”,s),this.event.bind(this.scrollbarX,“blur”,a),this.scrollbarXActive=null,this.scrollbarXWidth=null,this.scrollbarXLeft=null;var c=t(this.scrollbarXRail);this.scrollbarXBottom=parseInt(c.bottom,10),isNaN(this.scrollbarXBottom)?(this.isScrollbarXUsingBottom=!1,this.scrollbarXTop=u(c.top)):this.isScrollbarXUsingBottom=!0,this.railBorderXWidth=u(c.borderLeftWidth)+u(c.borderRightWidth),e(this.scrollbarXRail,{display:“block”}),this.railXMarginWidth=u(c.marginLeft)+u(c.marginRight),e(this.scrollbarXRail,{display:“”}),this.railXWidth=null,this.railXRatio=null,this.scrollbarYRail=i(m.element.rail(“y”)),r.appendChild(this.scrollbarYRail),this.scrollbarY=i(m.element.thumb(“y”)),this.scrollbarYRail.appendChild(this.scrollbarY),this.scrollbarY.setAttribute(“tabindex”,0),this.event.bind(this.scrollbarY,“focus”,s),this.event.bind(this.scrollbarY,“blur”,a),this.scrollbarYActive=null,this.scrollbarYHeight=null,this.scrollbarYTop=null;var h=t(this.scrollbarYRail);this.scrollbarYRight=parseInt(h.right,10),isNaN(this.scrollbarYRight)?(this.isScrollbarYUsingRight=!1,this.scrollbarYLeft=u(h.left)):this.isScrollbarYUsingRight=!0,this.scrollbarYOuterWidth=this.isRtl?f(this.scrollbarY):null,this.railBorderYWidth=u(h.borderTopWidth)+u(h.borderBottomWidth),e(this.scrollbarYRail,{display:“block”}),this.railYMarginHeight=u(h.marginTop)+u(h.marginBottom),e(this.scrollbarYRail,{display:“”}),this.railYHeight=null,this.railYRatio=null,this.reach={x:r.scrollLeft<=0?“start”:r.scrollLeft>=this.contentWidth-this.containerWidth?“end”:null,y:r.scrollTop<=0?“start”:r.scrollTop>=this.contentHeight-this.containerHeight?“end”:null},this.isAlive=!0,this.settings.handlers.forEach(function(t){return T(n)}),this.lastScrollTop=Math.floor(r.scrollTop),this.lastScrollLeft=r.scrollLeft,this.event.bind(this.element,“scroll”,function(t){return n.onScroll(t)}),R(this)};return H.prototype.update=function(){this.isAlive&&(this.negativeScrollAdjustment=this.isNegativeScroll?this.element.scrollWidth-this.element.clientWidth:0,e(this.scrollbarXRail,{display:“block”}),e(this.scrollbarYRail,{display:“block”}),this.railXMarginWidth=u(t(this.scrollbarXRail).marginLeft)+u(t(this.scrollbarXRail).marginRight),this.railYMarginHeight=u(t(this.scrollbarYRail).marginTop)+u(t(this.scrollbarYRail).marginBottom),e(this.scrollbarXRail,{display:“none”}),e(this.scrollbarYRail,{display:“none”}),R(this),W(this,“top”,0,!1,!0),W(this,“left”,0,!1,!0),e(this.scrollbarXRail,{display:“”}),e(this.scrollbarYRail,{display:“”}))},H.prototype.onScroll=function(t){this.isAlive&&(R(this),W(this,“top”,this.element.scrollTop-this.lastScrollTop),W(this,“left”,this.element.scrollLeft-this.lastScrollLeft),this.lastScrollTop=Math.floor(this.element.scrollTop),this.lastScrollLeft=this.element.scrollLeft)},H.prototype.destroy=function(){this.isAlive&&(this.event.unbindAll(),l(this.scrollbarX),l(this.scrollbarY),l(this.scrollbarXRail),l(this.scrollbarYRail),this.removePsClasses(),this.element=null,this.scrollbarX=null,this.scrollbarY=null,this.scrollbarXRail=null,this.scrollbarYRail=null,this.isAlive=!1)},H.prototype.removePsClasses=function(){this.element.className=this.element.className.split(“ ”).filter(function(t){return!t.match(/^ps(.+|)$/)}).join(“ ”)},H}); “use strict”; 'use scrict';

function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(“Cannot call a class as a function”); } }

function _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (“value” in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } }

function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; }

(function ($) {

$(document).ready(function () {
  $(document).on('click', '.chip .close', function () {
    var $this = $(this);

    if ($this.closest('.chips').data('initialized')) {
      return;
    }

    $this.closest('.chip').remove();
  });
});

var MaterialChip =
/*#__PURE__*/
function () {
  function MaterialChip(chips, options) {
    _classCallCheck(this, MaterialChip);

    this.chips = chips;
    this.$document = $(document);
    this.options = options;
    this.eventsHandled = false;
    this.ulWrapper = $('<ul class="chip-ul z-depth-1"></ul>');
    this.defaultOptions = {
      data: [],
      dataChip: [],
      placeholder: '',
      secondaryPlaceholder: ''
    };
    this.selectors = {
      chips: '.chips',
      chip: '.chip',
      input: 'input',
      delete: '.fas',
      selectedChip: '.selected'
    };
    this.keyCodes = {
      enter: 13,
      backspace: 8,
      delete: 46,
      arrowLeft: 37,
      arrowRight: 39,
      comma: 188
    };
    this.init();
  }

  _createClass(MaterialChip, [{
    key: "init",
    value: function init() {
      var _this = this;

      this.optionsDataStatement();
      this.assignOptions();
      this.chips.each(function (index, element) {
        var $this = $(element);

        if ($this.data('initialized')) {
          return;
        }

        var options = $this.data('options');

        if (!options.data || !Array.isArray(options.data)) {
          options.data = [];
        }

        $this.data('chips', options.data);
        $this.data('index', index);
        $this.data('initialized', true);

        if (!$this.hasClass(_this.selectors.chips)) {
          $this.addClass('chips');
        }

        _this.renderChips($this);
      });

      if (!this.eventsHandled) {
        this.handleEvents();
        this.eventsHandled = true;
      }

      return this;
    }
  }, {
    key: "optionsDataStatement",
    value: function optionsDataStatement() {
      if (this.options === 'data') {
        return this.chips.data('chips');
      }

      if (this.options === 'options') {
        return this.chips.data('options');
      }

      return true;
    }
  }, {
    key: "assignOptions",
    value: function assignOptions() {
      this.chips.data('options', $.extend({}, this.defaultOptions, this.options));
    }
  }, {
    key: "handleEvents",
    value: function handleEvents() {
      this.handleSelecorChips();
      this.handleBlurInput();
      this.handleSelectorChip();
      this.handleDocumentKeyDown();
      this.handleDocumentFocusIn();
      this.handleDocumentFocusOut();
      this.handleDocumentKeyDownChipsInput();
      this.handleDocumentClickChipsDelete();
      this.inputKeyDown();
      this.renderedLiClick();
      this.dynamicInputChanges();
    }
  }, {
    key: "handleSelecorChips",
    value: function handleSelecorChips() {
      var _this2 = this;

      this.$document.on('click', this.selectors.chips, function (e) {
        return $(e.target).find(_this2.selectors.input).focus();
      });
    }
  }, {
    key: "handleBlurInput",
    value: function handleBlurInput() {
      var _this3 = this;

      this.$document.on('blur', this.selectors.chips, function () {
        return setTimeout(function () {
          return _this3.ulWrapper.hide();
        }, 100);
      });
    }
  }, {
    key: "handleSelectorChip",
    value: function handleSelectorChip() {
      this.chips.on('click', '.chip', function (e) {
        return $(e.target).removeClass('selected').addClass('selected');
      });
    }
  }, {
    key: "handleDocumentKeyDown",
    value: function handleDocumentKeyDown() {
      var _this4 = this;

      this.$document.on('keydown', function (e) {
        if ($(e.target).is('input, textarea')) {
          return;
        }

        var $selectedChip = _this4.$document.find(_this4.selectors.chip + _this4.selectors.selectedChip);

        var $chipsWrapper = $selectedChip.closest(_this4.selectors.chips);
        var siblingsLength = $selectedChip.siblings(_this4.selectors.chip).length;

        if (!$selectedChip.length) {
          return;
        }

        var backspacePressed = e.which === _this4.keyCodes.backspace;
        var deletePressed = e.which === _this4.keyCodes.delete;
        var leftArrowPressed = e.which === _this4.keyCodes.arrowLeft;
        var rightArrowPressed = e.which === _this4.keyCodes.arrowRight;

        if (backspacePressed || deletePressed) {
          e.preventDefault();

          _this4.deleteSelectedChip($chipsWrapper, $selectedChip, siblingsLength);
        } else if (leftArrowPressed) {
          _this4.selectLeftChip($chipsWrapper, $selectedChip);
        } else if (rightArrowPressed) {
          _this4.selectRightChip($chipsWrapper, $selectedChip, siblingsLength);
        }
      });
    }
  }, {
    key: "handleDocumentFocusIn",
    value: function handleDocumentFocusIn() {
      var _this5 = this;

      var $chipsInput;
      var $chips = this.chips;

      if ($chips.hasClass('chips-autocomplete')) {
        $chipsInput = $chips.children().children('input');
      } else {
        $chipsInput = $chips.children('input');
      }

      $chipsInput.on('click', function (e) {
        $(e.target).closest(_this5.selectors.chips).addClass('focus');
        $(_this5.selectors.chip).removeClass('selected');
      });
    }
  }, {
    key: "handleDocumentFocusOut",
    value: function handleDocumentFocusOut() {
      var _this6 = this;

      this.$document.on('focusout', "".concat(this.selectors.chips, " ").concat(this.selectors.input), function (e) {
        return $(e.target).closest(_this6.selectors.chips).removeClass('focus');
      });
    }
  }, {
    key: "handleDocumentKeyDownChipsInput",
    value: function handleDocumentKeyDownChipsInput() {
      var _this7 = this;

      this.$document.on('keydown', "".concat(this.selectors.chips, " ").concat(this.selectors.input), function (e) {
        var $target = $(e.target);
        var $chipsWrapper = $target.closest(_this7.selectors.chips);
        var chipsIndex = $chipsWrapper.data('index');
        var chipsLength = $chipsWrapper.children(_this7.selectors.chip).length;
        var enterPressed = e.which === _this7.keyCodes.enter;
        var commaPressed = e.which === _this7.keyCodes.comma;

        if (enterPressed || commaPressed) {
          e.preventDefault();

          _this7.addChip(chipsIndex, {
            tag: $target.val()
          }, $chipsWrapper);

          $target.val('');
          return;
        }

        var leftArrowOrDeletePressed = e.keyCode === _this7.keyCodes.arrowLeft || e.keyCode === _this7.keyCodes.delete;
        var isValueEmpty = $target.val() === '';

        if (leftArrowOrDeletePressed && isValueEmpty && chipsLength) {
          _this7.selectChip(chipsIndex, chipsLength - 1, $chipsWrapper);

          $target.blur();
        }
      });
    }
  }, {
    key: "handleDocumentClickChipsDelete",
    value: function handleDocumentClickChipsDelete() {
      var _this8 = this;

      this.chips.on('click', '.chip .fas', function (e) {
        var $target = $(e.target);
        var $chip = $target.parent($(_this8.chips));
        var $chipsWrapper;

        if ($chip.parents().eq(1).hasClass('chips-autocomplete')) {
          $chipsWrapper = $chip.parents().eq(1);
        } else if (!$chip.parent().hasClass('chips-autocomplete') && !$chip.parents().eq(1).hasClass('chips-autocomplete')) {
          $chipsWrapper = $chip.parents().eq(0);
        } else if ($chip.parent().hasClass('chips-initial') && $chip.parent().hasClass('chips-autocomplete')) {
          $chipsWrapper = $chip.parents().eq(0);
        }

        _this8.deleteChip($chipsWrapper.data('index'), $chip.index(), $chipsWrapper);

        $chipsWrapper.find('input').focus();
      });
    }
  }, {
    key: "inputKeyDown",
    value: function inputKeyDown() {
      var _this9 = this;

      var $ulWrapper = this.ulWrapper;
      var dataChip = this.options.dataChip;
      var $thisChups = this.chips;
      var $input = $thisChups.children('.chip-position-wrapper').children('input');
      $input.on('keyup', function (e) {
        var $inputValue = $input.val();
        $ulWrapper.empty();

        if ($inputValue.length) {
          for (var item in dataChip) {
            if (dataChip[item].toLowerCase().includes($inputValue.toLowerCase())) {
              $thisChups.children('.chip-position-wrapper').append($ulWrapper.append($("<li>".concat(dataChip[item], "</li>"))));
            }
          }
        }

        if (e.which === _this9.keyCodes.enter) {
          $ulWrapper.empty();
          $thisChups.children(':first').trigger('click');
          $ulWrapper.remove();
        } // eslint-disable-next-line no-unused-expressions

        $inputValue.length === 0 ? $ulWrapper.hide() : $ulWrapper.show();
      });
    }
  }, {
    key: "dynamicInputChanges",
    value: function dynamicInputChanges() {
      var dataChip = this.options.dataChip;

      if (dataChip !== undefined) {
        this.chips.children('.chip-position-wrapper').children('input').on('change', function (e) {
          var $targetVal = $(e.target).val();

          if (!dataChip.includes($targetVal)) {
            dataChip.push($targetVal);
            dataChip.sort();
          }
        });
      }
    }
  }, {
    key: "renderedLiClick",
    value: function renderedLiClick() {
      var _this10 = this;

      this.chips.on('click', 'li', function (e) {
        e.preventDefault();
        var $target = $(e.target);
        var $chipsWrapper = $target.closest($(_this10.selectors.chips));
        var chipsIndex = $chipsWrapper.data('index');

        _this10.addChip(chipsIndex, {
          tag: $target.text()
        }, $chipsWrapper);

        _this10.chips.children('.chip-position-wrapper').children('input').val('');

        _this10.ulWrapper.remove();
      });
    }
  }, {
    key: "deleteSelectedChip",
    value: function deleteSelectedChip($chipsWrapper, $selectedChip, siblingsLength) {
      var chipsIndex = $chipsWrapper.data('index');
      var chipIndex = $selectedChip.index();
      this.deleteChip(chipsIndex, chipIndex, $chipsWrapper);
      var selectIndex = null;

      if (chipIndex < siblingsLength - 1) {
        selectIndex = chipIndex;
      } else if (chipIndex === siblingsLength || chipIndex === siblingsLength - 1) {
        selectIndex = siblingsLength - 1;
      }

      if (selectIndex < 0) {
        selectIndex = null;
      }

      if (selectIndex !== null) {
        this.selectChip(chipsIndex, selectIndex, $chipsWrapper);
      }

      if (!siblingsLength) {
        $chipsWrapper.find('input').focus();
      }
    }
  }, {
    key: "selectLeftChip",
    value: function selectLeftChip($chipsWrapper, $selectedChip) {
      var chipIndex = $selectedChip.index() - 1;

      if (chipIndex < 0) {
        return;
      }

      $(this.selectors.chip).removeClass('selected');
      this.selectChip($chipsWrapper.data('index'), chipIndex, $chipsWrapper);
    }
  }, {
    key: "selectRightChip",
    value: function selectRightChip($chipsWrapper, $selectedChip, siblingsLength) {
      var chipIndex = $selectedChip.index() + 1;
      $(this.selectors.chip).removeClass('selected');

      if (chipIndex > siblingsLength) {
        $chipsWrapper.find('input').focus();
        return;
      }

      this.selectChip($chipsWrapper.data('index'), chipIndex, $chipsWrapper);
    }
  }, {
    key: "renderChips",
    value: function renderChips($chipsWrapper) {
      var _this11 = this;

      var html = '';
      $chipsWrapper.data('chips').forEach(function (elem) {
        html += _this11.getSingleChipHtml(elem);
      });

      if ($chipsWrapper.hasClass('chips-autocomplete')) {
        html += '<span class="chip-position-wrapper position-relative"><input class="input" placeholder=""></span>';
      } else {
        html += '<input class="input" placeholder="">';
      }

      $chipsWrapper.html(html);
      this.setPlaceholder($chipsWrapper);
    }
  }, {
    key: "getSingleChipHtml",
    value: function getSingleChipHtml(elem) {
      if (!elem.tag) {
        return '';
      }

      var html = "<div class=\"chip\">".concat(elem.tag);

      if (elem.image) {
        html += " <img src=\"".concat(elem.image, "\"> ");
      }

      html += '<i class="close fas fa-times"></i>';
      html += '</div>';
      return html;
    }
  }, {
    key: "setPlaceholder",
    value: function setPlaceholder($chips) {
      var options = $chips.data('options');

      if ($chips.data('chips').length && options.placeholder) {
        $chips.find('input').prop('placeholder', options.placeholder);
      } else if (!$chips.data('chips').length && options.secondaryPlaceholder) {
        $chips.find('input').prop('placeholder', options.secondaryPlaceholder);
      }
    }
  }, {
    key: "isValid",
    value: function isValid($chipsWrapper, elem) {
      var chips = $chipsWrapper.data('chips');

      for (var i = 0; i < chips.length; i++) {
        if (chips[i].tag === elem.tag) {
          return false;
        }
      }

      return elem.tag !== '';
    }
  }, {
    key: "addChip",
    value: function addChip(chipsIndex, elem, $chipsWrapper) {
      if (!this.isValid($chipsWrapper, elem)) {
        return;
      }

      var $chipHtml = $(this.getSingleChipHtml(elem));
      $chipsWrapper.data('chips').push(elem);

      if ($chipsWrapper.hasClass('chips-autocomplete') && $chipsWrapper.hasClass('chips-initial') && $chipsWrapper.find('.chip').length > 0) {
        $chipHtml.insertAfter($chipsWrapper.find('.chip').last());
      } else {
        $chipHtml.insertBefore($chipsWrapper.find('input'));
      }

      $chipsWrapper.trigger('chip.add', elem);
      this.setPlaceholder($chipsWrapper);
    }
  }, {
    key: "deleteChip",
    value: function deleteChip(chipsIndex, chipIndex, $chipsWrapper) {
      var chip = $chipsWrapper.data('chips')[chipIndex];
      $chipsWrapper.find('.chip').eq(chipIndex).remove();
      $chipsWrapper.data('chips').splice(chipIndex, 1);
      $chipsWrapper.trigger('chip.delete', chip);
      this.setPlaceholder($chipsWrapper);
    }
  }, {
    key: "selectChip",
    value: function selectChip(chipsIndex, chipIndex, $chipsWrapper) {
      var $chip = $chipsWrapper.find('.chip').eq(chipIndex);

      if ($chip && $chip.hasClass('selected') === false) {
        $chip.addClass('selected');
        $chipsWrapper.trigger('chip.select', $chipsWrapper.data('chips')[chipIndex]);
      }
    }
  }, {
    key: "getChipsElement",
    value: function getChipsElement(index, $chipsWrapper) {
      return $chipsWrapper.eq(index);
    }
  }]);

  return MaterialChip;
}();

$.fn.materialChip = function (options) {
  return this.each(function () {
    new MaterialChip($(this), options);
  });
};

})(jQuery); /*!

* Name    : Just Another Parallax [Jarallax]
* Version : 1.10.4
* Author  : nK <https://nkdev.info>
* GitHub  : https://github.com/nk-o/jarallax
*/

/******/ (function(modules) { // webpackBootstrap /******/ // The module cache /******/ var installedModules = {}; /******/ /******/ // The require function /******/ function webpack_require(moduleId) { /******/ /******/ // Check if module is in cache /******/ if(installedModules) { /******/ return installedModules.exports; /******/ } /******/ // Create a new module (and put it into the cache) /******/ var module = installedModules = { /******/ i: moduleId, /******/ l: false, /******/ exports: {} /******/ }; /******/ /******/ // Execute the module function /******/ modules.call(module.exports, module, module.exports, webpack_require); /******/ /******/ // Flag the module as loaded /******/ module.l = true; /******/ /******/ // Return the exports of the module /******/ return module.exports; /******/ } /******/ /******/ /******/ // expose the modules object (webpack_modules) /******/ webpack_require.m = modules; /******/ /******/ // expose the module cache /******/ webpack_require.c = installedModules; /******/ /******/ // define getter function for harmony exports /******/ webpack_require.d = function(exports, name, getter) { /******/ if(!webpack_require.o(exports, name)) { /******/ Object.defineProperty(exports, name, { enumerable: true, get: getter }); /******/ } /******/ }; /******/ /******/ // define __esModule on exports /******/ webpack_require.r = function(exports) { /******/ if(typeof Symbol !== 'undefined' && Symbol.toStringTag) { /******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' }); /******/ } /******/ Object.defineProperty(exports, '__esModule', { value: true }); /******/ }; /******/ /******/ // create a fake namespace object /******/ // mode & 1: value is a module id, require it /******/ // mode & 2: merge all properties of value into the ns /******/ // mode & 4: return value when already ns object /******/ // mode & 8|1: behave like require /******/ webpack_require.t = function(value, mode) { /******/ if(mode & 1) value = webpack_require(value); /******/ if(mode & 8) return value; /******/ if((mode & 4) && typeof value === 'object' && value && value.__esModule) return value; /******/ var ns = Object.create(null); /******/ webpack_require.r(ns); /******/ Object.defineProperty(ns, 'default', { enumerable: true, value: value }); /******/ if(mode & 2 && typeof value != 'string') for(var key in value) webpack_require.d(ns, key, function(key) { return value; }.bind(null, key)); /******/ return ns; /******/ }; /******/ /******/ // getDefaultExport function for compatibility with non-harmony modules /******/ webpack_require.n = function(module) { /******/ var getter = module && module.__esModule ? /******/ function getDefault() { return module; } : /******/ function getModuleExports() { return module; }; /******/ webpack_require.d(getter, 'a', getter); /******/ return getter; /******/ }; /******/ /******/ // Object.prototype.hasOwnProperty.call /******/ webpack_require.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); }; /******/ /******/ // webpack_public_path /******/ webpack_require.p = “”; /******/ /******/ /******/ // Load entry module and return exports /******/ return webpack_require(_webpack_require_.s = 11); /******/ }) /************************************************************************/ /******/ ([ /* 0 */, /* 1 */, /* 2 */ /***/ (function(module, exports, webpack_require) {

“use strict”;

module.exports = function (callback) {

if (document.readyState === 'complete' || document.readyState === 'interactive') {
        // Already ready or interactive, execute callback
        callback.call();
} else if (document.attachEvent) {
        // Old browsers
        document.attachEvent('onreadystatechange', function () {
                if (document.readyState === 'interactive') callback.call();
        });
} else if (document.addEventListener) {
        // Modern browsers
        document.addEventListener('DOMContentLoaded', callback);
}

};

/***/ }), /* 3 */, /* 4 */ /***/ (function(module, exports, webpack_require) {

“use strict”; /* WEBPACK VAR INJECTION */(function(global) {

var win;

if (typeof window !== “undefined”) {

win = window;

} else if (typeof global !== “undefined”) {

win = global;

} else if (typeof self !== “undefined”) {

win = self;

} else {

win = {};

}

module.exports = win; /* WEBPACK VAR INJECTION */}.call(this, webpack_require(5)))

/***/ }), /* 5 */ /***/ (function(module, exports, webpack_require) {

“use strict”;

var _typeof = typeof Symbol === “function” && typeof Symbol.iterator === “symbol” ? function (obj) { return typeof obj; } : function (obj) { return obj && typeof Symbol === “function” && obj.constructor === Symbol && obj !== Symbol.prototype ? “symbol” : typeof obj; };

var g;

// This works in non-strict mode g = function () {

return this;

}();

try {

// This works if eval is allowed (see CSP)
g = g || Function("return this")() || (1, eval)("this");

} catch (e) {

// This works if the window reference is available
if ((typeof window === "undefined" ? "undefined" : _typeof(window)) === "object") g = window;

}

// g can still be undefined, but nothing to do about it… // We return undefined, instead of nothing here, so it's // easier to handle this case. if(!global) { …}

module.exports = g;

/***/ }), /* 6 */, /* 7 */, /* 8 */, /* 9 */, /* 10 */, /* 11 */ /***/ (function(module, exports, webpack_require) {

module.exports = webpack_require(12);

/***/ }), /* 12 */ /***/ (function(module, exports, webpack_require) {

“use strict”;

var _typeof = typeof Symbol === “function” && typeof Symbol.iterator === “symbol” ? function (obj) { return typeof obj; } : function (obj) { return obj && typeof Symbol === “function” && obj.constructor === Symbol && obj !== Symbol.prototype ? “symbol” : typeof obj; };

var _liteReady = webpack_require(2);

var _liteReady2 = _interopRequireDefault(_liteReady);

var _global = webpack_require(4);

var _jarallax = webpack_require(13);

var _jarallax2 = _interopRequireDefault(_jarallax);

function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }

// no conflict var oldPlugin = _global.window.jarallax; _global.window.jarallax = _jarallax2.default; _global.window.jarallax.noConflict = function () {

_global.window.jarallax = oldPlugin;
return this;

};

// jQuery support if (typeof _global.jQuery !== 'undefined') {

var jQueryPlugin = function jQueryPlugin() {
    var args = arguments || [];
    Array.prototype.unshift.call(args, this);
    var res = _jarallax2.default.apply(_global.window, args);
    return (typeof res === 'undefined' ? 'undefined' : _typeof(res)) !== 'object' ? res : this;
};
jQueryPlugin.constructor = _jarallax2.default.constructor;

// no conflict
var oldJqPlugin = _global.jQuery.fn.jarallax;
_global.jQuery.fn.jarallax = jQueryPlugin;
_global.jQuery.fn.jarallax.noConflict = function () {
    _global.jQuery.fn.jarallax = oldJqPlugin;
    return this;
};

}

// data-jarallax initialization (0, _liteReady2.default)(function () {

(0, _jarallax2.default)(document.querySelectorAll('[data-jarallax]'));

});

/***/ }), /* 13 */ /***/ (function(module, exports, webpack_require) {

“use strict”; /* WEBPACK VAR INJECTION */(function(global) {

Object.defineProperty(exports, “__esModule”, {

value: true

});

var _slicedToArray = function () { function sliceIterator(arr, i) { var _arr = []; var _n = true; var _d = false; var _e = undefined; try { for (var _i = arr(), _s; !(_n = (_s = _i.next()).done); _n = true) { _arr.push(_s.value); if (i && _arr.length === i) break; } } catch (err) { _d = true; _e = err; } finally { try { if (!_n && _i) _i(); } finally { if (_d) throw _e; } } return _arr; } return function (arr, i) { if (Array.isArray(arr)) { return arr; } else if (Symbol.iterator in Object(arr)) { return sliceIterator(arr, i); } else { throw new TypeError(“Invalid attempt to destructure non-iterable instance”); } }; }();

var _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (“value” in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();

var _typeof = typeof Symbol === “function” && typeof Symbol.iterator === “symbol” ? function (obj) { return typeof obj; } : function (obj) { return obj && typeof Symbol === “function” && obj.constructor === Symbol && obj !== Symbol.prototype ? “symbol” : typeof obj; };

var _liteReady = webpack_require(2);

var _liteReady2 = _interopRequireDefault(_liteReady);

var _rafl = webpack_require(14);

var _rafl2 = _interopRequireDefault(_rafl);

var _global = webpack_require(4);

function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }

function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(“Cannot call a class as a function”); } }

var isIE = navigator.userAgent.indexOf('MSIE ') > -1 || navigator.userAgent.indexOf('Trident/') > -1 || navigator.userAgent.indexOf('Edge/') > -1;

var supportTransform = function () {

var prefixes = 'transform WebkitTransform MozTransform'.split(' ');
var div = document.createElement('div');
for (var i = 0; i < prefixes.length; i++) {
    if (div && div.style[prefixes[i]] !== undefined) {
        return prefixes[i];
    }
}
return false;

}();

// Window data var wndW = void 0; var wndH = void 0; var wndY = void 0; var forceResizeParallax = false; var forceScrollParallax = false; function updateWndVars(e) {

wndW = _global.window.innerWidth || document.documentElement.clientWidth;
wndH = _global.window.innerHeight || document.documentElement.clientHeight;
if ((typeof e === 'undefined' ? 'undefined' : _typeof(e)) === 'object' && (e.type === 'load' || e.type === 'dom-loaded')) {
    forceResizeParallax = true;
}

} updateWndVars(); _global.window.addEventListener('resize', updateWndVars); _global.window.addEventListener('orientationchange', updateWndVars); _global.window.addEventListener('load', updateWndVars); (0, _liteReady2.default)(function () {

updateWndVars({
    type: 'dom-loaded'
});

});

// list with all jarallax instances // need to render all in one scroll/resize event var jarallaxList = [];

// Animate if changed window size or scrolled page var oldPageData = false; function updateParallax() {

if (!jarallaxList.length) {
    return;
}

if (_global.window.pageYOffset !== undefined) {
    wndY = _global.window.pageYOffset;
} else {
    wndY = (document.documentElement || document.body.parentNode || document.body).scrollTop;
}

var isResized = forceResizeParallax || !oldPageData || oldPageData.width !== wndW || oldPageData.height !== wndH;
var isScrolled = forceScrollParallax || isResized || !oldPageData || oldPageData.y !== wndY;

forceResizeParallax = false;
forceScrollParallax = false;

if (isResized || isScrolled) {
    jarallaxList.forEach(function (item) {
        if (isResized) {
            item.onResize();
        }
        if (isScrolled) {
            item.onScroll();
        }
    });

    oldPageData = {
        width: wndW,
        height: wndH,
        y: wndY
    };
}

(0, _rafl2.default)(updateParallax);

}

// ResizeObserver var resizeObserver = global.ResizeObserver ? new global.ResizeObserver(function (entry) {

if (entry && entry.length) {
    (0, _rafl2.default)(function () {
        entry.forEach(function (item) {
            if (item.target && item.target.jarallax) {
                if (!forceResizeParallax) {
                    item.target.jarallax.onResize();
                }
                forceScrollParallax = true;
            }
        });
    });
}

}) : false;

var instanceID = 0;

// Jarallax class

var Jarallax = function () {

function Jarallax(item, userOptions) {
    _classCallCheck(this, Jarallax);

    var self = this;

    self.instanceID = instanceID++;

    self.$item = item;

    self.defaults = {
        type: 'scroll', // type of parallax: scroll, scale, opacity, scale-opacity, scroll-opacity
        speed: 0.5, // supported value from -1 to 2
        imgSrc: null,
        imgElement: '.jarallax-img',
        imgSize: 'cover',
        imgPosition: '50% 50%',
        imgRepeat: 'no-repeat', // supported only for background, not for <img> tag
        keepImg: false, // keep <img> tag in it's default place
        elementInViewport: null,
        zIndex: -100,
        disableParallax: false,
        disableVideo: false,
        automaticResize: true, // use ResizeObserver to recalculate position and size of parallax image

        // video
        videoSrc: null,
        videoStartTime: 0,
        videoEndTime: 0,
        videoVolume: 0,
        videoPlayOnlyVisible: true,

        // events
        onScroll: null, // function(calculations) {}
        onInit: null, // function() {}
        onDestroy: null, // function() {}
        onCoverImage: null // function() {}
    };

    // DEPRECATED: old data-options
    var deprecatedDataAttribute = self.$item.getAttribute('data-jarallax');
    var oldDataOptions = JSON.parse(deprecatedDataAttribute || '{}');
    if (deprecatedDataAttribute) {
        // eslint-disable-next-line no-console
        console.warn('Detected usage of deprecated data-jarallax JSON options, you should use pure data-attribute options. See info here - https://github.com/nk-o/jarallax/issues/53');
    }

    // prepare data-options
    var dataOptions = self.$item.dataset || {};
    var pureDataOptions = {};
    Object.keys(dataOptions).forEach(function (key) {
        var loweCaseOption = key.substr(0, 1).toLowerCase() + key.substr(1);
        if (loweCaseOption && typeof self.defaults[loweCaseOption] !== 'undefined') {
            pureDataOptions[loweCaseOption] = dataOptions[key];
        }
    });

    self.options = self.extend({}, self.defaults, oldDataOptions, pureDataOptions, userOptions);
    self.pureOptions = self.extend({}, self.options);

    // prepare 'true' and 'false' strings to boolean
    Object.keys(self.options).forEach(function (key) {
        if (self.options[key] === 'true') {
            self.options[key] = true;
        } else if (self.options[key] === 'false') {
            self.options[key] = false;
        }
    });

    // fix speed option [-1.0, 2.0]
    self.options.speed = Math.min(2, Math.max(-1, parseFloat(self.options.speed)));

    // deprecated noAndroid and noIos options
    if (self.options.noAndroid || self.options.noIos) {
        // eslint-disable-next-line no-console
        console.warn('Detected usage of deprecated noAndroid or noIos options, you should use disableParallax option. See info here - https://github.com/nk-o/jarallax/#disable-on-mobile-devices');

        // prepare fallback if disableParallax option is not used
        if (!self.options.disableParallax) {
            if (self.options.noIos && self.options.noAndroid) {
                self.options.disableParallax = /iPad|iPhone|iPod|Android/;
            } else if (self.options.noIos) {
                self.options.disableParallax = /iPad|iPhone|iPod/;
            } else if (self.options.noAndroid) {
                self.options.disableParallax = /Android/;
            }
        }
    }

    // prepare disableParallax callback
    if (typeof self.options.disableParallax === 'string') {
        self.options.disableParallax = new RegExp(self.options.disableParallax);
    }
    if (self.options.disableParallax instanceof RegExp) {
        var disableParallaxRegexp = self.options.disableParallax;
        self.options.disableParallax = function () {
            return disableParallaxRegexp.test(navigator.userAgent);
        };
    }
    if (typeof self.options.disableParallax !== 'function') {
        self.options.disableParallax = function () {
            return false;
        };
    }

    // prepare disableVideo callback
    if (typeof self.options.disableVideo === 'string') {
        self.options.disableVideo = new RegExp(self.options.disableVideo);
    }
    if (self.options.disableVideo instanceof RegExp) {
        var disableVideoRegexp = self.options.disableVideo;
        self.options.disableVideo = function () {
            return disableVideoRegexp.test(navigator.userAgent);
        };
    }
    if (typeof self.options.disableVideo !== 'function') {
        self.options.disableVideo = function () {
            return false;
        };
    }

    // custom element to check if parallax in viewport
    var elementInVP = self.options.elementInViewport;
    // get first item from array
    if (elementInVP && (typeof elementInVP === 'undefined' ? 'undefined' : _typeof(elementInVP)) === 'object' && typeof elementInVP.length !== 'undefined') {
        var _elementInVP = elementInVP;

        var _elementInVP2 = _slicedToArray(_elementInVP, 1);

        elementInVP = _elementInVP2[0];
    }
    // check if dom element
    if (!(elementInVP instanceof Element)) {
        elementInVP = null;
    }
    self.options.elementInViewport = elementInVP;

    self.image = {
        src: self.options.imgSrc || null,
        $container: null,
        useImgTag: false,

        // position fixed is needed for the most of browsers because absolute position have glitches
        // on MacOS with smooth scroll there is a huge lags with absolute position - https://github.com/nk-o/jarallax/issues/75
        // on mobile devices better scrolled with absolute position
        position: /iPad|iPhone|iPod|Android/.test(navigator.userAgent) ? 'absolute' : 'fixed'
    };

    if (self.initImg() && self.canInitParallax()) {
        self.init();
    }
}

// add styles to element

_createClass(Jarallax, [{
    key: 'css',
    value: function css(el, styles) {
        if (typeof styles === 'string') {
            return _global.window.getComputedStyle(el).getPropertyValue(styles);
        }

        // add transform property with vendor prefix
        if (styles.transform && supportTransform) {
            styles[supportTransform] = styles.transform;
        }

        Object.keys(styles).forEach(function (key) {
            el.style[key] = styles[key];
        });
        return el;
    }

    // Extend like jQuery.extend

}, {
    key: 'extend',
    value: function extend(out) {
        var _arguments = arguments;

        out = out || {};
        Object.keys(arguments).forEach(function (i) {
            if (!_arguments[i]) {
                return;
            }
            Object.keys(_arguments[i]).forEach(function (key) {
                out[key] = _arguments[i][key];
            });
        });
        return out;
    }

    // get window size and scroll position. Useful for extensions

}, {
    key: 'getWindowData',
    value: function getWindowData() {
        return {
            width: wndW,
            height: wndH,
            y: wndY
        };
    }

    // Jarallax functions

}, {
    key: 'initImg',
    value: function initImg() {
        var self = this;

        // find image element
        var $imgElement = self.options.imgElement;
        if ($imgElement && typeof $imgElement === 'string') {
            $imgElement = self.$item.querySelector($imgElement);
        }
        // check if dom element
        if (!($imgElement instanceof Element)) {
            $imgElement = null;
        }

        if ($imgElement) {
            if (self.options.keepImg) {
                self.image.$item = $imgElement.cloneNode(true);
            } else {
                self.image.$item = $imgElement;
                self.image.$itemParent = $imgElement.parentNode;
            }
            self.image.useImgTag = true;
        }

        // true if there is img tag
        if (self.image.$item) {
            return true;
        }

        // get image src
        if (self.image.src === null) {
            self.image.src = self.css(self.$item, 'background-image').replace(/^url\(['"]?/g, '').replace(/['"]?\)$/g, '');
        }
        return !(!self.image.src || self.image.src === 'none');
    }
}, {
    key: 'canInitParallax',
    value: function canInitParallax() {
        return supportTransform && !this.options.disableParallax();
    }
}, {
    key: 'init',
    value: function init() {
        var self = this;
        var containerStyles = {
            position: 'absolute',
            top: 0,
            left: 0,
            width: '100%',
            height: '100%',
            overflow: 'hidden',
            pointerEvents: 'none'
        };
        var imageStyles = {};

        if (!self.options.keepImg) {
            // save default user styles
            var curStyle = self.$item.getAttribute('style');
            if (curStyle) {
                self.$item.setAttribute('data-jarallax-original-styles', curStyle);
            }
            if (self.image.useImgTag) {
                var curImgStyle = self.image.$item.getAttribute('style');
                if (curImgStyle) {
                    self.image.$item.setAttribute('data-jarallax-original-styles', curImgStyle);
                }
            }
        }

        // set relative position and z-index to the parent
        if (self.css(self.$item, 'position') === 'static') {
            self.css(self.$item, {
                position: 'relative'
            });
        }
        if (self.css(self.$item, 'z-index') === 'auto') {
            self.css(self.$item, {
                zIndex: 0
            });
        }

        // container for parallax image
        self.image.$container = document.createElement('div');
        self.css(self.image.$container, containerStyles);
        self.css(self.image.$container, {
            'z-index': self.options.zIndex
        });

        // fix for IE https://github.com/nk-o/jarallax/issues/110
        if (isIE) {
            self.css(self.image.$container, {
                opacity: 0.9999
            });
        }

        self.image.$container.setAttribute('id', 'jarallax-container-' + self.instanceID);
        self.$item.appendChild(self.image.$container);

        // use img tag
        if (self.image.useImgTag) {
            imageStyles = self.extend({
                'object-fit': self.options.imgSize,
                'object-position': self.options.imgPosition,
                // support for plugin https://github.com/bfred-it/object-fit-images
                'font-family': 'object-fit: ' + self.options.imgSize + '; object-position: ' + self.options.imgPosition + ';',
                'max-width': 'none'
            }, containerStyles, imageStyles);

            // use div with background image
        } else {
            self.image.$item = document.createElement('div');
            if (self.image.src) {
                imageStyles = self.extend({
                    'background-position': self.options.imgPosition,
                    'background-size': self.options.imgSize,
                    'background-repeat': self.options.imgRepeat,
                    'background-image': 'url("' + self.image.src + '")'
                }, containerStyles, imageStyles);
            }
        }

        if (self.options.type === 'opacity' || self.options.type === 'scale' || self.options.type === 'scale-opacity' || self.options.speed === 1) {
            self.image.position = 'absolute';
        }

        // check if one of parents have transform style (without this check, scroll transform will be inverted if used parallax with position fixed)
        // discussion - https://github.com/nk-o/jarallax/issues/9
        if (self.image.position === 'fixed') {
            var parentWithTransform = 0;
            var $itemParents = self.$item;
            while ($itemParents !== null && $itemParents !== document && parentWithTransform === 0) {
                var parentTransform = self.css($itemParents, '-webkit-transform') || self.css($itemParents, '-moz-transform') || self.css($itemParents, 'transform');
                if (parentTransform && parentTransform !== 'none') {
                    parentWithTransform = 1;
                    self.image.position = 'absolute';
                }
                $itemParents = $itemParents.parentNode;
            }
        }

        // add position to parallax block
        imageStyles.position = self.image.position;

        // insert parallax image
        self.css(self.image.$item, imageStyles);
        self.image.$container.appendChild(self.image.$item);

        // set initial position and size
        self.onResize();
        self.onScroll(true);

        // ResizeObserver
        if (self.options.automaticResize && resizeObserver) {
            resizeObserver.observe(self.$item);
        }

        // call onInit event
        if (self.options.onInit) {
            self.options.onInit.call(self);
        }

        // remove default user background
        if (self.css(self.$item, 'background-image') !== 'none') {
            self.css(self.$item, {
                'background-image': 'none'
            });
        }

        self.addToParallaxList();
    }

    // add to parallax instances list

}, {
    key: 'addToParallaxList',
    value: function addToParallaxList() {
        jarallaxList.push(this);

        if (jarallaxList.length === 1) {
            updateParallax();
        }
    }

    // remove from parallax instances list

}, {
    key: 'removeFromParallaxList',
    value: function removeFromParallaxList() {
        var self = this;

        jarallaxList.forEach(function (item, key) {
            if (item.instanceID === self.instanceID) {
                jarallaxList.splice(key, 1);
            }
        });
    }
}, {
    key: 'destroy',
    value: function destroy() {
        var self = this;

        self.removeFromParallaxList();

        // return styles on container as before jarallax init
        var originalStylesTag = self.$item.getAttribute('data-jarallax-original-styles');
        self.$item.removeAttribute('data-jarallax-original-styles');
        // null occurs if there is no style tag before jarallax init
        if (!originalStylesTag) {
            self.$item.removeAttribute('style');
        } else {
            self.$item.setAttribute('style', originalStylesTag);
        }

        if (self.image.useImgTag) {
            // return styles on img tag as before jarallax init
            var originalStylesImgTag = self.image.$item.getAttribute('data-jarallax-original-styles');
            self.image.$item.removeAttribute('data-jarallax-original-styles');
            // null occurs if there is no style tag before jarallax init
            if (!originalStylesImgTag) {
                self.image.$item.removeAttribute('style');
            } else {
                self.image.$item.setAttribute('style', originalStylesTag);
            }

            // move img tag to its default position
            if (self.image.$itemParent) {
                self.image.$itemParent.appendChild(self.image.$item);
            }
        }

        // remove additional dom elements
        if (self.$clipStyles) {
            self.$clipStyles.parentNode.removeChild(self.$clipStyles);
        }
        if (self.image.$container) {
            self.image.$container.parentNode.removeChild(self.image.$container);
        }

        // call onDestroy event
        if (self.options.onDestroy) {
            self.options.onDestroy.call(self);
        }

        // delete jarallax from item
        delete self.$item.jarallax;
    }

    // it will remove some image overlapping
    // overlapping occur due to an image position fixed inside absolute position element

}, {
    key: 'clipContainer',
    value: function clipContainer() {
        // needed only when background in fixed position
        if (this.image.position !== 'fixed') {
            return;
        }

        var self = this;
        var rect = self.image.$container.getBoundingClientRect();
        var width = rect.width,
            height = rect.height;

        if (!self.$clipStyles) {
            self.$clipStyles = document.createElement('style');
            self.$clipStyles.setAttribute('type', 'text/css');
            self.$clipStyles.setAttribute('id', 'jarallax-clip-' + self.instanceID);
            var head = document.head || document.getElementsByTagName('head')[0];
            head.appendChild(self.$clipStyles);
        }

        var styles = '#jarallax-container-' + self.instanceID + ' {\n           clip: rect(0 ' + width + 'px ' + height + 'px 0);\n           clip: rect(0, ' + width + 'px, ' + height + 'px, 0);\n        }';

        // add clip styles inline (this method need for support IE8 and less browsers)
        if (self.$clipStyles.styleSheet) {
            self.$clipStyles.styleSheet.cssText = styles;
        } else {
            self.$clipStyles.innerHTML = styles;
        }
    }
}, {
    key: 'coverImage',
    value: function coverImage() {
        var self = this;

        var rect = self.image.$container.getBoundingClientRect();
        var contH = rect.height;
        var speed = self.options.speed;

        var isScroll = self.options.type === 'scroll' || self.options.type === 'scroll-opacity';
        var scrollDist = 0;
        var resultH = contH;
        var resultMT = 0;

        // scroll parallax
        if (isScroll) {
            // scroll distance and height for image
            if (speed < 0) {
                scrollDist = speed * Math.max(contH, wndH);
            } else {
                scrollDist = speed * (contH + wndH);
            }

            // size for scroll parallax
            if (speed > 1) {
                resultH = Math.abs(scrollDist - wndH);
            } else if (speed < 0) {
                resultH = scrollDist / speed + Math.abs(scrollDist);
            } else {
                resultH += Math.abs(wndH - contH) * (1 - speed);
            }

            scrollDist /= 2;
        }

        // store scroll distance
        self.parallaxScrollDistance = scrollDist;

        // vertical center
        if (isScroll) {
            resultMT = (wndH - resultH) / 2;
        } else {
            resultMT = (contH - resultH) / 2;
        }

        // apply result to item
        self.css(self.image.$item, {
            height: resultH + 'px',
            marginTop: resultMT + 'px',
            left: self.image.position === 'fixed' ? rect.left + 'px' : '0',
            width: rect.width + 'px'
        });

        // call onCoverImage event
        if (self.options.onCoverImage) {
            self.options.onCoverImage.call(self);
        }

        // return some useful data. Used in the video cover function
        return {
            image: {
                height: resultH,
                marginTop: resultMT
            },
            container: rect
        };
    }
}, {
    key: 'isVisible',
    value: function isVisible() {
        return this.isElementInViewport || false;
    }
}, {
    key: 'onScroll',
    value: function onScroll(force) {
        var self = this;

        var rect = self.$item.getBoundingClientRect();
        var contT = rect.top;
        var contH = rect.height;
        var styles = {};

        // check if in viewport
        var viewportRect = rect;
        if (self.options.elementInViewport) {
            viewportRect = self.options.elementInViewport.getBoundingClientRect();
        }
        self.isElementInViewport = viewportRect.bottom >= 0 && viewportRect.right >= 0 && viewportRect.top <= wndH && viewportRect.left <= wndW;

        // stop calculations if item is not in viewport
        if (force ? false : !self.isElementInViewport) {
            return;
        }

        // calculate parallax helping variables
        var beforeTop = Math.max(0, contT);
        var beforeTopEnd = Math.max(0, contH + contT);
        var afterTop = Math.max(0, -contT);
        var beforeBottom = Math.max(0, contT + contH - wndH);
        var beforeBottomEnd = Math.max(0, contH - (contT + contH - wndH));
        var afterBottom = Math.max(0, -contT + wndH - contH);
        var fromViewportCenter = 1 - 2 * (wndH - contT) / (wndH + contH);

        // calculate on how percent of section is visible
        var visiblePercent = 1;
        if (contH < wndH) {
            visiblePercent = 1 - (afterTop || beforeBottom) / contH;
        } else if (beforeTopEnd <= wndH) {
            visiblePercent = beforeTopEnd / wndH;
        } else if (beforeBottomEnd <= wndH) {
            visiblePercent = beforeBottomEnd / wndH;
        }

        // opacity
        if (self.options.type === 'opacity' || self.options.type === 'scale-opacity' || self.options.type === 'scroll-opacity') {
            styles.transform = 'translate3d(0,0,0)';
            styles.opacity = visiblePercent;
        }

        // scale
        if (self.options.type === 'scale' || self.options.type === 'scale-opacity') {
            var scale = 1;
            if (self.options.speed < 0) {
                scale -= self.options.speed * visiblePercent;
            } else {
                scale += self.options.speed * (1 - visiblePercent);
            }
            styles.transform = 'scale(' + scale + ') translate3d(0,0,0)';
        }

        // scroll
        if (self.options.type === 'scroll' || self.options.type === 'scroll-opacity') {
            var positionY = self.parallaxScrollDistance * fromViewportCenter;

            // fix if parallax block in absolute position
            if (self.image.position === 'absolute') {
                positionY -= contT;
            }

            styles.transform = 'translate3d(0,' + positionY + 'px,0)';
        }

        self.css(self.image.$item, styles);

        // call onScroll event
        if (self.options.onScroll) {
            self.options.onScroll.call(self, {
                section: rect,

                beforeTop: beforeTop,
                beforeTopEnd: beforeTopEnd,
                afterTop: afterTop,
                beforeBottom: beforeBottom,
                beforeBottomEnd: beforeBottomEnd,
                afterBottom: afterBottom,

                visiblePercent: visiblePercent,
                fromViewportCenter: fromViewportCenter
            });
        }
    }
}, {
    key: 'onResize',
    value: function onResize() {
        this.coverImage();
        this.clipContainer();
    }
}]);

return Jarallax;

}();

// global definition

var plugin = function plugin(items) {

// check for dom element
// thanks: http://stackoverflow.com/questions/384286/javascript-isdom-how-do-you-check-if-a-javascript-object-is-a-dom-object
if ((typeof HTMLElement === 'undefined' ? 'undefined' : _typeof(HTMLElement)) === 'object' ? items instanceof HTMLElement : items && (typeof items === 'undefined' ? 'undefined' : _typeof(items)) === 'object' && items !== null && items.nodeType === 1 && typeof items.nodeName === 'string') {
    items = [items];
}

var options = arguments[1];
var args = Array.prototype.slice.call(arguments, 2);
var len = items.length;
var k = 0;
var ret = void 0;

for (k; k < len; k++) {
    if ((typeof options === 'undefined' ? 'undefined' : _typeof(options)) === 'object' || typeof options === 'undefined') {
        if (!items[k].jarallax) {
            items[k].jarallax = new Jarallax(items[k], options);
        }
    } else if (items[k].jarallax) {
        // eslint-disable-next-line prefer-spread
        ret = items[k].jarallax[options].apply(items[k].jarallax, args);
    }
    if (typeof ret !== 'undefined') {
        return ret;
    }
}

return items;

}; plugin.constructor = Jarallax;

exports.default = plugin; /* WEBPACK VAR INJECTION */}.call(this, webpack_require(5)))

/***/ }), /* 14 */ /***/ (function(module, exports, webpack_require) {

“use strict”;

var global = webpack_require(4);

/**

* `requestAnimationFrame()`
*/

var request = global.requestAnimationFrame || global.webkitRequestAnimationFrame || global.mozRequestAnimationFrame || fallback;

var prev = +new Date(); function fallback(fn) {

var curr = +new Date();
var ms = Math.max(0, 16 - (curr - prev));
var req = setTimeout(fn, ms);
return prev = curr, req;

}

/**

* `cancelAnimationFrame()`
*/

var cancel = global.cancelAnimationFrame || global.webkitCancelAnimationFrame || global.mozCancelAnimationFrame || clearTimeout;

if (Function.prototype.bind) {

request = request.bind(global);
cancel = cancel.bind(global);

}

exports = module.exports = request; exports.cancel = cancel;

/***/ }) /******/ ]);

/*!

* Name    : Video Background Extension for Jarallax
* Version : 1.0.1
* Author  : nK <https://nkdev.info>
* GitHub  : https://github.com/nk-o/jarallax
*/

/******/ (function(modules) { // webpackBootstrap /******/ // The module cache /******/ var installedModules = {}; /******/ /******/ // The require function /******/ function webpack_require(moduleId) { /******/ /******/ // Check if module is in cache /******/ if(installedModules) { /******/ return installedModules.exports; /******/ } /******/ // Create a new module (and put it into the cache) /******/ var module = installedModules = { /******/ i: moduleId, /******/ l: false, /******/ exports: {} /******/ }; /******/ /******/ // Execute the module function /******/ modules.call(module.exports, module, module.exports, webpack_require); /******/ /******/ // Flag the module as loaded /******/ module.l = true; /******/ /******/ // Return the exports of the module /******/ return module.exports; /******/ } /******/ /******/ /******/ // expose the modules object (webpack_modules) /******/ webpack_require.m = modules; /******/ /******/ // expose the module cache /******/ webpack_require.c = installedModules; /******/ /******/ // define getter function for harmony exports /******/ webpack_require.d = function(exports, name, getter) { /******/ if(!webpack_require.o(exports, name)) { /******/ Object.defineProperty(exports, name, { enumerable: true, get: getter }); /******/ } /******/ }; /******/ /******/ // define __esModule on exports /******/ webpack_require.r = function(exports) { /******/ if(typeof Symbol !== 'undefined' && Symbol.toStringTag) { /******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' }); /******/ } /******/ Object.defineProperty(exports, '__esModule', { value: true }); /******/ }; /******/ /******/ // create a fake namespace object /******/ // mode & 1: value is a module id, require it /******/ // mode & 2: merge all properties of value into the ns /******/ // mode & 4: return value when already ns object /******/ // mode & 8|1: behave like require /******/ webpack_require.t = function(value, mode) { /******/ if(mode & 1) value = webpack_require(value); /******/ if(mode & 8) return value; /******/ if((mode & 4) && typeof value === 'object' && value && value.__esModule) return value; /******/ var ns = Object.create(null); /******/ webpack_require.r(ns); /******/ Object.defineProperty(ns, 'default', { enumerable: true, value: value }); /******/ if(mode & 2 && typeof value != 'string') for(var key in value) webpack_require.d(ns, key, function(key) { return value; }.bind(null, key)); /******/ return ns; /******/ }; /******/ /******/ // getDefaultExport function for compatibility with non-harmony modules /******/ webpack_require.n = function(module) { /******/ var getter = module && module.__esModule ? /******/ function getDefault() { return module; } : /******/ function getModuleExports() { return module; }; /******/ webpack_require.d(getter, 'a', getter); /******/ return getter; /******/ }; /******/ /******/ // Object.prototype.hasOwnProperty.call /******/ webpack_require.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); }; /******/ /******/ // webpack_public_path /******/ webpack_require.p = “”; /******/ /******/ /******/ // Load entry module and return exports /******/ return webpack_require(_webpack_require_.s = 6); /******/ }) /************************************************************************/ /******/ ([ /* 0 */, /* 1 */, /* 2 */ /***/ (function(module, exports, webpack_require) {

“use strict”;

module.exports = function (callback) {

if (document.readyState === 'complete' || document.readyState === 'interactive') {
        // Already ready or interactive, execute callback
        callback.call();
} else if (document.attachEvent) {
        // Old browsers
        document.attachEvent('onreadystatechange', function () {
                if (document.readyState === 'interactive') callback.call();
        });
} else if (document.addEventListener) {
        // Modern browsers
        document.addEventListener('DOMContentLoaded', callback);
}

};

/***/ }), /* 3 */, /* 4 */ /***/ (function(module, exports, webpack_require) {

“use strict”; /* WEBPACK VAR INJECTION */(function(global) {

var win;

if (typeof window !== “undefined”) {

win = window;

} else if (typeof global !== “undefined”) {

win = global;

} else if (typeof self !== “undefined”) {

win = self;

} else {

win = {};

}

module.exports = win; /* WEBPACK VAR INJECTION */}.call(this, webpack_require(5)))

/***/ }), /* 5 */ /***/ (function(module, exports, webpack_require) {

“use strict”;

var _typeof = typeof Symbol === “function” && typeof Symbol.iterator === “symbol” ? function (obj) { return typeof obj; } : function (obj) { return obj && typeof Symbol === “function” && obj.constructor === Symbol && obj !== Symbol.prototype ? “symbol” : typeof obj; };

var g;

// This works in non-strict mode g = function () {

return this;

}();

try {

// This works if eval is allowed (see CSP)
g = g || Function("return this")() || (1, eval)("this");

} catch (e) {

// This works if the window reference is available
if ((typeof window === "undefined" ? "undefined" : _typeof(window)) === "object") g = window;

}

// g can still be undefined, but nothing to do about it… // We return undefined, instead of nothing here, so it's // easier to handle this case. if(!global) { …}

module.exports = g;

/***/ }), /* 6 */ /***/ (function(module, exports, webpack_require) {

module.exports = webpack_require(7);

/***/ }), /* 7 */ /***/ (function(module, exports, webpack_require) {

“use strict”;

var _videoWorker = webpack_require(8);

var _videoWorker2 = _interopRequireDefault(_videoWorker);

var _global = webpack_require(4);

var _global2 = _interopRequireDefault(_global);

var _liteReady = webpack_require(2);

var _liteReady2 = _interopRequireDefault(_liteReady);

var _jarallaxVideo = webpack_require(10);

var _jarallaxVideo2 = _interopRequireDefault(_jarallaxVideo);

function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }

// add video worker globally to fallback jarallax < 1.10 versions _global2.default.VideoWorker = _global2.default.VideoWorker || _videoWorker2.default;

(0, _jarallaxVideo2.default)();

// data-jarallax-video initialization (0, _liteReady2.default)(function () {

if (typeof jarallax !== 'undefined') {
    jarallax(document.querySelectorAll('[data-jarallax-video]'));
}

});

/***/ }), /* 8 */ /***/ (function(module, exports, webpack_require) {

“use strict”;

module.exports = webpack_require(9);

/***/ }), /* 9 */ /***/ (function(module, exports, webpack_require) {

“use strict”;

Object.defineProperty(exports, “__esModule”, {

value: true

});

var _typeof = typeof Symbol === “function” && typeof Symbol.iterator === “symbol” ? function (obj) { return typeof obj; } : function (obj) { return obj && typeof Symbol === “function” && obj.constructor === Symbol && obj !== Symbol.prototype ? “symbol” : typeof obj; };

var _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (“value” in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();

function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(“Cannot call a class as a function”); } }

// Deferred // thanks stackoverflow.com/questions/18096715/implement-deferred-object-without-using-jquery function Deferred() {

this._done = [];
this._fail = [];

} Deferred.prototype = {

execute: function execute(list, args) {
    var i = list.length;
    args = Array.prototype.slice.call(args);
    while (i--) {
        list[i].apply(null, args);
    }
},
resolve: function resolve() {
    this.execute(this._done, arguments);
},
reject: function reject() {
    this.execute(this._fail, arguments);
},
done: function done(callback) {
    this._done.push(callback);
},
fail: function fail(callback) {
    this._fail.push(callback);
}

};

var ID = 0; var YoutubeAPIadded = 0; var VimeoAPIadded = 0; var loadingYoutubePlayer = 0; var loadingVimeoPlayer = 0; var loadingYoutubeDefer = new Deferred(); var loadingVimeoDefer = new Deferred();

var VideoWorker = function () {

function VideoWorker(url, options) {
    _classCallCheck(this, VideoWorker);

    var self = this;

    self.url = url;

    self.options_default = {
        autoplay: false,
        loop: false,
        mute: false,
        volume: 100,
        showContols: true,

        // start / end video time in seconds
        startTime: 0,
        endTime: 0
    };

    self.options = self.extend({}, self.options_default, options);

    // check URL
    self.videoID = self.parseURL(url);

    // init
    if (self.videoID) {
        self.ID = ID++;
        self.loadAPI();
        self.init();
    }
}

// Extend like jQuery.extend

_createClass(VideoWorker, [{
    key: 'extend',
    value: function extend(out) {
        var _arguments = arguments;

        out = out || {};
        Object.keys(arguments).forEach(function (i) {
            if (!_arguments[i]) {
                return;
            }
            Object.keys(_arguments[i]).forEach(function (key) {
                out[key] = _arguments[i][key];
            });
        });
        return out;
    }
}, {
    key: 'parseURL',
    value: function parseURL(url) {
        // parse youtube ID
        function getYoutubeID(ytUrl) {
            // eslint-disable-next-line no-useless-escape
            var regExp = /.*(?:youtu.be\/|v\/|u\/\w\/|embed\/|watch\?v=)([^#\&\?]*).*/;
            var match = ytUrl.match(regExp);
            return match && match[1].length === 11 ? match[1] : false;
        }

        // parse vimeo ID
        function getVimeoID(vmUrl) {
            // eslint-disable-next-line no-useless-escape
            var regExp = /https?:\/\/(?:www\.|player\.)?vimeo.com\/(?:channels\/(?:\w+\/)?|groups\/([^\/]*)\/videos\/|album\/(\d+)\/video\/|video\/|)(\d+)(?:$|\/|\?)/;
            var match = vmUrl.match(regExp);
            return match && match[3] ? match[3] : false;
        }

        // parse local string
        function getLocalVideos(locUrl) {
            // eslint-disable-next-line no-useless-escape
            var videoFormats = locUrl.split(/,(?=mp4\:|webm\:|ogv\:|ogg\:)/);
            var result = {};
            var ready = 0;
            videoFormats.forEach(function (val) {
                // eslint-disable-next-line no-useless-escape
                var match = val.match(/^(mp4|webm|ogv|ogg)\:(.*)/);
                if (match && match[1] && match[2]) {
                    // eslint-disable-next-line prefer-destructuring
                    result[match[1] === 'ogv' ? 'ogg' : match[1]] = match[2];
                    ready = 1;
                }
            });
            return ready ? result : false;
        }

        var Youtube = getYoutubeID(url);
        var Vimeo = getVimeoID(url);
        var Local = getLocalVideos(url);

        if (Youtube) {
            this.type = 'youtube';
            return Youtube;
        } else if (Vimeo) {
            this.type = 'vimeo';
            return Vimeo;
        } else if (Local) {
            this.type = 'local';
            return Local;
        }

        return false;
    }
}, {
    key: 'isValid',
    value: function isValid() {
        return !!this.videoID;
    }

    // events

}, {
    key: 'on',
    value: function on(name, callback) {
        this.userEventsList = this.userEventsList || [];

        // add new callback in events list
        (this.userEventsList[name] || (this.userEventsList[name] = [])).push(callback);
    }
}, {
    key: 'off',
    value: function off(name, callback) {
        var _this = this;

        if (!this.userEventsList || !this.userEventsList[name]) {
            return;
        }

        if (!callback) {
            delete this.userEventsList[name];
        } else {
            this.userEventsList[name].forEach(function (val, key) {
                if (val === callback) {
                    _this.userEventsList[name][key] = false;
                }
            });
        }
    }
}, {
    key: 'fire',
    value: function fire(name) {
        var _this2 = this;

        var args = [].slice.call(arguments, 1);
        if (this.userEventsList && typeof this.userEventsList[name] !== 'undefined') {
            this.userEventsList[name].forEach(function (val) {
                // call with all arguments
                if (val) {
                    val.apply(_this2, args);
                }
            });
        }
    }
}, {
    key: 'play',
    value: function play(start) {
        var self = this;
        if (!self.player) {
            return;
        }

        if (self.type === 'youtube' && self.player.playVideo) {
            if (typeof start !== 'undefined') {
                self.player.seekTo(start || 0);
            }
            if (YT.PlayerState.PLAYING !== self.player.getPlayerState()) {
                self.player.playVideo();
            }
        }

        if (self.type === 'vimeo') {
            if (typeof start !== 'undefined') {
                self.player.setCurrentTime(start);
            }
            self.player.getPaused().then(function (paused) {
                if (paused) {
                    self.player.play();
                }
            });
        }

        if (self.type === 'local') {
            if (typeof start !== 'undefined') {
                self.player.currentTime = start;
            }
            if (self.player.paused) {
                self.player.play();
            }
        }
    }
}, {
    key: 'pause',
    value: function pause() {
        var self = this;
        if (!self.player) {
            return;
        }

        if (self.type === 'youtube' && self.player.pauseVideo) {
            if (YT.PlayerState.PLAYING === self.player.getPlayerState()) {
                self.player.pauseVideo();
            }
        }

        if (self.type === 'vimeo') {
            self.player.getPaused().then(function (paused) {
                if (!paused) {
                    self.player.pause();
                }
            });
        }

        if (self.type === 'local') {
            if (!self.player.paused) {
                self.player.pause();
            }
        }
    }
}, {
    key: 'mute',
    value: function mute() {
        var self = this;
        if (!self.player) {
            return;
        }

        if (self.type === 'youtube' && self.player.mute) {
            self.player.mute();
        }

        if (self.type === 'vimeo' && self.player.setVolume) {
            self.player.setVolume(0);
        }

        if (self.type === 'local') {
            self.$video.muted = true;
        }
    }
}, {
    key: 'unmute',
    value: function unmute() {
        var self = this;
        if (!self.player) {
            return;
        }

        if (self.type === 'youtube' && self.player.mute) {
            self.player.unMute();
        }

        if (self.type === 'vimeo' && self.player.setVolume) {
            self.player.setVolume(self.options.volume);
        }

        if (self.type === 'local') {
            self.$video.muted = false;
        }
    }
}, {
    key: 'setVolume',
    value: function setVolume() {
        var volume = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : false;

        var self = this;
        if (!self.player || !volume) {
            return;
        }

        if (self.type === 'youtube' && self.player.setVolume) {
            self.player.setVolume(volume);
        }

        if (self.type === 'vimeo' && self.player.setVolume) {
            self.player.setVolume(volume);
        }

        if (self.type === 'local') {
            self.$video.volume = volume / 100;
        }
    }
}, {
    key: 'getVolume',
    value: function getVolume(callback) {
        var self = this;
        if (!self.player) {
            callback(false);
            return;
        }

        if (self.type === 'youtube' && self.player.getVolume) {
            callback(self.player.getVolume());
        }

        if (self.type === 'vimeo' && self.player.getVolume) {
            self.player.getVolume().then(function (volume) {
                callback(volume);
            });
        }

        if (self.type === 'local') {
            callback(self.$video.volume * 100);
        }
    }
}, {
    key: 'getMuted',
    value: function getMuted(callback) {
        var self = this;
        if (!self.player) {
            callback(null);
            return;
        }

        if (self.type === 'youtube' && self.player.isMuted) {
            callback(self.player.isMuted());
        }

        if (self.type === 'vimeo' && self.player.getVolume) {
            self.player.getVolume().then(function (volume) {
                callback(!!volume);
            });
        }

        if (self.type === 'local') {
            callback(self.$video.muted);
        }
    }
}, {
    key: 'getImageURL',
    value: function getImageURL(callback) {
        var self = this;

        if (self.videoImage) {
            callback(self.videoImage);
            return;
        }

        if (self.type === 'youtube') {
            var availableSizes = ['maxresdefault', 'sddefault', 'hqdefault', '0'];
            var step = 0;

            var tempImg = new Image();
            tempImg.onload = function () {
                // if no thumbnail, youtube add their own image with width = 120px
                if ((this.naturalWidth || this.width) !== 120 || step === availableSizes.length - 1) {
                    // ok
                    self.videoImage = 'https://img.youtube.com/vi/' + self.videoID + '/' + availableSizes[step] + '.jpg';
                    callback(self.videoImage);
                } else {
                    // try another size
                    step++;
                    this.src = 'https://img.youtube.com/vi/' + self.videoID + '/' + availableSizes[step] + '.jpg';
                }
            };
            tempImg.src = 'https://img.youtube.com/vi/' + self.videoID + '/' + availableSizes[step] + '.jpg';
        }

        if (self.type === 'vimeo') {
            var request = new XMLHttpRequest();
            request.open('GET', 'https://vimeo.com/api/v2/video/' + self.videoID + '.json', true);
            request.onreadystatechange = function () {
                if (this.readyState === 4) {
                    if (this.status >= 200 && this.status < 400) {
                        // Success!
                        var response = JSON.parse(this.responseText);
                        self.videoImage = response[0].thumbnail_large;
                        callback(self.videoImage);
                    } else {
                        // Error :(
                    }
                }
            };
            request.send();
            request = null;
        }
    }

    // fallback to the old version.

}, {
    key: 'getIframe',
    value: function getIframe(callback) {
        this.getVideo(callback);
    }
}, {
    key: 'getVideo',
    value: function getVideo(callback) {
        var self = this;

        // return generated video block
        if (self.$video) {
            callback(self.$video);
            return;
        }

        // generate new video block
        self.onAPIready(function () {
            var hiddenDiv = void 0;
            if (!self.$video) {
                hiddenDiv = document.createElement('div');
                hiddenDiv.style.display = 'none';
            }

            // Youtube
            if (self.type === 'youtube') {
                self.playerOptions = {};
                self.playerOptions.videoId = self.videoID;
                self.playerOptions.playerVars = {
                    autohide: 1,
                    rel: 0,
                    autoplay: 0,
                    // autoplay enable on mobile devices
                    playsinline: 1
                };

                // hide controls
                if (!self.options.showContols) {
                    self.playerOptions.playerVars.iv_load_policy = 3;
                    self.playerOptions.playerVars.modestbranding = 1;
                    self.playerOptions.playerVars.controls = 0;
                    self.playerOptions.playerVars.showinfo = 0;
                    self.playerOptions.playerVars.disablekb = 1;
                }

                // events
                var ytStarted = void 0;
                var ytProgressInterval = void 0;
                self.playerOptions.events = {
                    onReady: function onReady(e) {
                        // mute
                        if (self.options.mute) {
                            e.target.mute();
                        } else if (self.options.volume) {
                            e.target.setVolume(self.options.volume);
                        }

                        // autoplay
                        if (self.options.autoplay) {
                            self.play(self.options.startTime);
                        }
                        self.fire('ready', e);

                        // volumechange
                        setInterval(function () {
                            self.getVolume(function (volume) {
                                if (self.options.volume !== volume) {
                                    self.options.volume = volume;
                                    self.fire('volumechange', e);
                                }
                            });
                        }, 150);
                    },
                    onStateChange: function onStateChange(e) {
                        // loop
                        if (self.options.loop && e.data === YT.PlayerState.ENDED) {
                            self.play(self.options.startTime);
                        }
                        if (!ytStarted && e.data === YT.PlayerState.PLAYING) {
                            ytStarted = 1;
                            self.fire('started', e);
                        }
                        if (e.data === YT.PlayerState.PLAYING) {
                            self.fire('play', e);
                        }
                        if (e.data === YT.PlayerState.PAUSED) {
                            self.fire('pause', e);
                        }
                        if (e.data === YT.PlayerState.ENDED) {
                            self.fire('ended', e);
                        }

                        // progress check
                        if (e.data === YT.PlayerState.PLAYING) {
                            ytProgressInterval = setInterval(function () {
                                self.fire('timeupdate', e);

                                // check for end of video and play again or stop
                                if (self.options.endTime && self.player.getCurrentTime() >= self.options.endTime) {
                                    if (self.options.loop) {
                                        self.play(self.options.startTime);
                                    } else {
                                        self.pause();
                                    }
                                }
                            }, 150);
                        } else {
                            clearInterval(ytProgressInterval);
                        }
                    }
                };

                var firstInit = !self.$video;
                if (firstInit) {
                    var div = document.createElement('div');
                    div.setAttribute('id', self.playerID);
                    hiddenDiv.appendChild(div);
                    document.body.appendChild(hiddenDiv);
                }
                self.player = self.player || new window.YT.Player(self.playerID, self.playerOptions);
                if (firstInit) {
                    self.$video = document.getElementById(self.playerID);

                    // get video width and height
                    self.videoWidth = parseInt(self.$video.getAttribute('width'), 10) || 1280;
                    self.videoHeight = parseInt(self.$video.getAttribute('height'), 10) || 720;
                }
            }

            // Vimeo
            if (self.type === 'vimeo') {
                self.playerOptions = '';

                self.playerOptions += 'player_id=' + self.playerID;
                self.playerOptions += '&autopause=0';
                self.playerOptions += '&transparent=0';

                // hide controls
                if (!self.options.showContols) {
                    self.playerOptions += '&badge=0&byline=0&portrait=0&title=0';
                }

                // autoplay
                self.playerOptions += '&autoplay=' + (self.options.autoplay ? '1' : '0');

                // loop
                self.playerOptions += '&loop=' + (self.options.loop ? 1 : 0);

                if (!self.$video) {
                    self.$video = document.createElement('iframe');
                    self.$video.setAttribute('id', self.playerID);
                    self.$video.setAttribute('src', 'https://player.vimeo.com/video/' + self.videoID + '?' + self.playerOptions);
                    self.$video.setAttribute('frameborder', '0');
                    hiddenDiv.appendChild(self.$video);
                    document.body.appendChild(hiddenDiv);
                }

                self.player = self.player || new Vimeo.Player(self.$video);

                // get video width and height
                self.player.getVideoWidth().then(function (width) {
                    self.videoWidth = width || 1280;
                });
                self.player.getVideoHeight().then(function (height) {
                    self.videoHeight = height || 720;
                });

                // set current time for autoplay
                if (self.options.startTime && self.options.autoplay) {
                    self.player.setCurrentTime(self.options.startTime);
                }

                // mute
                if (self.options.mute) {
                    self.player.setVolume(0);
                } else if (self.options.volume) {
                    self.player.setVolume(self.options.volume);
                }

                var vmStarted = void 0;
                self.player.on('timeupdate', function (e) {
                    if (!vmStarted) {
                        self.fire('started', e);
                        vmStarted = 1;
                    }

                    self.fire('timeupdate', e);

                    // check for end of video and play again or stop
                    if (self.options.endTime) {
                        if (self.options.endTime && e.seconds >= self.options.endTime) {
                            if (self.options.loop) {
                                self.play(self.options.startTime);
                            } else {
                                self.pause();
                            }
                        }
                    }
                });
                self.player.on('play', function (e) {
                    self.fire('play', e);

                    // check for the start time and start with it
                    if (self.options.startTime && e.seconds === 0) {
                        self.play(self.options.startTime);
                    }
                });
                self.player.on('pause', function (e) {
                    self.fire('pause', e);
                });
                self.player.on('ended', function (e) {
                    self.fire('ended', e);
                });
                self.player.on('loaded', function (e) {
                    self.fire('ready', e);
                });
                self.player.on('volumechange', function (e) {
                    self.fire('volumechange', e);
                });
            }

            // Local
            function addSourceToLocal(element, src, type) {
                var source = document.createElement('source');
                source.src = src;
                source.type = type;
                element.appendChild(source);
            }
            if (self.type === 'local') {
                if (!self.$video) {
                    self.$video = document.createElement('video');

                    // show controls
                    if (self.options.showContols) {
                        self.$video.controls = true;
                    }

                    // mute
                    if (self.options.mute) {
                        self.$video.muted = true;
                    } else if (self.$video.volume) {
                        self.$video.volume = self.options.volume / 100;
                    }

                    // loop
                    if (self.options.loop) {
                        self.$video.loop = true;
                    }

                    // autoplay enable on mobile devices
                    self.$video.setAttribute('playsinline', '');
                    self.$video.setAttribute('webkit-playsinline', '');

                    self.$video.setAttribute('id', self.playerID);
                    hiddenDiv.appendChild(self.$video);
                    document.body.appendChild(hiddenDiv);

                    Object.keys(self.videoID).forEach(function (key) {
                        addSourceToLocal(self.$video, self.videoID[key], 'video/' + key);
                    });
                }

                self.player = self.player || self.$video;

                var locStarted = void 0;
                self.player.addEventListener('playing', function (e) {
                    if (!locStarted) {
                        self.fire('started', e);
                    }
                    locStarted = 1;
                });
                self.player.addEventListener('timeupdate', function (e) {
                    self.fire('timeupdate', e);

                    // check for end of video and play again or stop
                    if (self.options.endTime) {
                        if (self.options.endTime && this.currentTime >= self.options.endTime) {
                            if (self.options.loop) {
                                self.play(self.options.startTime);
                            } else {
                                self.pause();
                            }
                        }
                    }
                });
                self.player.addEventListener('play', function (e) {
                    self.fire('play', e);
                });
                self.player.addEventListener('pause', function (e) {
                    self.fire('pause', e);
                });
                self.player.addEventListener('ended', function (e) {
                    self.fire('ended', e);
                });
                self.player.addEventListener('loadedmetadata', function () {
                    // get video width and height
                    self.videoWidth = this.videoWidth || 1280;
                    self.videoHeight = this.videoHeight || 720;

                    self.fire('ready');

                    // autoplay
                    if (self.options.autoplay) {
                        self.play(self.options.startTime);
                    }
                });
                self.player.addEventListener('volumechange', function (e) {
                    self.getVolume(function (volume) {
                        self.options.volume = volume;
                    });
                    self.fire('volumechange', e);
                });
            }

            callback(self.$video);
        });
    }
}, {
    key: 'init',
    value: function init() {
        var self = this;

        self.playerID = 'VideoWorker-' + self.ID;
    }
}, {
    key: 'loadAPI',
    value: function loadAPI() {
        var self = this;

        if (YoutubeAPIadded && VimeoAPIadded) {
            return;
        }

        var src = '';

        // load Youtube API
        if (self.type === 'youtube' && !YoutubeAPIadded) {
            YoutubeAPIadded = 1;
            src = 'https://www.youtube.com/iframe_api';
        }

        // load Vimeo API
        if (self.type === 'vimeo' && !VimeoAPIadded) {
            VimeoAPIadded = 1;
            src = 'https://player.vimeo.com/api/player.js';
        }

        if (!src) {
            return;
        }

        // add script in head section
        var tag = document.createElement('script');
        var head = document.getElementsByTagName('head')[0];
        tag.src = src;

        head.appendChild(tag);

        head = null;
        tag = null;
    }
}, {
    key: 'onAPIready',
    value: function onAPIready(callback) {
        var self = this;

        // Youtube
        if (self.type === 'youtube') {
            // Listen for global YT player callback
            if ((typeof YT === 'undefined' || YT.loaded === 0) && !loadingYoutubePlayer) {
                // Prevents Ready event from being called twice
                loadingYoutubePlayer = 1;

                // Creates deferred so, other players know when to wait.
                window.onYouTubeIframeAPIReady = function () {
                    window.onYouTubeIframeAPIReady = null;
                    loadingYoutubeDefer.resolve('done');
                    callback();
                };
            } else if ((typeof YT === 'undefined' ? 'undefined' : _typeof(YT)) === 'object' && YT.loaded === 1) {
                callback();
            } else {
                loadingYoutubeDefer.done(function () {
                    callback();
                });
            }
        }

        // Vimeo
        if (self.type === 'vimeo') {
            if (typeof Vimeo === 'undefined' && !loadingVimeoPlayer) {
                loadingVimeoPlayer = 1;
                var vimeoInterval = setInterval(function () {
                    if (typeof Vimeo !== 'undefined') {
                        clearInterval(vimeoInterval);
                        loadingVimeoDefer.resolve('done');
                        callback();
                    }
                }, 20);
            } else if (typeof Vimeo !== 'undefined') {
                callback();
            } else {
                loadingVimeoDefer.done(function () {
                    callback();
                });
            }
        }

        // Local
        if (self.type === 'local') {
            callback();
        }
    }
}]);

return VideoWorker;

}();

exports.default = VideoWorker;

/***/ }), /* 10 */ /***/ (function(module, exports, webpack_require) {

“use strict”;

Object.defineProperty(exports, “__esModule”, {

value: true

}); exports.default = jarallaxVideo;

var _videoWorker = webpack_require(8);

var _videoWorker2 = _interopRequireDefault(_videoWorker);

var _global = webpack_require(4);

var _global2 = _interopRequireDefault(_global);

function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }

function jarallaxVideo() {

var jarallax = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : _global2.default.jarallax;

if (typeof jarallax === 'undefined') {
    return;
}

var Jarallax = jarallax.constructor;

// append video after init Jarallax
var defInit = Jarallax.prototype.init;
Jarallax.prototype.init = function () {
    var self = this;

    defInit.apply(self);

    if (self.video && !self.options.disableVideo()) {
        self.video.getVideo(function (video) {
            var $parent = video.parentNode;
            self.css(video, {
                position: self.image.position,
                top: '0px',
                left: '0px',
                right: '0px',
                bottom: '0px',
                width: '100%',
                height: '100%',
                maxWidth: 'none',
                maxHeight: 'none',
                margin: 0,
                zIndex: -1
            });
            self.$video = video;
            self.image.$container.appendChild(video);

            // remove parent video element (created by VideoWorker)
            $parent.parentNode.removeChild($parent);
        });
    }
};

// cover video
var defCoverImage = Jarallax.prototype.coverImage;
Jarallax.prototype.coverImage = function () {
    var self = this;
    var imageData = defCoverImage.apply(self);
    var node = self.image.$item ? self.image.$item.nodeName : false;

    if (imageData && self.video && node && (node === 'IFRAME' || node === 'VIDEO')) {
        var h = imageData.image.height;
        var w = h * self.image.width / self.image.height;
        var ml = (imageData.container.width - w) / 2;
        var mt = imageData.image.marginTop;

        if (imageData.container.width > w) {
            w = imageData.container.width;
            h = w * self.image.height / self.image.width;
            ml = 0;
            mt += (imageData.image.height - h) / 2;
        }

        // add video height over than need to hide controls
        if (node === 'IFRAME') {
            h += 400;
            mt -= 200;
        }

        self.css(self.$video, {
            width: w + 'px',
            marginLeft: ml + 'px',
            height: h + 'px',
            marginTop: mt + 'px'
        });
    }

    return imageData;
};

// init video
var defInitImg = Jarallax.prototype.initImg;
Jarallax.prototype.initImg = function () {
    var self = this;
    var defaultResult = defInitImg.apply(self);

    if (!self.options.videoSrc) {
        self.options.videoSrc = self.$item.getAttribute('data-jarallax-video') || null;
    }

    if (self.options.videoSrc) {
        self.defaultInitImgResult = defaultResult;
        return true;
    }

    return defaultResult;
};

var defCanInitParallax = Jarallax.prototype.canInitParallax;
Jarallax.prototype.canInitParallax = function () {
    var self = this;
    var defaultResult = defCanInitParallax.apply(self);

    if (!self.options.videoSrc) {
        return defaultResult;
    }

    var video = new _videoWorker2.default(self.options.videoSrc, {
        autoplay: true,
        loop: true,
        showContols: false,
        startTime: self.options.videoStartTime || 0,
        endTime: self.options.videoEndTime || 0,
        mute: self.options.videoVolume ? 0 : 1,
        volume: self.options.videoVolume || 0
    });

    if (video.isValid()) {
        // if parallax will not be inited, we can add thumbnail on background.
        if (!defaultResult) {
            if (!self.defaultInitImgResult) {
                video.getImageURL(function (url) {
                    // save default user styles
                    var curStyle = self.$item.getAttribute('style');
                    if (curStyle) {
                        self.$item.setAttribute('data-jarallax-original-styles', curStyle);
                    }

                    // set new background
                    self.css(self.$item, {
                        'background-image': 'url("' + url + '")',
                        'background-position': 'center',
                        'background-size': 'cover'
                    });
                });
            }

            // init video
        } else {
            video.on('ready', function () {
                if (self.options.videoPlayOnlyVisible) {
                    var oldOnScroll = self.onScroll;
                    self.onScroll = function () {
                        oldOnScroll.apply(self);
                        if (self.isVisible()) {
                            video.play();
                        } else {
                            video.pause();
                        }
                    };
                } else {
                    video.play();
                }
            });

            video.on('started', function () {
                self.image.$default_item = self.image.$item;
                self.image.$item = self.$video;

                // set video width and height
                self.image.width = self.video.videoWidth || 1280;
                self.image.height = self.video.videoHeight || 720;
                self.options.imgWidth = self.image.width;
                self.options.imgHeight = self.image.height;
                self.coverImage();
                self.clipContainer();
                self.onScroll();

                // hide image
                if (self.image.$default_item) {
                    self.image.$default_item.style.display = 'none';
                }
            });

            self.video = video;

            // set image if not exists
            if (!self.defaultInitImgResult) {
                if (video.type !== 'local') {
                    video.getImageURL(function (url) {
                        self.image.src = url;
                        self.init();
                    });

                    return false;
                }

                // set empty image on local video if not defined
                self.image.src = '';
                return true;
            }
        }
    }

    return defaultResult;
};

// Destroy video parallax
var defDestroy = Jarallax.prototype.destroy;
Jarallax.prototype.destroy = function () {
    var self = this;

    if (self.image.$default_item) {
        self.image.$item = self.image.$default_item;
        delete self.image.$default_item;
    }

    defDestroy.apply(self);
};

}

/***/ }) /******/ ]); “use strict”;

function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(“Cannot call a class as a function”); } }

function _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (“value” in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } }

function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; }

(function ($) {

var INPUT_DATA = {};
var DATA_COLOR = '';
var BUTTON_X_COLOR = '';
var BUTTON_X_BLUR_COLOR = '#ced4da';
var INPUT_FOCUS = '1px solid #4285f4';
var INPUT_BLUR = '1px solid #ced4da';
var INPUT_FOCUS_SHADOW = '0 1px 0 0 #4285f4';
var INPUT_BLUR_SHADOW = '';
var ENTER_CHAR_CODE = 13;

var mdbAutocomplete =
/*#__PURE__*/
function () {
  function mdbAutocomplete(input, options) {
    _classCallCheck(this, mdbAutocomplete);

    this.defaults = {
      data: INPUT_DATA,
      dataColor: DATA_COLOR,
      xColor: BUTTON_X_COLOR,
      xBlurColor: BUTTON_X_BLUR_COLOR,
      inputFocus: INPUT_FOCUS,
      inputBlur: INPUT_BLUR,
      inputFocusShadow: INPUT_FOCUS_SHADOW,
      inputBlurShadow: INPUT_BLUR_SHADOW
    };
    this.$input = input;
    this.options = this.assignOptions(options);
    this.$clearButton = $('.mdb-autocomplete-clear');
    this.$autocompleteWrap = $('<ul class="mdb-autocomplete-wrap"></ul>');
    this.init();
  }

  _createClass(mdbAutocomplete, [{
    key: "init",
    value: function init() {
      this.setData();
      this.inputFocus();
      this.inputBlur();
      this.inputKeyupData();
      this.inputLiClick();
      this.clearAutocomplete();
    }
  }, {
    key: "assignOptions",
    value: function assignOptions(newOptions) {
      return $.extend({}, this.defaults, newOptions);
    }
  }, {
    key: "setData",
    value: function setData() {
      if (Object.keys(this.options.data).length) {
        this.$autocompleteWrap.insertAfter(this.$input);
      }
    }
  }, {
    key: "inputFocus",
    value: function inputFocus() {
      var _this = this;

      this.$input.on('focus', function () {
        _this.$input.css('border-bottom', _this.options.inputFocus);

        _this.$input.css('box-shadow', _this.options.inputFocusShadow);
      });
    }
  }, {
    key: "inputBlur",
    value: function inputBlur() {
      var _this2 = this;

      this.$input.on('blur', function () {
        _this2.$input.css('border-bottom', _this2.options.inputBlur);

        _this2.$input.css('box-shadow', _this2.options.inputBlurShadow);
      });
    }
  }, {
    key: "inputKeyupData",
    value: function inputKeyupData() {
      var _this3 = this;

      this.$input.on('keyup', function (e) {
        var $inputValue = _this3.$input.val();

        _this3.$autocompleteWrap.empty();

        if ($inputValue.length) {
          for (var item in _this3.options.data) {
            if (_this3.options.data[item].toLowerCase().indexOf($inputValue.toLowerCase()) !== -1) {
              var option = $("<li>".concat(_this3.options.data[item], "</li>"));

              _this3.$autocompleteWrap.append(option);
            }
          }
        }

        if (e.which === ENTER_CHAR_CODE) {
          _this3.$autocompleteWrap.children(':first').trigger('click');

          _this3.$autocompleteWrap.empty();
        }

        if ($inputValue.length === 0) {
          _this3.$input.parent().find('.mdb-autocomplete-clear').css('visibility', 'hidden');
        } else {
          _this3.$input.parent().find('.mdb-autocomplete-clear').css('visibility', 'visible');
        }

        _this3.$autocompleteWrap.children().css('color', _this3.options.dataColor);
      });
    }
  }, {
    key: "inputLiClick",
    value: function inputLiClick() {
      var _this4 = this;

      this.$autocompleteWrap.on('click', 'li', function (e) {
        e.preventDefault();

        _this4.$input.val($(e.target).text());

        _this4.$autocompleteWrap.empty();
      });
    }
  }, {
    key: "clearAutocomplete",
    value: function clearAutocomplete() {
      var _this5 = this;

      this.$clearButton.on('click', function (e) {
        e.preventDefault();
        var $this = $(e.currentTarget);
        $this.parent().find('.mdb-autocomplete').val('');
        $this.css('visibility', 'hidden');

        _this5.$autocompleteWrap.empty();

        $this.parent().find('label').removeClass('active');
      });
    }
  }, {
    key: "changeSVGcolors",
    value: function changeSVGcolors() {
      var _this6 = this;

      if (this.$input.hasClass('mdb-autocomplete')) {
        this.$input.on('click keyup', function (e) {
          e.preventDefault();
          $(e.target).parent().find('.mdb-autocomplete-clear').find('svg').css('fill', _this6.options.xColor);
        });
        this.$input.on('blur', function (e) {
          e.preventDefault();
          $(e.target).parent().find('.mdb-autocomplete-clear').find('svg').css('fill', _this6.options.xBlurColor);
        });
      }
    }
  }]);

  return mdbAutocomplete;
}();

$.fn.mdbAutocomplete = function (options) {
  return this.each(function () {
    new mdbAutocomplete($(this), options);
  });
};

})(jQuery); /*

Enhanced Bootstrap Modals
https://mdbootstrap.com
office@mdbootstrap.com

*/

(function($){

$('body').on('shown.bs.modal', '.modal', function() {
  if(!$('.modal-backdrop').length) {

    $modal_dialog = $(this).children('.modal-dialog')

    if($modal_dialog.hasClass('modal-side')) {
      $(this).addClass('modal-scrolling');
      $('body').addClass('scrollable');
    }

    if($modal_dialog.hasClass('modal-frame')) {
      $(this).addClass('modal-content-clickable');
      $('body').addClass('scrollable');
    }
  }
});
$('body').on('hidden.bs.modal', '.modal', function() {
  $('body').removeClass('scrollable');
});

})(jQuery);

/*!

* bsCustomFileInput v1.3.2 (https://github.com/Johann-S/bs-custom-file-input)
* Copyright 2018 - 2019 Johann-S <johann.servoire@gmail.com>
* Licensed under MIT (https://github.com/Johann-S/bs-custom-file-input/blob/master/LICENSE)
*/

(function (global, factory) {

typeof exports === 'object' && typeof module !== 'undefined' ? module.exports = factory() :
  typeof define === 'function' && define.amd ? define(factory) :
  (global = global || self, global.bsCustomFileInput = factory());

}(this, function () {

'use strict';

var Selector = {
  CUSTOMFILE: '.custom-file input[type="file"]',
  CUSTOMFILELABEL: '.custom-file-label',
  FORM: 'form',
  INPUT: 'input'
};

var textNodeType = 3;

var getDefaultText = function getDefaultText(input) {
  var defaultText = '';
  var label = input.parentNode.querySelector(Selector.CUSTOMFILELABEL);

  if (label) {
    defaultText = label.innerHTML;
  }

  return defaultText;
};

var findFirstChildNode = function findFirstChildNode(element) {
  if (element.childNodes.length > 0) {
    var childNodes = [].slice.call(element.childNodes);

    for (var i = 0; i < childNodes.length; i++) {
      var node = childNodes[i];

      if (node.nodeType !== textNodeType) {
        return node;
      }
    }
  }

  return element;
};

var restoreDefaultText = function restoreDefaultText(input) {
  var defaultText = input.bsCustomFileInput.defaultText;
  var label = input.parentNode.querySelector(Selector.CUSTOMFILELABEL);

  if (label) {
    var element = findFirstChildNode(label);
    element.innerHTML = defaultText;
  }
};

var fileApi = !!window.File;
var FAKE_PATH = 'fakepath';
var FAKE_PATH_SEPARATOR = '\\';

var getSelectedFiles = function getSelectedFiles(input) {
  if (input.hasAttribute('multiple') && fileApi) {
    return [].slice.call(input.files).map(function (file) {
      return file.name;
    }).join(', ');
  }

  if (input.value.indexOf(FAKE_PATH) !== -1) {
    var splittedValue = input.value.split(FAKE_PATH_SEPARATOR);
    return splittedValue[splittedValue.length - 1];
  }

  return input.value;
};

function handleInputChange() {
  var label = this.parentNode.querySelector(Selector.CUSTOMFILELABEL);

  if (label) {
    var element = findFirstChildNode(label);
    var inputValue = getSelectedFiles(this);

    if (inputValue.length) {
      element.innerHTML = inputValue;
    } else {
      restoreDefaultText(this);
    }
  }
}

function handleFormReset() {
  var customFileList = [].slice.call(this.querySelectorAll(Selector.INPUT)).filter(function (input) {
    return !!input.bsCustomFileInput;
  });

  for (var i = 0, len = customFileList.length; i < len; i++) {
    restoreDefaultText(customFileList[i]);
  }
}

var customProperty = 'bsCustomFileInput';
var Event = {
  FORMRESET: 'reset',
  INPUTCHANGE: 'change'
};
var bsCustomFileInput = {
  init: function init(inputSelector, formSelector) {
    if (inputSelector === void 0) {
      inputSelector = Selector.CUSTOMFILE;
    }

    if (formSelector === void 0) {
      formSelector = Selector.FORM;
    }

    var customFileInputList = [].slice.call(document.querySelectorAll(inputSelector));
    var formList = [].slice.call(document.querySelectorAll(formSelector));

    for (var i = 0, len = customFileInputList.length; i < len; i++) {
      var input = customFileInputList[i];
      Object.defineProperty(input, customProperty, {
        value: {
          defaultText: getDefaultText(input)
        },
        writable: true
      });
      handleInputChange.call(input);
      input.addEventListener(Event.INPUTCHANGE, handleInputChange);
    }

    for (var _i = 0, _len = formList.length; _i < _len; _i++) {
      formList[_i].addEventListener(Event.FORMRESET, handleFormReset);

      Object.defineProperty(formList[_i], customProperty, {
        value: true,
        writable: true
      });
    }
  },
  destroy: function destroy() {
    var formList = [].slice.call(document.querySelectorAll(Selector.FORM)).filter(function (form) {
      return !!form.bsCustomFileInput;
    });
    var customFileInputList = [].slice.call(document.querySelectorAll(Selector.INPUT)).filter(function (input) {
      return !!input.bsCustomFileInput;
    });

    for (var i = 0, len = customFileInputList.length; i < len; i++) {
      var input = customFileInputList[i];
      restoreDefaultText(input);
      input[customProperty] = undefined;
      input.removeEventListener(Event.INPUTCHANGE, handleInputChange);
    }

    for (var _i2 = 0, _len2 = formList.length; _i2 < _len2; _i2++) {
      formList[_i2].removeEventListener(Event.FORMRESET, handleFormReset);

      formList[_i2][customProperty] = undefined;
    }
  }
};

return bsCustomFileInput;

})); //# sourceMappingURL=bs-custom-file-input.js.map

document.addEventListener(“DOMContentLoaded”, function () {

bsCustomFileInput.init()

});

“use strict”;

var toggler = document.getElementsByClassName(“rotate”); var i;

for (i = 0; i < toggler.length; i++) {

toggler[i].addEventListener("click", function () {
  this.parentElement.querySelector(".nested").classList.toggle("active");
  this.classList.toggle("down");
});

}