diff --git a/js/webflow.js b/js/webflow.js
deleted file mode 100644
index b1c8629..0000000
--- a/js/webflow.js
+++ /dev/null
@@ -1,4283 +0,0 @@
-/*!
- * Webflow: Front-end site library
- * @license MIT
- * Inline scripts may access the api using an async handler:
- * var Webflow = Webflow || [];
- * Webflow.push(readyFunction);
- */
-/******/ (function(modules) { // webpackBootstrap
-/******/ // The module cache
-/******/ var installedModules = {};
-/******/
-/******/ // The require function
-/******/ function __webpack_require__(moduleId) {
-/******/
-/******/ // Check if module is in cache
-/******/ if(installedModules[moduleId]) {
-/******/ return installedModules[moduleId].exports;
-/******/ }
-/******/ // Create a new module (and put it into the cache)
-/******/ var module = installedModules[moduleId] = {
-/******/ i: moduleId,
-/******/ l: false,
-/******/ exports: {}
-/******/ };
-/******/
-/******/ // Execute the module function
-/******/ modules[moduleId].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[key]; }.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['default']; } :
-/******/ 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 = 3);
-/******/ })
-/************************************************************************/
-/******/ ([
-/* 0 */
-/***/ (function(module, exports, __webpack_require__) {
-
-"use strict";
- // @wf-will-never-add-flow-to-this-file
-
-/* globals window, document, navigator, WEBFLOW_ENV_TEST */
-
-/* eslint-disable no-var */
-
-/**
- * Webflow: Core site library
- */
-
-var Webflow = {};
-var modules = {};
-var primary = [];
-var secondary = window.Webflow || [];
-var $ = window.jQuery;
-var $win = $(window);
-var $doc = $(document);
-var isFunction = $.isFunction;
-
-var _ = Webflow._ = __webpack_require__(5);
-
-var tram = Webflow.tram = __webpack_require__(1) && $.tram;
-var domready = false;
-var destroyed = false;
-tram.config.hideBackface = false;
-tram.config.keepInherited = true;
-/**
- * Webflow.define - Define a named module
- * @param {string} name
- * @param {function} factory
- * @param {object} options
- * @return {object}
- */
-
-Webflow.define = function (name, factory, options) {
- if (modules[name]) {
- unbindModule(modules[name]);
- }
-
- var instance = modules[name] = factory($, _, options) || {};
- bindModule(instance);
- return instance;
-};
-/**
- * Webflow.require - Require a named module
- * @param {string} name
- * @return {object}
- */
-
-
-Webflow.require = function (name) {
- return modules[name];
-};
-
-function bindModule(module) {
- // If running in Webflow app, subscribe to design/preview events
- if (Webflow.env()) {
- isFunction(module.design) && $win.on('__wf_design', module.design);
- isFunction(module.preview) && $win.on('__wf_preview', module.preview);
- } // Subscribe to front-end destroy event
-
-
- isFunction(module.destroy) && $win.on('__wf_destroy', module.destroy); // Look for ready method on module
-
- if (module.ready && isFunction(module.ready)) {
- addReady(module);
- }
-}
-
-function addReady(module) {
- // If domready has already happened, run ready method
- if (domready) {
- module.ready();
- return;
- } // Otherwise add ready method to the primary queue (only once)
-
-
- if (_.contains(primary, module.ready)) {
- return;
- }
-
- primary.push(module.ready);
-}
-
-function unbindModule(module) {
- // Unsubscribe module from window events
- isFunction(module.design) && $win.off('__wf_design', module.design);
- isFunction(module.preview) && $win.off('__wf_preview', module.preview);
- isFunction(module.destroy) && $win.off('__wf_destroy', module.destroy); // Remove ready method from primary queue
-
- if (module.ready && isFunction(module.ready)) {
- removeReady(module);
- }
-}
-
-function removeReady(module) {
- primary = _.filter(primary, function (readyFn) {
- return readyFn !== module.ready;
- });
-}
-/**
- * Webflow.push - Add a ready handler into secondary queue
- * @param {function} ready Callback to invoke on domready
- */
-
-
-Webflow.push = function (ready) {
- // If domready has already happened, invoke handler
- if (domready) {
- isFunction(ready) && ready();
- return;
- } // Otherwise push into secondary queue
-
-
- secondary.push(ready);
-};
-/**
- * Webflow.env - Get the state of the Webflow app
- * @param {string} mode [optional]
- * @return {boolean}
- */
-
-
-Webflow.env = function (mode) {
- var designFlag = window.__wf_design;
- var inApp = typeof designFlag !== 'undefined';
-
- if (!mode) {
- return inApp;
- }
-
- if (mode === 'design') {
- return inApp && designFlag;
- }
-
- if (mode === 'preview') {
- return inApp && !designFlag;
- }
-
- if (mode === 'slug') {
- return inApp && window.__wf_slug;
- }
-
- if (mode === 'editor') {
- return window.WebflowEditor;
- }
-
- if (mode === 'test') {
- return false || window.__wf_test;
- }
-
- if (mode === 'frame') {
- return window !== window.top;
- }
-}; // Feature detects + browser sniffs ಠ_ಠ
-
-
-var userAgent = navigator.userAgent.toLowerCase();
-var touch = Webflow.env.touch = 'ontouchstart' in window || window.DocumentTouch && document instanceof window.DocumentTouch;
-var chrome = Webflow.env.chrome = /chrome/.test(userAgent) && /Google/.test(navigator.vendor) && parseInt(userAgent.match(/chrome\/(\d+)\./)[1], 10);
-var ios = Webflow.env.ios = /(ipod|iphone|ipad)/.test(userAgent);
-Webflow.env.safari = /safari/.test(userAgent) && !chrome && !ios; // Maintain current touch target to prevent late clicks on touch devices
-
-var touchTarget; // Listen for both events to support touch/mouse hybrid devices
-
-touch && $doc.on('touchstart mousedown', function (evt) {
- touchTarget = evt.target;
-});
-/**
- * Webflow.validClick - validate click target against current touch target
- * @param {HTMLElement} clickTarget Element being clicked
- * @return {Boolean} True if click target is valid (always true on non-touch)
- */
-
-Webflow.validClick = touch ? function (clickTarget) {
- return clickTarget === touchTarget || $.contains(clickTarget, touchTarget);
-} : function () {
- return true;
-};
-/**
- * Webflow.resize, Webflow.scroll - throttled event proxies
- */
-
-var resizeEvents = 'resize.webflow orientationchange.webflow load.webflow';
-var scrollEvents = 'scroll.webflow ' + resizeEvents;
-Webflow.resize = eventProxy($win, resizeEvents);
-Webflow.scroll = eventProxy($win, scrollEvents);
-Webflow.redraw = eventProxy(); // Create a proxy instance for throttled events
-
-function eventProxy(target, types) {
- // Set up throttled method (using custom frame-based _.throttle)
- var handlers = [];
- var proxy = {};
- proxy.up = _.throttle(function (evt) {
- _.each(handlers, function (h) {
- h(evt);
- });
- }); // Bind events to target
-
- if (target && types) {
- target.on(types, proxy.up);
- }
- /**
- * Add an event handler
- * @param {function} handler
- */
-
-
- proxy.on = function (handler) {
- if (typeof handler !== 'function') {
- return;
- }
-
- if (_.contains(handlers, handler)) {
- return;
- }
-
- handlers.push(handler);
- };
- /**
- * Remove an event handler
- * @param {function} handler
- */
-
-
- proxy.off = function (handler) {
- // If no arguments supplied, clear all handlers
- if (!arguments.length) {
- handlers = [];
- return;
- } // Otherwise, remove handler from the list
-
-
- handlers = _.filter(handlers, function (h) {
- return h !== handler;
- });
- };
-
- return proxy;
-} // Webflow.location - Wrap window.location in api
-
-
-Webflow.location = function (url) {
- window.location = url;
-};
-
-if (Webflow.env()) {
- // Ignore redirects inside a Webflow design/edit environment
- Webflow.location = function () {};
-} // Webflow.ready - Call primary and secondary handlers
-
-
-Webflow.ready = function () {
- domready = true; // Restore modules after destroy
-
- if (destroyed) {
- restoreModules(); // Otherwise run primary ready methods
- } else {
- _.each(primary, callReady);
- } // Run secondary ready methods
-
-
- _.each(secondary, callReady); // Trigger resize
-
-
- Webflow.resize.up();
-};
-
-function callReady(readyFn) {
- isFunction(readyFn) && readyFn();
-}
-
-function restoreModules() {
- destroyed = false;
-
- _.each(modules, bindModule);
-}
-/**
- * Webflow.load - Add a window load handler that will run even if load event has already happened
- * @param {function} handler
- */
-
-
-var deferLoad;
-
-Webflow.load = function (handler) {
- deferLoad.then(handler);
-};
-
-function bindLoad() {
- // Reject any previous deferred (to support destroy)
- if (deferLoad) {
- deferLoad.reject();
- $win.off('load', deferLoad.resolve);
- } // Create deferred and bind window load event
-
-
- deferLoad = new $.Deferred();
- $win.on('load', deferLoad.resolve);
-} // Webflow.destroy - Trigger a destroy event for all modules
-
-
-Webflow.destroy = function (options) {
- options = options || {};
- destroyed = true;
- $win.triggerHandler('__wf_destroy'); // Allow domready reset for tests
-
- if (options.domready != null) {
- domready = options.domready;
- } // Unbind modules
-
-
- _.each(modules, unbindModule); // Clear any proxy event handlers
-
-
- Webflow.resize.off();
- Webflow.scroll.off();
- Webflow.redraw.off(); // Clear any queued ready methods
-
- primary = [];
- secondary = []; // If load event has not yet fired, replace the deferred
-
- if (deferLoad.state() === 'pending') {
- bindLoad();
- }
-}; // Listen for domready
-
-
-$(Webflow.ready); // Listen for window.onload and resolve deferred
-
-bindLoad(); // Export commonjs module
-
-module.exports = window.Webflow = Webflow;
-
-/***/ }),
-/* 1 */
-/***/ (function(module, exports, __webpack_require__) {
-
-"use strict";
- // @wf-will-never-add-flow-to-this-file
-
-/* eslint-disable eslint-comments/no-unlimited-disable */
-
-/* eslint-disable */
-
-/*!
- * tram.js v0.8.2-global
- * Cross-browser CSS3 transitions in JavaScript
- * https://github.com/bkwld/tram
- * MIT License
- */
-
-/* prettier-ignore */
-
-var _interopRequireDefault = __webpack_require__(2);
-
-var _typeof2 = _interopRequireDefault(__webpack_require__(6));
-
-window.tram = function (a) {
- function b(a, b) {
- var c = new M.Bare();
- return c.init(a, b);
- }
-
- function c(a) {
- return a.replace(/[A-Z]/g, function (a) {
- return "-" + a.toLowerCase();
- });
- }
-
- function d(a) {
- var b = parseInt(a.slice(1), 16),
- c = b >> 16 & 255,
- d = b >> 8 & 255,
- e = 255 & b;
- return [c, d, e];
- }
-
- function e(a, b, c) {
- return "#" + (1 << 24 | a << 16 | b << 8 | c).toString(16).slice(1);
- }
-
- function f() {}
-
- function g(a, b) {
- j("Type warning: Expected: [" + a + "] Got: [" + (0, _typeof2["default"])(b) + "] " + b);
- }
-
- function h(a, b, c) {
- j("Units do not match [" + a + "]: " + b + ", " + c);
- }
-
- function i(a, b, c) {
- if (void 0 !== b && (c = b), void 0 === a) return c;
- var d = c;
- return $.test(a) || !_.test(a) ? d = parseInt(a, 10) : _.test(a) && (d = 1e3 * parseFloat(a)), 0 > d && (d = 0), d === d ? d : c;
- }
-
- function j(a) {
- U.debug && window && window.console.warn(a);
- }
-
- function k(a) {
- for (var b = -1, c = a ? a.length : 0, d = []; ++b < c;) {
- var e = a[b];
- e && d.push(e);
- }
-
- return d;
- }
-
- var l = function (a, b, c) {
- function d(a) {
- return "object" == (0, _typeof2["default"])(a);
- }
-
- function e(a) {
- return "function" == typeof a;
- }
-
- function f() {}
-
- function g(h, i) {
- function j() {
- var a = new k();
- return e(a.init) && a.init.apply(a, arguments), a;
- }
-
- function k() {}
-
- i === c && (i = h, h = Object), j.Bare = k;
- var l,
- m = f[a] = h[a],
- n = k[a] = j[a] = new f();
- return n.constructor = j, j.mixin = function (b) {
- return k[a] = j[a] = g(j, b)[a], j;
- }, j.open = function (a) {
- if (l = {}, e(a) ? l = a.call(j, n, m, j, h) : d(a) && (l = a), d(l)) for (var c in l) {
- b.call(l, c) && (n[c] = l[c]);
- }
- return e(n.init) || (n.init = h), j;
- }, j.open(i);
- }
-
- return g;
- }("prototype", {}.hasOwnProperty),
- m = {
- ease: ["ease", function (a, b, c, d) {
- var e = (a /= d) * a,
- f = e * a;
- return b + c * (-2.75 * f * e + 11 * e * e + -15.5 * f + 8 * e + .25 * a);
- }],
- "ease-in": ["ease-in", function (a, b, c, d) {
- var e = (a /= d) * a,
- f = e * a;
- return b + c * (-1 * f * e + 3 * e * e + -3 * f + 2 * e);
- }],
- "ease-out": ["ease-out", function (a, b, c, d) {
- var e = (a /= d) * a,
- f = e * a;
- return b + c * (.3 * f * e + -1.6 * e * e + 2.2 * f + -1.8 * e + 1.9 * a);
- }],
- "ease-in-out": ["ease-in-out", function (a, b, c, d) {
- var e = (a /= d) * a,
- f = e * a;
- return b + c * (2 * f * e + -5 * e * e + 2 * f + 2 * e);
- }],
- linear: ["linear", function (a, b, c, d) {
- return c * a / d + b;
- }],
- "ease-in-quad": ["cubic-bezier(0.550, 0.085, 0.680, 0.530)", function (a, b, c, d) {
- return c * (a /= d) * a + b;
- }],
- "ease-out-quad": ["cubic-bezier(0.250, 0.460, 0.450, 0.940)", function (a, b, c, d) {
- return -c * (a /= d) * (a - 2) + b;
- }],
- "ease-in-out-quad": ["cubic-bezier(0.455, 0.030, 0.515, 0.955)", function (a, b, c, d) {
- return (a /= d / 2) < 1 ? c / 2 * a * a + b : -c / 2 * (--a * (a - 2) - 1) + b;
- }],
- "ease-in-cubic": ["cubic-bezier(0.550, 0.055, 0.675, 0.190)", function (a, b, c, d) {
- return c * (a /= d) * a * a + b;
- }],
- "ease-out-cubic": ["cubic-bezier(0.215, 0.610, 0.355, 1)", function (a, b, c, d) {
- return c * ((a = a / d - 1) * a * a + 1) + b;
- }],
- "ease-in-out-cubic": ["cubic-bezier(0.645, 0.045, 0.355, 1)", function (a, b, c, d) {
- return (a /= d / 2) < 1 ? c / 2 * a * a * a + b : c / 2 * ((a -= 2) * a * a + 2) + b;
- }],
- "ease-in-quart": ["cubic-bezier(0.895, 0.030, 0.685, 0.220)", function (a, b, c, d) {
- return c * (a /= d) * a * a * a + b;
- }],
- "ease-out-quart": ["cubic-bezier(0.165, 0.840, 0.440, 1)", function (a, b, c, d) {
- return -c * ((a = a / d - 1) * a * a * a - 1) + b;
- }],
- "ease-in-out-quart": ["cubic-bezier(0.770, 0, 0.175, 1)", function (a, b, c, d) {
- return (a /= d / 2) < 1 ? c / 2 * a * a * a * a + b : -c / 2 * ((a -= 2) * a * a * a - 2) + b;
- }],
- "ease-in-quint": ["cubic-bezier(0.755, 0.050, 0.855, 0.060)", function (a, b, c, d) {
- return c * (a /= d) * a * a * a * a + b;
- }],
- "ease-out-quint": ["cubic-bezier(0.230, 1, 0.320, 1)", function (a, b, c, d) {
- return c * ((a = a / d - 1) * a * a * a * a + 1) + b;
- }],
- "ease-in-out-quint": ["cubic-bezier(0.860, 0, 0.070, 1)", function (a, b, c, d) {
- return (a /= d / 2) < 1 ? c / 2 * a * a * a * a * a + b : c / 2 * ((a -= 2) * a * a * a * a + 2) + b;
- }],
- "ease-in-sine": ["cubic-bezier(0.470, 0, 0.745, 0.715)", function (a, b, c, d) {
- return -c * Math.cos(a / d * (Math.PI / 2)) + c + b;
- }],
- "ease-out-sine": ["cubic-bezier(0.390, 0.575, 0.565, 1)", function (a, b, c, d) {
- return c * Math.sin(a / d * (Math.PI / 2)) + b;
- }],
- "ease-in-out-sine": ["cubic-bezier(0.445, 0.050, 0.550, 0.950)", function (a, b, c, d) {
- return -c / 2 * (Math.cos(Math.PI * a / d) - 1) + b;
- }],
- "ease-in-expo": ["cubic-bezier(0.950, 0.050, 0.795, 0.035)", function (a, b, c, d) {
- return 0 === a ? b : c * Math.pow(2, 10 * (a / d - 1)) + b;
- }],
- "ease-out-expo": ["cubic-bezier(0.190, 1, 0.220, 1)", function (a, b, c, d) {
- return a === d ? b + c : c * (-Math.pow(2, -10 * a / d) + 1) + b;
- }],
- "ease-in-out-expo": ["cubic-bezier(1, 0, 0, 1)", function (a, b, c, d) {
- return 0 === a ? b : a === d ? b + c : (a /= d / 2) < 1 ? c / 2 * Math.pow(2, 10 * (a - 1)) + b : c / 2 * (-Math.pow(2, -10 * --a) + 2) + b;
- }],
- "ease-in-circ": ["cubic-bezier(0.600, 0.040, 0.980, 0.335)", function (a, b, c, d) {
- return -c * (Math.sqrt(1 - (a /= d) * a) - 1) + b;
- }],
- "ease-out-circ": ["cubic-bezier(0.075, 0.820, 0.165, 1)", function (a, b, c, d) {
- return c * Math.sqrt(1 - (a = a / d - 1) * a) + b;
- }],
- "ease-in-out-circ": ["cubic-bezier(0.785, 0.135, 0.150, 0.860)", function (a, b, c, d) {
- return (a /= d / 2) < 1 ? -c / 2 * (Math.sqrt(1 - a * a) - 1) + b : c / 2 * (Math.sqrt(1 - (a -= 2) * a) + 1) + b;
- }],
- "ease-in-back": ["cubic-bezier(0.600, -0.280, 0.735, 0.045)", function (a, b, c, d, e) {
- return void 0 === e && (e = 1.70158), c * (a /= d) * a * ((e + 1) * a - e) + b;
- }],
- "ease-out-back": ["cubic-bezier(0.175, 0.885, 0.320, 1.275)", function (a, b, c, d, e) {
- return void 0 === e && (e = 1.70158), c * ((a = a / d - 1) * a * ((e + 1) * a + e) + 1) + b;
- }],
- "ease-in-out-back": ["cubic-bezier(0.680, -0.550, 0.265, 1.550)", function (a, b, c, d, e) {
- return void 0 === e && (e = 1.70158), (a /= d / 2) < 1 ? c / 2 * a * a * (((e *= 1.525) + 1) * a - e) + b : c / 2 * ((a -= 2) * a * (((e *= 1.525) + 1) * a + e) + 2) + b;
- }]
- },
- n = {
- "ease-in-back": "cubic-bezier(0.600, 0, 0.735, 0.045)",
- "ease-out-back": "cubic-bezier(0.175, 0.885, 0.320, 1)",
- "ease-in-out-back": "cubic-bezier(0.680, 0, 0.265, 1)"
- },
- o = document,
- p = window,
- q = "bkwld-tram",
- r = /[\-\.0-9]/g,
- s = /[A-Z]/,
- t = "number",
- u = /^(rgb|#)/,
- v = /(em|cm|mm|in|pt|pc|px)$/,
- w = /(em|cm|mm|in|pt|pc|px|%)$/,
- x = /(deg|rad|turn)$/,
- y = "unitless",
- z = /(all|none) 0s ease 0s/,
- A = /^(width|height)$/,
- B = " ",
- C = o.createElement("a"),
- D = ["Webkit", "Moz", "O", "ms"],
- E = ["-webkit-", "-moz-", "-o-", "-ms-"],
- F = function F(a) {
- if (a in C.style) return {
- dom: a,
- css: a
- };
- var b,
- c,
- d = "",
- e = a.split("-");
-
- for (b = 0; b < e.length; b++) {
- d += e[b].charAt(0).toUpperCase() + e[b].slice(1);
- }
-
- for (b = 0; b < D.length; b++) {
- if (c = D[b] + d, c in C.style) return {
- dom: c,
- css: E[b] + a
- };
- }
- },
- G = b.support = {
- bind: Function.prototype.bind,
- transform: F("transform"),
- transition: F("transition"),
- backface: F("backface-visibility"),
- timing: F("transition-timing-function")
- };
-
- if (G.transition) {
- var H = G.timing.dom;
- if (C.style[H] = m["ease-in-back"][0], !C.style[H]) for (var I in n) {
- m[I][0] = n[I];
- }
- }
-
- var J = b.frame = function () {
- var a = p.requestAnimationFrame || p.webkitRequestAnimationFrame || p.mozRequestAnimationFrame || p.oRequestAnimationFrame || p.msRequestAnimationFrame;
- return a && G.bind ? a.bind(p) : function (a) {
- p.setTimeout(a, 16);
- };
- }(),
- K = b.now = function () {
- var a = p.performance,
- b = a && (a.now || a.webkitNow || a.msNow || a.mozNow);
- return b && G.bind ? b.bind(a) : Date.now || function () {
- return +new Date();
- };
- }(),
- L = l(function (b) {
- function d(a, b) {
- var c = k(("" + a).split(B)),
- d = c[0];
- b = b || {};
- var e = Y[d];
- if (!e) return j("Unsupported property: " + d);
-
- if (!b.weak || !this.props[d]) {
- var f = e[0],
- g = this.props[d];
- return g || (g = this.props[d] = new f.Bare()), g.init(this.$el, c, e, b), g;
- }
- }
-
- function e(a, b, c) {
- if (a) {
- var e = (0, _typeof2["default"])(a);
- if (b || (this.timer && this.timer.destroy(), this.queue = [], this.active = !1), "number" == e && b) return this.timer = new S({
- duration: a,
- context: this,
- complete: h
- }), void (this.active = !0);
-
- if ("string" == e && b) {
- switch (a) {
- case "hide":
- o.call(this);
- break;
-
- case "stop":
- l.call(this);
- break;
-
- case "redraw":
- p.call(this);
- break;
-
- default:
- d.call(this, a, c && c[1]);
- }
-
- return h.call(this);
- }
-
- if ("function" == e) return void a.call(this, this);
-
- if ("object" == e) {
- var f = 0;
- u.call(this, a, function (a, b) {
- a.span > f && (f = a.span), a.stop(), a.animate(b);
- }, function (a) {
- "wait" in a && (f = i(a.wait, 0));
- }), t.call(this), f > 0 && (this.timer = new S({
- duration: f,
- context: this
- }), this.active = !0, b && (this.timer.complete = h));
- var g = this,
- j = !1,
- k = {};
- J(function () {
- u.call(g, a, function (a) {
- a.active && (j = !0, k[a.name] = a.nextStyle);
- }), j && g.$el.css(k);
- });
- }
- }
- }
-
- function f(a) {
- a = i(a, 0), this.active ? this.queue.push({
- options: a
- }) : (this.timer = new S({
- duration: a,
- context: this,
- complete: h
- }), this.active = !0);
- }
-
- function g(a) {
- return this.active ? (this.queue.push({
- options: a,
- args: arguments
- }), void (this.timer.complete = h)) : j("No active transition timer. Use start() or wait() before then().");
- }
-
- function h() {
- if (this.timer && this.timer.destroy(), this.active = !1, this.queue.length) {
- var a = this.queue.shift();
- e.call(this, a.options, !0, a.args);
- }
- }
-
- function l(a) {
- this.timer && this.timer.destroy(), this.queue = [], this.active = !1;
- var b;
- "string" == typeof a ? (b = {}, b[a] = 1) : b = "object" == (0, _typeof2["default"])(a) && null != a ? a : this.props, u.call(this, b, v), t.call(this);
- }
-
- function m(a) {
- l.call(this, a), u.call(this, a, w, x);
- }
-
- function n(a) {
- "string" != typeof a && (a = "block"), this.el.style.display = a;
- }
-
- function o() {
- l.call(this), this.el.style.display = "none";
- }
-
- function p() {
- this.el.offsetHeight;
- }
-
- function r() {
- l.call(this), a.removeData(this.el, q), this.$el = this.el = null;
- }
-
- function t() {
- var a,
- b,
- c = [];
- this.upstream && c.push(this.upstream);
-
- for (a in this.props) {
- b = this.props[a], b.active && c.push(b.string);
- }
-
- c = c.join(","), this.style !== c && (this.style = c, this.el.style[G.transition.dom] = c);
- }
-
- function u(a, b, e) {
- var f,
- g,
- h,
- i,
- j = b !== v,
- k = {};
-
- for (f in a) {
- h = a[f], f in Z ? (k.transform || (k.transform = {}), k.transform[f] = h) : (s.test(f) && (f = c(f)), f in Y ? k[f] = h : (i || (i = {}), i[f] = h));
- }
-
- for (f in k) {
- if (h = k[f], g = this.props[f], !g) {
- if (!j) continue;
- g = d.call(this, f);
- }
-
- b.call(this, g, h);
- }
-
- e && i && e.call(this, i);
- }
-
- function v(a) {
- a.stop();
- }
-
- function w(a, b) {
- a.set(b);
- }
-
- function x(a) {
- this.$el.css(a);
- }
-
- function y(a, c) {
- b[a] = function () {
- return this.children ? A.call(this, c, arguments) : (this.el && c.apply(this, arguments), this);
- };
- }
-
- function A(a, b) {
- var c,
- d = this.children.length;
-
- for (c = 0; d > c; c++) {
- a.apply(this.children[c], b);
- }
-
- return this;
- }
-
- b.init = function (b) {
- if (this.$el = a(b), this.el = this.$el[0], this.props = {}, this.queue = [], this.style = "", this.active = !1, U.keepInherited && !U.fallback) {
- var c = W(this.el, "transition");
- c && !z.test(c) && (this.upstream = c);
- }
-
- G.backface && U.hideBackface && V(this.el, G.backface.css, "hidden");
- }, y("add", d), y("start", e), y("wait", f), y("then", g), y("next", h), y("stop", l), y("set", m), y("show", n), y("hide", o), y("redraw", p), y("destroy", r);
- }),
- M = l(L, function (b) {
- function c(b, c) {
- var d = a.data(b, q) || a.data(b, q, new L.Bare());
- return d.el || d.init(b), c ? d.start(c) : d;
- }
-
- b.init = function (b, d) {
- var e = a(b);
- if (!e.length) return this;
- if (1 === e.length) return c(e[0], d);
- var f = [];
- return e.each(function (a, b) {
- f.push(c(b, d));
- }), this.children = f, this;
- };
- }),
- N = l(function (a) {
- function b() {
- var a = this.get();
- this.update("auto");
- var b = this.get();
- return this.update(a), b;
- }
-
- function c(a, b, c) {
- return void 0 !== b && (c = b), a in m ? a : c;
- }
-
- function d(a) {
- var b = /rgba?\((\d+),\s*(\d+),\s*(\d+)/.exec(a);
- return (b ? e(b[1], b[2], b[3]) : a).replace(/#(\w)(\w)(\w)$/, "#$1$1$2$2$3$3");
- }
-
- var f = {
- duration: 500,
- ease: "ease",
- delay: 0
- };
- a.init = function (a, b, d, e) {
- this.$el = a, this.el = a[0];
- var g = b[0];
- d[2] && (g = d[2]), X[g] && (g = X[g]), this.name = g, this.type = d[1], this.duration = i(b[1], this.duration, f.duration), this.ease = c(b[2], this.ease, f.ease), this.delay = i(b[3], this.delay, f.delay), this.span = this.duration + this.delay, this.active = !1, this.nextStyle = null, this.auto = A.test(this.name), this.unit = e.unit || this.unit || U.defaultUnit, this.angle = e.angle || this.angle || U.defaultAngle, U.fallback || e.fallback ? this.animate = this.fallback : (this.animate = this.transition, this.string = this.name + B + this.duration + "ms" + ("ease" != this.ease ? B + m[this.ease][0] : "") + (this.delay ? B + this.delay + "ms" : ""));
- }, a.set = function (a) {
- a = this.convert(a, this.type), this.update(a), this.redraw();
- }, a.transition = function (a) {
- this.active = !0, a = this.convert(a, this.type), this.auto && ("auto" == this.el.style[this.name] && (this.update(this.get()), this.redraw()), "auto" == a && (a = b.call(this))), this.nextStyle = a;
- }, a.fallback = function (a) {
- var c = this.el.style[this.name] || this.convert(this.get(), this.type);
- a = this.convert(a, this.type), this.auto && ("auto" == c && (c = this.convert(this.get(), this.type)), "auto" == a && (a = b.call(this))), this.tween = new R({
- from: c,
- to: a,
- duration: this.duration,
- delay: this.delay,
- ease: this.ease,
- update: this.update,
- context: this
- });
- }, a.get = function () {
- return W(this.el, this.name);
- }, a.update = function (a) {
- V(this.el, this.name, a);
- }, a.stop = function () {
- (this.active || this.nextStyle) && (this.active = !1, this.nextStyle = null, V(this.el, this.name, this.get()));
- var a = this.tween;
- a && a.context && a.destroy();
- }, a.convert = function (a, b) {
- if ("auto" == a && this.auto) return a;
- var c,
- e = "number" == typeof a,
- f = "string" == typeof a;
-
- switch (b) {
- case t:
- if (e) return a;
- if (f && "" === a.replace(r, "")) return +a;
- c = "number(unitless)";
- break;
-
- case u:
- if (f) {
- if ("" === a && this.original) return this.original;
- if (b.test(a)) return "#" == a.charAt(0) && 7 == a.length ? a : d(a);
- }
-
- c = "hex or rgb string";
- break;
-
- case v:
- if (e) return a + this.unit;
- if (f && b.test(a)) return a;
- c = "number(px) or string(unit)";
- break;
-
- case w:
- if (e) return a + this.unit;
- if (f && b.test(a)) return a;
- c = "number(px) or string(unit or %)";
- break;
-
- case x:
- if (e) return a + this.angle;
- if (f && b.test(a)) return a;
- c = "number(deg) or string(angle)";
- break;
-
- case y:
- if (e) return a;
- if (f && w.test(a)) return a;
- c = "number(unitless) or string(unit or %)";
- }
-
- return g(c, a), a;
- }, a.redraw = function () {
- this.el.offsetHeight;
- };
- }),
- O = l(N, function (a, b) {
- a.init = function () {
- b.init.apply(this, arguments), this.original || (this.original = this.convert(this.get(), u));
- };
- }),
- P = l(N, function (a, b) {
- a.init = function () {
- b.init.apply(this, arguments), this.animate = this.fallback;
- }, a.get = function () {
- return this.$el[this.name]();
- }, a.update = function (a) {
- this.$el[this.name](a);
- };
- }),
- Q = l(N, function (a, b) {
- function c(a, b) {
- var c, d, e, f, g;
-
- for (c in a) {
- f = Z[c], e = f[0], d = f[1] || c, g = this.convert(a[c], e), b.call(this, d, g, e);
- }
- }
-
- a.init = function () {
- b.init.apply(this, arguments), this.current || (this.current = {}, Z.perspective && U.perspective && (this.current.perspective = U.perspective, V(this.el, this.name, this.style(this.current)), this.redraw()));
- }, a.set = function (a) {
- c.call(this, a, function (a, b) {
- this.current[a] = b;
- }), V(this.el, this.name, this.style(this.current)), this.redraw();
- }, a.transition = function (a) {
- var b = this.values(a);
- this.tween = new T({
- current: this.current,
- values: b,
- duration: this.duration,
- delay: this.delay,
- ease: this.ease
- });
- var c,
- d = {};
-
- for (c in this.current) {
- d[c] = c in b ? b[c] : this.current[c];
- }
-
- this.active = !0, this.nextStyle = this.style(d);
- }, a.fallback = function (a) {
- var b = this.values(a);
- this.tween = new T({
- current: this.current,
- values: b,
- duration: this.duration,
- delay: this.delay,
- ease: this.ease,
- update: this.update,
- context: this
- });
- }, a.update = function () {
- V(this.el, this.name, this.style(this.current));
- }, a.style = function (a) {
- var b,
- c = "";
-
- for (b in a) {
- c += b + "(" + a[b] + ") ";
- }
-
- return c;
- }, a.values = function (a) {
- var b,
- d = {};
- return c.call(this, a, function (a, c, e) {
- d[a] = c, void 0 === this.current[a] && (b = 0, ~a.indexOf("scale") && (b = 1), this.current[a] = this.convert(b, e));
- }), d;
- };
- }),
- R = l(function (b) {
- function c(a) {
- 1 === n.push(a) && J(g);
- }
-
- function g() {
- var a,
- b,
- c,
- d = n.length;
- if (d) for (J(g), b = K(), a = d; a--;) {
- c = n[a], c && c.render(b);
- }
- }
-
- function i(b) {
- var c,
- d = a.inArray(b, n);
- d >= 0 && (c = n.slice(d + 1), n.length = d, c.length && (n = n.concat(c)));
- }
-
- function j(a) {
- return Math.round(a * o) / o;
- }
-
- function k(a, b, c) {
- return e(a[0] + c * (b[0] - a[0]), a[1] + c * (b[1] - a[1]), a[2] + c * (b[2] - a[2]));
- }
-
- var l = {
- ease: m.ease[1],
- from: 0,
- to: 1
- };
- b.init = function (a) {
- this.duration = a.duration || 0, this.delay = a.delay || 0;
- var b = a.ease || l.ease;
- m[b] && (b = m[b][1]), "function" != typeof b && (b = l.ease), this.ease = b, this.update = a.update || f, this.complete = a.complete || f, this.context = a.context || this, this.name = a.name;
- var c = a.from,
- d = a.to;
- void 0 === c && (c = l.from), void 0 === d && (d = l.to), this.unit = a.unit || "", "number" == typeof c && "number" == typeof d ? (this.begin = c, this.change = d - c) : this.format(d, c), this.value = this.begin + this.unit, this.start = K(), a.autoplay !== !1 && this.play();
- }, b.play = function () {
- this.active || (this.start || (this.start = K()), this.active = !0, c(this));
- }, b.stop = function () {
- this.active && (this.active = !1, i(this));
- }, b.render = function (a) {
- var b,
- c = a - this.start;
-
- if (this.delay) {
- if (c <= this.delay) return;
- c -= this.delay;
- }
-
- if (c < this.duration) {
- var d = this.ease(c, 0, 1, this.duration);
- return b = this.startRGB ? k(this.startRGB, this.endRGB, d) : j(this.begin + d * this.change), this.value = b + this.unit, void this.update.call(this.context, this.value);
- }
-
- b = this.endHex || this.begin + this.change, this.value = b + this.unit, this.update.call(this.context, this.value), this.complete.call(this.context), this.destroy();
- }, b.format = function (a, b) {
- if (b += "", a += "", "#" == a.charAt(0)) return this.startRGB = d(b), this.endRGB = d(a), this.endHex = a, this.begin = 0, void (this.change = 1);
-
- if (!this.unit) {
- var c = b.replace(r, ""),
- e = a.replace(r, "");
- c !== e && h("tween", b, a), this.unit = c;
- }
-
- b = parseFloat(b), a = parseFloat(a), this.begin = this.value = b, this.change = a - b;
- }, b.destroy = function () {
- this.stop(), this.context = null, this.ease = this.update = this.complete = f;
- };
- var n = [],
- o = 1e3;
- }),
- S = l(R, function (a) {
- a.init = function (a) {
- this.duration = a.duration || 0, this.complete = a.complete || f, this.context = a.context, this.play();
- }, a.render = function (a) {
- var b = a - this.start;
- b < this.duration || (this.complete.call(this.context), this.destroy());
- };
- }),
- T = l(R, function (a, b) {
- a.init = function (a) {
- this.context = a.context, this.update = a.update, this.tweens = [], this.current = a.current;
- var b, c;
-
- for (b in a.values) {
- c = a.values[b], this.current[b] !== c && this.tweens.push(new R({
- name: b,
- from: this.current[b],
- to: c,
- duration: a.duration,
- delay: a.delay,
- ease: a.ease,
- autoplay: !1
- }));
- }
-
- this.play();
- }, a.render = function (a) {
- var b,
- c,
- d = this.tweens.length,
- e = !1;
-
- for (b = d; b--;) {
- c = this.tweens[b], c.context && (c.render(a), this.current[c.name] = c.value, e = !0);
- }
-
- return e ? void (this.update && this.update.call(this.context)) : this.destroy();
- }, a.destroy = function () {
- if (b.destroy.call(this), this.tweens) {
- var a,
- c = this.tweens.length;
-
- for (a = c; a--;) {
- this.tweens[a].destroy();
- }
-
- this.tweens = null, this.current = null;
- }
- };
- }),
- U = b.config = {
- debug: !1,
- defaultUnit: "px",
- defaultAngle: "deg",
- keepInherited: !1,
- hideBackface: !1,
- perspective: "",
- fallback: !G.transition,
- agentTests: []
- };
-
- b.fallback = function (a) {
- if (!G.transition) return U.fallback = !0;
- U.agentTests.push("(" + a + ")");
- var b = new RegExp(U.agentTests.join("|"), "i");
- U.fallback = b.test(navigator.userAgent);
- }, b.fallback("6.0.[2-5] Safari"), b.tween = function (a) {
- return new R(a);
- }, b.delay = function (a, b, c) {
- return new S({
- complete: b,
- duration: a,
- context: c
- });
- }, a.fn.tram = function (a) {
- return b.call(null, this, a);
- };
- var V = a.style,
- W = a.css,
- X = {
- transform: G.transform && G.transform.css
- },
- Y = {
- color: [O, u],
- background: [O, u, "background-color"],
- "outline-color": [O, u],
- "border-color": [O, u],
- "border-top-color": [O, u],
- "border-right-color": [O, u],
- "border-bottom-color": [O, u],
- "border-left-color": [O, u],
- "border-width": [N, v],
- "border-top-width": [N, v],
- "border-right-width": [N, v],
- "border-bottom-width": [N, v],
- "border-left-width": [N, v],
- "border-spacing": [N, v],
- "letter-spacing": [N, v],
- margin: [N, v],
- "margin-top": [N, v],
- "margin-right": [N, v],
- "margin-bottom": [N, v],
- "margin-left": [N, v],
- padding: [N, v],
- "padding-top": [N, v],
- "padding-right": [N, v],
- "padding-bottom": [N, v],
- "padding-left": [N, v],
- "outline-width": [N, v],
- opacity: [N, t],
- top: [N, w],
- right: [N, w],
- bottom: [N, w],
- left: [N, w],
- "font-size": [N, w],
- "text-indent": [N, w],
- "word-spacing": [N, w],
- width: [N, w],
- "min-width": [N, w],
- "max-width": [N, w],
- height: [N, w],
- "min-height": [N, w],
- "max-height": [N, w],
- "line-height": [N, y],
- "scroll-top": [P, t, "scrollTop"],
- "scroll-left": [P, t, "scrollLeft"]
- },
- Z = {};
- G.transform && (Y.transform = [Q], Z = {
- x: [w, "translateX"],
- y: [w, "translateY"],
- rotate: [x],
- rotateX: [x],
- rotateY: [x],
- scale: [t],
- scaleX: [t],
- scaleY: [t],
- skew: [x],
- skewX: [x],
- skewY: [x]
- }), G.transform && G.backface && (Z.z = [w, "translateZ"], Z.rotateZ = [x], Z.scaleZ = [t], Z.perspective = [v]);
- var $ = /ms/,
- _ = /s|\./;
- return a.tram = b;
-}(window.jQuery);
-
-/***/ }),
-/* 2 */
-/***/ (function(module, exports) {
-
-function _interopRequireDefault(obj) {
- return obj && obj.__esModule ? obj : {
- "default": obj
- };
-}
-
-module.exports = _interopRequireDefault;
-
-/***/ }),
-/* 3 */
-/***/ (function(module, exports, __webpack_require__) {
-
-__webpack_require__(4);
-__webpack_require__(7);
-__webpack_require__(8);
-__webpack_require__(9);
-__webpack_require__(10);
-__webpack_require__(11);
-__webpack_require__(12);
-__webpack_require__(13);
-module.exports = __webpack_require__(18);
-
-
-/***/ }),
-/* 4 */
-/***/ (function(module, exports, __webpack_require__) {
-
-"use strict";
- // @wf-will-never-add-flow-to-this-file
-
-/* globals document, window, navigator */
-
-/* eslint-disable no-var */
-
-/**
- * Webflow: Brand pages on the subdomain
- */
-
-var Webflow = __webpack_require__(0);
-
-Webflow.define('brand', module.exports = function ($) {
- var api = {};
- var doc = document;
- var $html = $('html');
- var $body = $('body');
- var namespace = '.w-webflow-badge';
- var location = window.location;
- var isPhantom = /PhantomJS/i.test(navigator.userAgent);
- var fullScreenEvents = 'fullscreenchange webkitfullscreenchange mozfullscreenchange msfullscreenchange';
- var brandElement; // -----------------------------------
- // Module methods
-
- api.ready = function () {
- var shouldBrand = $html.attr('data-wf-status');
- var publishedDomain = $html.attr('data-wf-domain') || '';
-
- if (/\.webflow\.io$/i.test(publishedDomain) && location.hostname !== publishedDomain) {
- shouldBrand = true;
- }
-
- if (shouldBrand && !isPhantom) {
- brandElement = brandElement || createBadge();
- ensureBrand();
- setTimeout(ensureBrand, 500);
- $(doc).off(fullScreenEvents, onFullScreenChange).on(fullScreenEvents, onFullScreenChange);
- }
- };
-
- function onFullScreenChange() {
- var fullScreen = doc.fullScreen || doc.mozFullScreen || doc.webkitIsFullScreen || doc.msFullscreenElement || Boolean(doc.webkitFullscreenElement);
- $(brandElement).attr('style', fullScreen ? 'display: none !important;' : '');
- }
-
- function createBadge() {
- var $brand = $('').attr('href', 'https://webflow.com?utm_campaign=brandjs');
- var $logoArt = $('').attr('src', 'https://d3e54v103j8qbb.cloudfront.net/img/webflow-badge-icon.f67cd735e3.svg').attr('alt', '').css({
- marginRight: '8px',
- width: '16px'
- });
- var $logoText = $('').attr('src', 'https://d1otoma47x30pg.cloudfront.net/img/webflow-badge-text.6faa6a38cd.svg').attr('alt', 'Made in Webflow');
- $brand.append($logoArt, $logoText);
- return $brand[0];
- }
-
- function ensureBrand() {
- var found = $body.children(namespace);
- var match = found.length && found.get(0) === brandElement;
- var inEditor = Webflow.env('editor');
-
- if (match) {
- // Remove brand when Editor is active
- if (inEditor) {
- found.remove();
- } // Exit early, brand is in place
-
-
- return;
- } // Remove any invalid brand elements
-
-
- if (found.length) {
- found.remove();
- } // Append the brand (unless Editor is active)
-
-
- if (!inEditor) {
- $body.append(brandElement);
- }
- } // Export module
-
-
- return api;
-});
-
-/***/ }),
-/* 5 */
-/***/ (function(module, exports, __webpack_require__) {
-
-"use strict";
- // @wf-will-never-add-flow-to-this-file
-// Include tram for frame-throttling
-
-/* globals window */
-
-/* eslint-disable no-var */
-
-var $ = window.$;
-var tram = __webpack_require__(1) && $.tram;
-/*!
- * Webflow._ (aka) Underscore.js 1.6.0 (custom build)
- * _.each
- * _.map
- * _.find
- * _.filter
- * _.any
- * _.contains
- * _.delay
- * _.defer
- * _.throttle (webflow)
- * _.debounce
- * _.keys
- * _.has
- * _.now
- * _.template (webflow: upgraded to 1.13.6)
- *
- * http://underscorejs.org
- * (c) 2009-2013 Jeremy Ashkenas, DocumentCloud and Investigative Reporters & Editors
- * Underscore may be freely distributed under the MIT license.
- * @license MIT
- */
-
-module.exports = function () {
- var _ = {}; // Current version.
-
- _.VERSION = '1.6.0-Webflow'; // Establish the object that gets returned to break out of a loop iteration.
-
- var breaker = {}; // Save bytes in the minified (but not gzipped) version:
-
- /* eslint-disable one-var */
-
- var ArrayProto = Array.prototype,
- ObjProto = Object.prototype,
- FuncProto = Function.prototype;
- /* eslint-enable one-var */
- // Create quick reference variables for speed access to core prototypes.
-
- /* eslint-disable one-var, no-unused-vars */
-
- var push = ArrayProto.push,
- slice = ArrayProto.slice,
- concat = ArrayProto.concat,
- toString = ObjProto.toString,
- hasOwnProperty = ObjProto.hasOwnProperty;
- /* eslint-enable one-var, no-unused-vars */
- // All **ECMAScript 5** native function implementations that we hope to use
- // are declared here.
-
- /* eslint-disable one-var, no-unused-vars */
-
- var nativeForEach = ArrayProto.forEach,
- nativeMap = ArrayProto.map,
- nativeReduce = ArrayProto.reduce,
- nativeReduceRight = ArrayProto.reduceRight,
- nativeFilter = ArrayProto.filter,
- nativeEvery = ArrayProto.every,
- nativeSome = ArrayProto.some,
- nativeIndexOf = ArrayProto.indexOf,
- nativeLastIndexOf = ArrayProto.lastIndexOf,
- nativeIsArray = Array.isArray,
- nativeKeys = Object.keys,
- nativeBind = FuncProto.bind;
- /* eslint-enable one-var, no-unused-vars */
- // Collection Functions
- // --------------------
- // The cornerstone, an `each` implementation, aka `forEach`.
- // Handles objects with the built-in `forEach`, arrays, and raw objects.
- // Delegates to **ECMAScript 5**'s native `forEach` if available.
-
- var each = _.each = _.forEach = function (obj, iterator, context) {
- /* jshint shadow:true */
- if (obj == null) return obj;
-
- if (nativeForEach && obj.forEach === nativeForEach) {
- obj.forEach(iterator, context); // eslint-disable-next-line no-implicit-coercion
- } else if (obj.length === +obj.length) {
- for (var i = 0, length = obj.length; i < length; i++) {
- if (iterator.call(context, obj[i], i, obj) === breaker) return;
- }
- } else {
- var keys = _.keys(obj); // eslint-disable-next-line no-redeclare
-
-
- for (var i = 0, length = keys.length; i < length; i++) {
- if (iterator.call(context, obj[keys[i]], keys[i], obj) === breaker) return;
- }
- }
-
- return obj;
- }; // Return the results of applying the iterator to each element.
- // Delegates to **ECMAScript 5**'s native `map` if available.
-
-
- _.map = _.collect = function (obj, iterator, context) {
- var results = [];
- if (obj == null) return results;
- if (nativeMap && obj.map === nativeMap) return obj.map(iterator, context);
- each(obj, function (value, index, list) {
- results.push(iterator.call(context, value, index, list));
- });
- return results;
- }; // Return the first value which passes a truth test. Aliased as `detect`.
-
-
- _.find = _.detect = function (obj, predicate, context) {
- var result;
- any(obj, function (value, index, list) {
- if (predicate.call(context, value, index, list)) {
- result = value;
- return true;
- }
- });
- return result;
- }; // Return all the elements that pass a truth test.
- // Delegates to **ECMAScript 5**'s native `filter` if available.
- // Aliased as `select`.
-
-
- _.filter = _.select = function (obj, predicate, context) {
- var results = [];
- if (obj == null) return results;
- if (nativeFilter && obj.filter === nativeFilter) return obj.filter(predicate, context);
- each(obj, function (value, index, list) {
- if (predicate.call(context, value, index, list)) results.push(value);
- });
- return results;
- }; // Determine if at least one element in the object matches a truth test.
- // Delegates to **ECMAScript 5**'s native `some` if available.
- // Aliased as `any`.
-
-
- var any = _.some = _.any = function (obj, predicate, context) {
- predicate || (predicate = _.identity);
- var result = false;
- if (obj == null) return result;
- if (nativeSome && obj.some === nativeSome) return obj.some(predicate, context);
- each(obj, function (value, index, list) {
- if (result || (result = predicate.call(context, value, index, list))) return breaker;
- });
- return !!result; // eslint-disable-line no-implicit-coercion
- }; // Determine if the array or object contains a given value (using `===`).
- // Aliased as `include`.
-
-
- _.contains = _.include = function (obj, target) {
- if (obj == null) return false;
- if (nativeIndexOf && obj.indexOf === nativeIndexOf) // eslint-disable-next-line eqeqeq
- return obj.indexOf(target) != -1;
- return any(obj, function (value) {
- return value === target;
- });
- }; // Function (ahem) Functions
- // --------------------
- // Delays a function for the given number of milliseconds, and then calls
- // it with the arguments supplied.
-
-
- _.delay = function (func, wait) {
- var args = slice.call(arguments, 2);
- return setTimeout(function () {
- return func.apply(null, args);
- }, wait);
- }; // Defers a function, scheduling it to run after the current call stack has
- // cleared.
-
-
- _.defer = function (func) {
- return _.delay.apply(_, [func, 1].concat(slice.call(arguments, 1)));
- }; // Returns a function, that, when invoked, will only be triggered once every
- // browser animation frame - using tram's requestAnimationFrame polyfill.
-
-
- _.throttle = function (func) {
- // eslint-disable-next-line one-var
- var wait, args, context;
- return function () {
- if (wait) return;
- wait = true;
- args = arguments;
- context = this;
- tram.frame(function () {
- wait = false;
- func.apply(context, args);
- });
- };
- }; // Returns a function, that, as long as it continues to be invoked, will not
- // be triggered. The function will be called after it stops being called for
- // N milliseconds. If `immediate` is passed, trigger the function on the
- // leading edge, instead of the trailing.
-
-
- _.debounce = function (func, wait, immediate) {
- // eslint-disable-next-line one-var
- var timeout, args, context, timestamp, result;
-
- var later = function later() {
- var last = _.now() - timestamp;
-
- if (last < wait) {
- timeout = setTimeout(later, wait - last);
- } else {
- timeout = null;
-
- if (!immediate) {
- result = func.apply(context, args);
- context = args = null;
- }
- }
- };
-
- return function () {
- context = this;
- args = arguments;
- timestamp = _.now();
- var callNow = immediate && !timeout;
-
- if (!timeout) {
- timeout = setTimeout(later, wait);
- }
-
- if (callNow) {
- result = func.apply(context, args);
- context = args = null;
- }
-
- return result;
- };
- }; // Object Functions
- // ----------------
- // Fill in a given object with default properties.
-
-
- _.defaults = function (obj) {
- if (!_.isObject(obj)) return obj;
-
- for (var i = 1, length = arguments.length; i < length; i++) {
- var source = arguments[i];
-
- for (var prop in source) {
- // eslint-disable-next-line no-void
- if (obj[prop] === void 0) obj[prop] = source[prop];
- }
- }
-
- return obj;
- }; // Retrieve the names of an object's properties.
- // Delegates to **ECMAScript 5**'s native `Object.keys`
-
-
- _.keys = function (obj) {
- if (!_.isObject(obj)) return [];
- if (nativeKeys) return nativeKeys(obj);
- var keys = [];
-
- for (var key in obj) {
- if (_.has(obj, key)) keys.push(key);
- }
-
- return keys;
- }; // Shortcut function for checking if an object has a given property directly
- // on itself (in other words, not on a prototype).
-
-
- _.has = function (obj, key) {
- return hasOwnProperty.call(obj, key);
- }; // Is a given variable an object?
-
-
- _.isObject = function (obj) {
- return obj === Object(obj);
- }; // Utility Functions
- // -----------------
- // A (possibly faster) way to get the current timestamp as an integer.
-
-
- _.now = Date.now || function () {
- return new Date().getTime();
- }; // By default, Underscore uses ERB-style template delimiters, change the
- // following template settings to use alternative delimiters.
-
-
- _.templateSettings = {
- evaluate: /<%([\s\S]+?)%>/g,
- interpolate: /<%=([\s\S]+?)%>/g,
- escape: /<%-([\s\S]+?)%>/g
- }; // When customizing `templateSettings`, if you don't want to define an
- // interpolation, evaluation or escaping regex, we need one that is
- // guaranteed not to match.
-
- var noMatch = /(.)^/; // Certain characters need to be escaped so that they can be put into a
- // string literal.
-
- var escapes = {
- "'": "'",
- '\\': '\\',
- '\r': 'r',
- '\n': 'n',
- "\u2028": 'u2028',
- "\u2029": 'u2029'
- };
- var escapeRegExp = /\\|'|\r|\n|\u2028|\u2029/g;
-
- var escapeChar = function escapeChar(match) {
- return '\\' + escapes[match];
- }; // In order to prevent third-party code injection through
- // `_.templateSettings.variable`, we test it against the following regular
- // expression. It is intentionally a bit more liberal than just matching valid
- // identifiers, but still prevents possible loopholes through defaults or
- // destructuring assignment.
-
-
- var bareIdentifier = /^\s*(\w|\$)+\s*$/; // JavaScript micro-templating, similar to John Resig's implementation.
- // Underscore templating handles arbitrary delimiters, preserves whitespace,
- // and correctly escapes quotes within interpolated code.
- // NB: `oldSettings` only exists for backwards compatibility.
-
- _.template = function (text, settings, oldSettings) {
- if (!settings && oldSettings) settings = oldSettings;
- settings = _.defaults({}, settings, _.templateSettings); // Combine delimiters into one regular expression via alternation.
-
- var matcher = RegExp([(settings.escape || noMatch).source, (settings.interpolate || noMatch).source, (settings.evaluate || noMatch).source].join('|') + '|$', 'g'); // Compile the template source, escaping string literals appropriately.
-
- var index = 0;
- var source = "__p+='";
- text.replace(matcher, function (match, escape, interpolate, evaluate, offset) {
- source += text.slice(index, offset).replace(escapeRegExp, escapeChar);
- index = offset + match.length;
-
- if (escape) {
- source += "'+\n((__t=(" + escape + "))==null?'':_.escape(__t))+\n'";
- } else if (interpolate) {
- source += "'+\n((__t=(" + interpolate + "))==null?'':__t)+\n'";
- } else if (evaluate) {
- source += "';\n" + evaluate + "\n__p+='";
- } // Adobe VMs need the match returned to produce the correct offset.
-
-
- return match;
- });
- source += "';\n";
- var argument = settings.variable;
-
- if (argument) {
- // Insure against third-party code injection. (CVE-2021-23358)
- if (!bareIdentifier.test(argument)) throw new Error('variable is not a bare identifier: ' + argument);
- } else {
- // If a variable is not specified, place data values in local scope.
- source = 'with(obj||{}){\n' + source + '}\n';
- argument = 'obj';
- }
-
- source = "var __t,__p='',__j=Array.prototype.join," + "print=function(){__p+=__j.call(arguments,'');};\n" + source + 'return __p;\n';
- var render;
-
- try {
- // eslint-disable-next-line no-new-func
- render = new Function(settings.variable || 'obj', '_', source);
- } catch (e) {
- e.source = source;
- throw e;
- }
-
- var template = function template(data) {
- return render.call(this, data, _);
- }; // Provide the compiled source as a convenience for precompilation.
-
-
- template.source = 'function(' + argument + '){\n' + source + '}';
- return template;
- }; // Export underscore
-
-
- return _;
-}();
-/* eslint-enable */
-
-/***/ }),
-/* 6 */
-/***/ (function(module, exports) {
-
-function _typeof2(obj) { if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") { _typeof2 = function _typeof2(obj) { return typeof obj; }; } else { _typeof2 = function _typeof2(obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; } return _typeof2(obj); }
-
-function _typeof(obj) {
- if (typeof Symbol === "function" && _typeof2(Symbol.iterator) === "symbol") {
- module.exports = _typeof = function _typeof(obj) {
- return _typeof2(obj);
- };
- } else {
- module.exports = _typeof = function _typeof(obj) {
- return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : _typeof2(obj);
- };
- }
-
- return _typeof(obj);
-}
-
-module.exports = _typeof;
-
-/***/ }),
-/* 7 */
-/***/ (function(module, exports, __webpack_require__) {
-
-"use strict";
- // @wf-will-never-add-flow-to-this-file
-
-/* globals window, document */
-
-/* eslint-disable no-var */
-
-/**
- * Webflow: focus-visible
- */
-
-var Webflow = __webpack_require__(0);
-/*
- * This polyfill comes from https://github.com/WICG/focus-visible
- */
-
-
-Webflow.define('focus-visible', module.exports = function () {
- /**
- * Applies the :focus-visible polyfill at the given scope.
- * A scope in this case is either the top-level Document or a Shadow Root.
- *
- * @param {(Document|ShadowRoot)} scope
- * @see https://github.com/WICG/focus-visible
- */
- function applyFocusVisiblePolyfill(scope) {
- var hadKeyboardEvent = true;
- var hadFocusVisibleRecently = false;
- var hadFocusVisibleRecentlyTimeout = null;
- var inputTypesAllowlist = {
- text: true,
- search: true,
- url: true,
- tel: true,
- email: true,
- password: true,
- number: true,
- date: true,
- month: true,
- week: true,
- time: true,
- datetime: true,
- 'datetime-local': true
- };
- /**
- * Helper function for legacy browsers and iframes which sometimes focus
- * elements like document, body, and non-interactive SVG.
- * @param {Element} el
- */
-
- function isValidFocusTarget(el) {
- if (el && el !== document && el.nodeName !== 'HTML' && el.nodeName !== 'BODY' && 'classList' in el && 'contains' in el.classList) {
- return true;
- }
-
- return false;
- }
- /**
- * Computes whether the given element should automatically trigger the
- * `focus-visible` class being added, i.e. whether it should always match
- * `:focus-visible` when focused.
- * @param {Element} el
- * @return {boolean}
- */
-
-
- function focusTriggersKeyboardModality(el) {
- var type = el.type;
- var tagName = el.tagName;
-
- if (tagName === 'INPUT' && inputTypesAllowlist[type] && !el.readOnly) {
- return true;
- }
-
- if (tagName === 'TEXTAREA' && !el.readOnly) {
- return true;
- }
-
- if (el.isContentEditable) {
- return true;
- }
-
- return false;
- }
-
- function addFocusVisibleAttribute(el) {
- if (el.getAttribute('data-wf-focus-visible')) {
- return;
- }
-
- el.setAttribute('data-wf-focus-visible', 'true');
- }
-
- function removeFocusVisibleAttribute(el) {
- if (!el.getAttribute('data-wf-focus-visible')) {
- return;
- }
-
- el.removeAttribute('data-wf-focus-visible');
- }
- /**
- * If the most recent user interaction was via the keyboard;
- * and the key press did not include a meta, alt/option, or control key;
- * then the modality is keyboard. Otherwise, the modality is not keyboard.
- * Apply `focus-visible` to any current active element and keep track
- * of our keyboard modality state with `hadKeyboardEvent`.
- * @param {KeyboardEvent} e
- */
-
-
- function onKeyDown(e) {
- if (e.metaKey || e.altKey || e.ctrlKey) {
- return;
- }
-
- if (isValidFocusTarget(scope.activeElement)) {
- addFocusVisibleAttribute(scope.activeElement);
- }
-
- hadKeyboardEvent = true;
- }
- /**
- * If at any point a user clicks with a pointing device, ensure that we change
- * the modality away from keyboard.
- * This avoids the situation where a user presses a key on an already focused
- * element, and then clicks on a different element, focusing it with a
- * pointing device, while we still think we're in keyboard modality.
- * @param {Event} e
- */
-
-
- function onPointerDown() {
- hadKeyboardEvent = false;
- }
- /**
- * On `focus`, add the `focus-visible` class to the target if:
- * - the target received focus as a result of keyboard navigation, or
- * - the event target is an element that will likely require interaction
- * via the keyboard (e.g. a text box)
- * @param {Event} e
- */
-
-
- function onFocus(e) {
- // Prevent IE from focusing the document or HTML element.
- if (!isValidFocusTarget(e.target)) {
- return;
- }
-
- if (hadKeyboardEvent || focusTriggersKeyboardModality(e.target)) {
- addFocusVisibleAttribute(e.target);
- }
- }
- /**
- * On `blur`, remove the `focus-visible` class from the target.
- * @param {Event} e
- */
-
-
- function onBlur(e) {
- if (!isValidFocusTarget(e.target)) {
- return;
- }
-
- if (e.target.hasAttribute('data-wf-focus-visible')) {
- // To detect a tab/window switch, we look for a blur event followed
- // rapidly by a visibility change.
- // If we don't see a visibility change within 100ms, it's probably a
- // regular focus change.
- hadFocusVisibleRecently = true;
- window.clearTimeout(hadFocusVisibleRecentlyTimeout);
- hadFocusVisibleRecentlyTimeout = window.setTimeout(function () {
- hadFocusVisibleRecently = false;
- }, 100);
- removeFocusVisibleAttribute(e.target);
- }
- }
- /**
- * If the user changes tabs, keep track of whether or not the previously
- * focused element had .focus-visible.
- * @param {Event} e
- */
-
-
- function onVisibilityChange() {
- if (document.visibilityState === 'hidden') {
- // If the tab becomes active again, the browser will handle calling focus
- // on the element (Safari actually calls it twice).
- // If this tab change caused a blur on an element with focus-visible,
- // re-apply the class when the user switches back to the tab.
- if (hadFocusVisibleRecently) {
- hadKeyboardEvent = true;
- }
-
- addInitialPointerMoveListeners();
- }
- }
- /**
- * Add a group of listeners to detect usage of any pointing devices.
- * These listeners will be added when the polyfill first loads, and anytime
- * the window is blurred, so that they are active when the window regains
- * focus.
- */
-
-
- function addInitialPointerMoveListeners() {
- document.addEventListener('mousemove', onInitialPointerMove);
- document.addEventListener('mousedown', onInitialPointerMove);
- document.addEventListener('mouseup', onInitialPointerMove);
- document.addEventListener('pointermove', onInitialPointerMove);
- document.addEventListener('pointerdown', onInitialPointerMove);
- document.addEventListener('pointerup', onInitialPointerMove);
- document.addEventListener('touchmove', onInitialPointerMove);
- document.addEventListener('touchstart', onInitialPointerMove);
- document.addEventListener('touchend', onInitialPointerMove);
- }
-
- function removeInitialPointerMoveListeners() {
- document.removeEventListener('mousemove', onInitialPointerMove);
- document.removeEventListener('mousedown', onInitialPointerMove);
- document.removeEventListener('mouseup', onInitialPointerMove);
- document.removeEventListener('pointermove', onInitialPointerMove);
- document.removeEventListener('pointerdown', onInitialPointerMove);
- document.removeEventListener('pointerup', onInitialPointerMove);
- document.removeEventListener('touchmove', onInitialPointerMove);
- document.removeEventListener('touchstart', onInitialPointerMove);
- document.removeEventListener('touchend', onInitialPointerMove);
- }
- /**
- * When the polfyill first loads, assume the user is in keyboard modality.
- * If any event is received from a pointing device (e.g. mouse, pointer,
- * touch), turn off keyboard modality.
- * This accounts for situations where focus enters the page from the URL bar.
- * @param {Event} e
- */
-
-
- function onInitialPointerMove(e) {
- // Work around a Safari quirk that fires a mousemove on whenever the
- // window blurs, even if you're tabbing out of the page. ¯\_(ツ)_/¯
- if (e.target.nodeName && e.target.nodeName.toLowerCase() === 'html') {
- return;
- }
-
- hadKeyboardEvent = false;
- removeInitialPointerMoveListeners();
- } // For some kinds of state, we are interested in changes at the global scope
- // only. For example, global pointer input, global key presses and global
- // visibility change should affect the state at every scope:
-
-
- document.addEventListener('keydown', onKeyDown, true);
- document.addEventListener('mousedown', onPointerDown, true);
- document.addEventListener('pointerdown', onPointerDown, true);
- document.addEventListener('touchstart', onPointerDown, true);
- document.addEventListener('visibilitychange', onVisibilityChange, true);
- addInitialPointerMoveListeners(); // For focus and blur, we specifically care about state changes in the local
- // scope. This is because focus / blur events that originate from within a
- // shadow root are not re-dispatched from the host element if it was already
- // the active element in its own scope:
-
- scope.addEventListener('focus', onFocus, true);
- scope.addEventListener('blur', onBlur, true);
- }
-
- function ready() {
- if (typeof document !== 'undefined') {
- try {
- // check for native support; this will throw if the selector is not considered valid
- document.querySelector(':focus-visible');
- } catch (e) {
- // :focus-visible pseudo-selector is not supported natively
- applyFocusVisiblePolyfill(document);
- }
- }
- } // Export module
-
-
- return {
- ready: ready
- };
-});
-
-/***/ }),
-/* 8 */
-/***/ (function(module, exports, __webpack_require__) {
-
-"use strict";
- // @wf-will-never-add-flow-to-this-file
-
-/* globals window, document */
-
-/* eslint-disable no-var */
-
-/**
- * Webflow: focus-within
- */
-
-var Webflow = __webpack_require__(0); // polyfill based off of https://github.com/matteobad/focus-within-polyfill
-
-
-Webflow.define('focus-within', module.exports = function () {
- /**
- * Calculate the entire event path.
- *
- * @param {Element} node
- * @return {Array} computedPath
- */
- function computeEventPath(node) {
- var path = [node];
- var parent = null;
-
- while (parent = node.parentNode || node.host || node.defaultView) {
- path.push(parent);
- node = parent;
- }
-
- return path;
- }
-
- function addFocusWithinAttribute(el) {
- if (typeof el.getAttribute !== 'function' || el.getAttribute('data-wf-focus-within')) {
- return;
- }
-
- el.setAttribute('data-wf-focus-within', 'true');
- }
-
- function removeFocusWithinAttribute(el) {
- if (typeof el.getAttribute !== 'function' || !el.getAttribute('data-wf-focus-within')) {
- return;
- }
-
- el.removeAttribute('data-wf-focus-within');
- }
- /**
- * Attach event listerns to initiate polyfill
- * @return {boolean}
- */
-
-
- function loadFocusWithinPolyfill() {
- var handler = function handler(e) {
- var running;
- /**
- * Request animation frame callback.
- * Remove previously applied attributes.
- * Add new attributes.
- */
-
- function action() {
- running = false;
-
- if ('blur' === e.type) {
- Array.prototype.slice.call(computeEventPath(e.target)).forEach(removeFocusWithinAttribute);
- }
-
- if ('focus' === e.type) {
- Array.prototype.slice.call(computeEventPath(e.target)).forEach(addFocusWithinAttribute);
- }
- }
-
- if (!running) {
- window.requestAnimationFrame(action);
- running = true;
- }
- };
-
- document.addEventListener('focus', handler, true);
- document.addEventListener('blur', handler, true);
- addFocusWithinAttribute(document.body);
- return true;
- }
-
- function ready() {
- if (typeof document !== 'undefined' && document.body.hasAttribute('data-wf-focus-within')) {
- try {
- // check for native support; this will throw if the selector is not considered valid
- document.querySelector(':focus-within');
- } catch (e) {
- loadFocusWithinPolyfill();
- }
- }
- } // Export module
-
-
- return {
- ready: ready
- };
-});
-
-/***/ }),
-/* 9 */
-/***/ (function(module, exports, __webpack_require__) {
-
-"use strict";
- // @wf-will-never-add-flow-to-this-file
-
-/* globals document, MouseEvent */
-
-/* eslint-disable no-var */
-
-/**
- * Webflow: focus
- */
-
-var Webflow = __webpack_require__(0);
-/*
- * Safari has a weird bug where it doesn't support :focus for links with hrefs,
- * buttons, and input[type=button|submit], so we listen for mousedown events
- * instead and force the element to emit a focus event in those cases.
-
- * See these webkit bugs for reference:
- * https://bugs.webkit.org/show_bug.cgi?id=22261
- * https://bugs.webkit.org/show_bug.cgi?id=229895
- */
-
-
-Webflow.define('focus', module.exports = function () {
- var capturedEvents = [];
- var capturing = false;
-
- function captureEvent(e) {
- if (capturing) {
- e.preventDefault();
- e.stopPropagation();
- e.stopImmediatePropagation();
- capturedEvents.unshift(e);
- }
- }
- /*
- * The only mousedown events we care about here are ones emanating from
- * (A) anchor links with href attribute,
- * (B) non-disabled buttons,
- * (C) non-disabled textarea,
- * (D) non-disabled inputs of type "button", "reset", "checkbox", "radio", "submit"
- * (E) non-interactive elements (button, a, input, textarea, select) that have a tabindex with a numeric value
- * (F) audio elements
- * (G) video elements with controls attribute
- */
-
-
- function isPolyfilledFocusEvent(e) {
- var el = e.target;
- var tag = el.tagName;
- return /^a$/i.test(tag) && el.href != null || // (A)
- /^(button|textarea)$/i.test(tag) && el.disabled !== true || // (B) (C)
- /^input$/i.test(tag) && /^(button|reset|submit|radio|checkbox)$/i.test(el.type) && !el.disabled || // (D)
- !/^(button|input|textarea|select|a)$/i.test(tag) && !Number.isNaN(Number.parseFloat(el.tabIndex)) || // (E)
- /^audio$/i.test(tag) || // (F)
- /^video$/i.test(tag) && el.controls === true // (G)
- ;
- }
-
- function handler(e) {
- if (isPolyfilledFocusEvent(e)) {
- // start capturing possible out-of-order mouse events
- capturing = true;
- /*
- * enqueue the focus event _after_ the current batch of events, which
- * includes any blur events. The correct order of events is:
- *
- * [this element] MOUSEDOWN <-- this event
- * [previously active element] BLUR
- * [previously active element] FOCUSOUT
- * [this element] FOCUS <-- forced event
- * [this element] FOCUSIN <-- forced event
- * [this element] MOUSEUP <-- possibly captured event (it may have fired _before_ the FOCUS event)
- * [this element] CLICK <-- possibly captured event (it may have fired _before_ the FOCUS event)
- */
-
- setTimeout(function () {
- // stop capturing possible out-of-order mouse events
- capturing = false; // trigger focus event
-
- e.target.focus(); // re-dispatch captured mouse events in order
-
- while (capturedEvents.length > 0) {
- var event = capturedEvents.pop();
- event.target.dispatchEvent(new MouseEvent(event.type, event));
- }
- }, 0);
- }
- }
-
- function ready() {
- if (typeof document !== 'undefined' && document.body.hasAttribute('data-wf-focus-within') && Webflow.env.safari) {
- document.addEventListener('mousedown', handler, true);
- document.addEventListener('mouseup', captureEvent, true);
- document.addEventListener('click', captureEvent, true);
- }
- } // Export module
-
-
- return {
- ready: ready
- };
-});
-
-/***/ }),
-/* 10 */
-/***/ (function(module, exports, __webpack_require__) {
-
-"use strict";
- // @wf-will-never-add-flow-to-this-file
-
-/* globals window, document */
-
-/* eslint-disable no-var */
-
-/**
- * Webflow: Auto-select links to current page or section
- */
-
-var Webflow = __webpack_require__(0);
-
-Webflow.define('links', module.exports = function ($, _) {
- var api = {};
- var $win = $(window);
- var designer;
- var inApp = Webflow.env();
- var location = window.location;
- var tempLink = document.createElement('a');
- var linkCurrent = 'w--current';
- var indexPage = /index\.(html|php)$/;
- var dirList = /\/$/;
- var anchors;
- var slug; // -----------------------------------
- // Module methods
-
- api.ready = api.design = api.preview = init; // -----------------------------------
- // Private methods
-
- function init() {
- designer = inApp && Webflow.env('design');
- slug = Webflow.env('slug') || location.pathname || ''; // Reset scroll listener, init anchors
-
- Webflow.scroll.off(scroll);
- anchors = []; // Test all links for a selectable href
-
- var links = document.links;
-
- for (var i = 0; i < links.length; ++i) {
- select(links[i]);
- } // Listen for scroll if any anchors exist
-
-
- if (anchors.length) {
- Webflow.scroll.on(scroll);
- scroll();
- }
- }
-
- function select(link) {
- var href = designer && link.getAttribute('href-disabled') || link.getAttribute('href');
- tempLink.href = href; // Ignore any hrefs with a colon to safely avoid all uri schemes
-
- if (href.indexOf(':') >= 0) {
- return;
- }
-
- var $link = $(link); // Check for all links with hash (eg (this-host)(/this-path)#section) to this page
-
- if (tempLink.hash.length > 1 && tempLink.host + tempLink.pathname === location.host + location.pathname) {
- // Ignore any hrefs with Google Translate type hash
- // Example: jQuery can't parse $('#googtrans(en|es)')
- // https://forum.webflow.com/t/dropdown-menus-not-working-on-site/87140
- if (!/^#[a-zA-Z0-9\-\_]+$/.test(tempLink.hash)) {
- return;
- }
-
- var $section = $(tempLink.hash);
- $section.length && anchors.push({
- link: $link,
- sec: $section,
- active: false
- });
- return;
- } // Ignore empty # links
-
-
- if (href === '#' || href === '') {
- return;
- } // Determine whether the link should be selected
-
-
- var match = tempLink.href === location.href || href === slug || indexPage.test(href) && dirList.test(slug);
- setClass($link, linkCurrent, match);
- }
-
- function scroll() {
- var viewTop = $win.scrollTop();
- var viewHeight = $win.height(); // Check each anchor for a section in view
-
- _.each(anchors, function (anchor) {
- var $link = anchor.link;
- var $section = anchor.sec;
- var top = $section.offset().top;
- var height = $section.outerHeight();
- var offset = viewHeight * 0.5;
- var active = $section.is(':visible') && top + height - offset >= viewTop && top + offset <= viewTop + viewHeight;
-
- if (anchor.active === active) {
- return;
- }
-
- anchor.active = active;
- setClass($link, linkCurrent, active);
- });
- }
-
- function setClass($elem, className, add) {
- var exists = $elem.hasClass(className);
-
- if (add && exists) {
- return;
- }
-
- if (!add && !exists) {
- return;
- }
-
- add ? $elem.addClass(className) : $elem.removeClass(className);
- } // Export module
-
-
- return api;
-});
-
-/***/ }),
-/* 11 */
-/***/ (function(module, exports, __webpack_require__) {
-
-"use strict";
- // @wf-will-never-add-flow-to-this-file
-
-/* globals window, document */
-
-/* eslint-disable no-var */
-
-/**
- * Webflow: Smooth scroll
- */
-
-var Webflow = __webpack_require__(0);
-
-Webflow.define('scroll', module.exports = function ($) {
- /**
- * A collection of namespaced events found in this module.
- * Namespaced events encapsulate our code, and make it safer and easier
- * for designers to apply custom code overrides.
- * @see https://api.jquery.com/on/#event-names
- * @typedef {Object.} NamespacedEventsCollection
- */
- var NS_EVENTS = {
- WF_CLICK_EMPTY: 'click.wf-empty-link',
- WF_CLICK_SCROLL: 'click.wf-scroll'
- };
- var loc = window.location;
- var history = inIframe() ? null : window.history;
- var $win = $(window);
- var $doc = $(document);
- var $body = $(document.body);
-
- var animate = window.requestAnimationFrame || window.mozRequestAnimationFrame || window.webkitRequestAnimationFrame || function (fn) {
- window.setTimeout(fn, 15);
- };
-
- var rootTag = Webflow.env('editor') ? '.w-editor-body' : 'body';
- var headerSelector = 'header, ' + rootTag + ' > .header, ' + rootTag + ' > .w-nav:not([data-no-scroll])';
- var emptyHrefSelector = 'a[href="#"]';
- /**
- * Select only links whose href:
- * - contains a #
- * - is not one of our namespaced TabLink elements
- * - is not _only_ a #
- */
-
- var localHrefSelector = 'a[href*="#"]:not(.w-tab-link):not(' + emptyHrefSelector + ')';
- var scrollTargetOutlineCSS = '.wf-force-outline-none[tabindex="-1"]:focus{outline:none;}';
- var focusStylesEl = document.createElement('style');
- focusStylesEl.appendChild(document.createTextNode(scrollTargetOutlineCSS));
-
- function inIframe() {
- try {
- return Boolean(window.frameElement);
- } catch (e) {
- return true;
- }
- }
-
- var validHash = /^#[a-zA-Z0-9][\w:.-]*$/;
- /**
- * Determine if link navigates to current page
- * @param {HTMLAnchorElement} link
- */
-
- function linksToCurrentPage(link) {
- return validHash.test(link.hash) && link.host + link.pathname === loc.host + loc.pathname;
- }
- /**
- * Check if the designer has indicated that this page should
- * have no scroll animation, or if the end user has set
- * prefers-reduced-motion in their OS
- */
-
-
- var reducedMotionMediaQuery = typeof window.matchMedia === 'function' && window.matchMedia('(prefers-reduced-motion: reduce)');
-
- function reducedMotionEnabled() {
- return document.body.getAttribute('data-wf-scroll-motion') === 'none' || reducedMotionMediaQuery.matches;
- }
-
- function setFocusable($el, action) {
- var initialTabindex;
-
- switch (action) {
- case 'add':
- initialTabindex = $el.attr('tabindex');
-
- if (initialTabindex) {
- $el.attr('data-wf-tabindex-swap', initialTabindex);
- } else {
- $el.attr('tabindex', '-1');
- }
-
- break;
-
- case 'remove':
- initialTabindex = $el.attr('data-wf-tabindex-swap');
-
- if (initialTabindex) {
- $el.attr('tabindex', initialTabindex);
- $el.removeAttr('data-wf-tabindex-swap');
- } else {
- $el.removeAttr('tabindex');
- }
-
- break;
- }
-
- $el.toggleClass('wf-force-outline-none', action === 'add');
- }
- /**
- * Determine if we should execute custom scroll
- */
-
-
- function validateScroll(evt) {
- var target = evt.currentTarget;
-
- if ( // Bail if in Designer
- Webflow.env('design') || // Ignore links being used by jQuery mobile
- window.$.mobile && /(?:^|\s)ui-link(?:$|\s)/.test(target.className)) {
- return;
- }
-
- var hash = linksToCurrentPage(target) ? target.hash : '';
- if (hash === '') return;
- var $el = $(hash);
-
- if (!$el.length) {
- return;
- }
-
- if (evt) {
- evt.preventDefault();
- evt.stopPropagation();
- }
-
- updateHistory(hash, evt);
- window.setTimeout(function () {
- scroll($el, function setFocus() {
- setFocusable($el, 'add');
- $el.get(0).focus({
- preventScroll: true
- });
- setFocusable($el, 'remove');
- });
- }, evt ? 0 : 300);
- }
-
- function updateHistory(hash) {
- // Push new history state
- if (loc.hash !== hash && history && history.pushState && // Navigation breaks Chrome when the protocol is `file:`.
- !(Webflow.env.chrome && loc.protocol === 'file:')) {
- var oldHash = history.state && history.state.hash;
-
- if (oldHash !== hash) {
- history.pushState({
- hash: hash
- }, '', hash);
- }
- }
- }
-
- function scroll($targetEl, cb) {
- var start = $win.scrollTop();
- var end = calculateScrollEndPosition($targetEl);
- if (start === end) return;
- var duration = calculateScrollDuration($targetEl, start, end);
- var clock = Date.now();
-
- var step = function step() {
- var elapsed = Date.now() - clock;
- window.scroll(0, getY(start, end, elapsed, duration));
-
- if (elapsed <= duration) {
- animate(step);
- } else if (typeof cb === 'function') {
- cb();
- }
- };
-
- animate(step);
- }
-
- function calculateScrollEndPosition($targetEl) {
- // If a fixed header exists, offset for the height
- var $header = $(headerSelector);
- var offsetY = $header.css('position') === 'fixed' ? $header.outerHeight() : 0;
- var end = $targetEl.offset().top - offsetY; // If specified, scroll so that the element ends up in the middle of the viewport
-
- if ($targetEl.data('scroll') === 'mid') {
- var available = $win.height() - offsetY;
- var elHeight = $targetEl.outerHeight();
-
- if (elHeight < available) {
- end -= Math.round((available - elHeight) / 2);
- }
- }
-
- return end;
- }
-
- function calculateScrollDuration($targetEl, start, end) {
- if (reducedMotionEnabled()) return 0;
- var mult = 1; // Check for custom time multiplier on the body and the scroll target
-
- $body.add($targetEl).each(function (_, el) {
- var time = parseFloat(el.getAttribute('data-scroll-time'));
-
- if (!isNaN(time) && time >= 0) {
- mult = time;
- }
- });
- return (472.143 * Math.log(Math.abs(start - end) + 125) - 2000) * mult;
- }
-
- function getY(start, end, elapsed, duration) {
- if (elapsed > duration) {
- return end;
- }
-
- return start + (end - start) * ease(elapsed / duration);
- }
-
- function ease(t) {
- return t < 0.5 ? 4 * t * t * t : (t - 1) * (2 * t - 2) * (2 * t - 2) + 1;
- }
-
- function ready() {
- var WF_CLICK_EMPTY = NS_EVENTS.WF_CLICK_EMPTY,
- WF_CLICK_SCROLL = NS_EVENTS.WF_CLICK_SCROLL;
- $doc.on(WF_CLICK_SCROLL, localHrefSelector, validateScroll);
- /**
- * Prevent empty hash links from triggering scroll.
- * Legacy feature to preserve: use the default "#" link
- * to trigger an interaction, and do not want the page
- * to scroll to the top.
- */
-
- $doc.on(WF_CLICK_EMPTY, emptyHrefSelector, function (e) {
- e.preventDefault();
- });
- document.head.insertBefore(focusStylesEl, document.head.firstChild);
- } // Export module
-
-
- return {
- ready: ready
- };
-});
-
-/***/ }),
-/* 12 */
-/***/ (function(module, exports, __webpack_require__) {
-
-"use strict";
- // @wf-will-never-add-flow-to-this-file
-
-/* globals document, window */
-
-/* eslint-disable no-var */
-
-/**
- * Webflow: Touch events
- * Supports legacy 'tap' event
- * Adds a 'swipe' event to desktop and mobile
- */
-
-var Webflow = __webpack_require__(0);
-
-Webflow.define('touch', module.exports = function ($) {
- var api = {};
- var getSelection = window.getSelection; // Delegate all legacy 'tap' events to 'click'
-
- $.event.special.tap = {
- bindType: 'click',
- delegateType: 'click'
- };
-
- api.init = function (el) {
- el = typeof el === 'string' ? $(el).get(0) : el;
- return el ? new Touch(el) : null;
- };
-
- function Touch(el) {
- var active = false;
- var useTouch = false;
- var thresholdX = Math.min(Math.round(window.innerWidth * 0.04), 40);
- var startX;
- var lastX;
- el.addEventListener('touchstart', start, false);
- el.addEventListener('touchmove', move, false);
- el.addEventListener('touchend', end, false);
- el.addEventListener('touchcancel', cancel, false);
- el.addEventListener('mousedown', start, false);
- el.addEventListener('mousemove', move, false);
- el.addEventListener('mouseup', end, false);
- el.addEventListener('mouseout', cancel, false);
-
- function start(evt) {
- // We don’t handle multi-touch events yet.
- var touches = evt.touches;
-
- if (touches && touches.length > 1) {
- return;
- }
-
- active = true;
-
- if (touches) {
- useTouch = true;
- startX = touches[0].clientX;
- } else {
- startX = evt.clientX;
- }
-
- lastX = startX;
- }
-
- function move(evt) {
- if (!active) {
- return;
- }
-
- if (useTouch && evt.type === 'mousemove') {
- evt.preventDefault();
- evt.stopPropagation();
- return;
- }
-
- var touches = evt.touches;
- var x = touches ? touches[0].clientX : evt.clientX;
- var velocityX = x - lastX;
- lastX = x; // Allow swipes while pointer is down, but prevent them during text selection
-
- if (Math.abs(velocityX) > thresholdX && getSelection && String(getSelection()) === '') {
- triggerEvent('swipe', evt, {
- direction: velocityX > 0 ? 'right' : 'left'
- });
- cancel();
- }
- }
-
- function end(evt) {
- if (!active) {
- return;
- }
-
- active = false;
-
- if (useTouch && evt.type === 'mouseup') {
- evt.preventDefault();
- evt.stopPropagation();
- useTouch = false;
- return;
- }
- }
-
- function cancel() {
- active = false;
- }
-
- function destroy() {
- el.removeEventListener('touchstart', start, false);
- el.removeEventListener('touchmove', move, false);
- el.removeEventListener('touchend', end, false);
- el.removeEventListener('touchcancel', cancel, false);
- el.removeEventListener('mousedown', start, false);
- el.removeEventListener('mousemove', move, false);
- el.removeEventListener('mouseup', end, false);
- el.removeEventListener('mouseout', cancel, false);
- el = null;
- } // Public instance methods
-
-
- this.destroy = destroy;
- } // Wrap native event to supoprt preventdefault + stopPropagation
-
-
- function triggerEvent(type, evt, data) {
- var newEvent = $.Event(type, {
- originalEvent: evt
- });
- $(evt.target).trigger(newEvent, data);
- } // Listen for touch events on all nodes by default.
-
-
- api.instance = api.init(document); // Export module
-
- return api;
-});
-
-/***/ }),
-/* 13 */
-/***/ (function(module, exports, __webpack_require__) {
-
-"use strict";
- // @wf-will-never-add-flow-to-this-file
-
-/* globals
- window,
- document,
- FormData,
- WEBFLOW_FORM_API_HOST,
- WEBFLOW_FORM_OLDIE_HOST
-*/
-
-/* eslint-disable no-var */
-
-/**
- * Webflow: Forms
- */
-
-var _interopRequireDefault = __webpack_require__(2);
-
-var _slicedToArray2 = _interopRequireDefault(__webpack_require__(14));
-
-var Webflow = __webpack_require__(0);
-
-Webflow.define('forms', module.exports = function ($, _) {
- var api = {};
- var $doc = $(document);
- var $forms;
- var loc = window.location;
- var retro = window.XDomainRequest && !window.atob;
- var namespace = '.w-form';
- var siteId;
- var emailField = /e(-)?mail/i;
- var emailValue = /^\S+@\S+$/;
- var alert = window.alert;
- var inApp = Webflow.env();
- var listening;
- var formUrl;
- var signFileUrl; // MailChimp domains: list-manage.com + mirrors
-
- var chimpRegex = /list-manage[1-9]?.com/i;
-
- var disconnected = _.debounce(function () {
- alert('Oops! This page has improperly configured forms. Please contact your website administrator to fix this issue.');
- }, 100);
-
- api.ready = api.design = api.preview = function () {
- // Init forms
- init(); // Wire document events on published site only once
-
- if (!inApp && !listening) {
- addListeners();
- }
- };
-
- function init() {
- siteId = $('html').attr('data-wf-site');
- formUrl = "https://webflow.com" + '/api/v1/form/' + siteId; // Work around same-protocol IE XDR limitation - without this IE9 and below forms won't submit
-
- if (retro && formUrl.indexOf("https://webflow.com") >= 0) {
- formUrl = formUrl.replace("https://webflow.com", "https://formdata.webflow.com");
- }
-
- signFileUrl = "".concat(formUrl, "/signFile");
- $forms = $(namespace + ' form');
-
- if (!$forms.length) {
- return;
- }
-
- $forms.each(build);
- }
-
- function build(i, el) {
- // Store form state using namespace
- var $el = $(el);
- var data = $.data(el, namespace);
-
- if (!data) {
- data = $.data(el, namespace, {
- form: $el
- });
- } // data.form
-
-
- reset(data);
- var wrap = $el.closest('div.w-form');
- data.done = wrap.find('> .w-form-done');
- data.fail = wrap.find('> .w-form-fail');
- data.fileUploads = wrap.find('.w-file-upload');
- data.fileUploads.each(function (j) {
- initFileUpload(j, data);
- }); // Accessiblity fixes
-
- var formName = data.form.attr('aria-label') || data.form.attr('data-name') || 'Form';
-
- if (!data.done.attr('aria-label')) {
- data.form.attr('aria-label', formName);
- }
-
- data.done.attr('tabindex', '-1');
- data.done.attr('role', 'region');
-
- if (!data.done.attr('aria-label')) {
- data.done.attr('aria-label', formName + ' success');
- }
-
- data.fail.attr('tabindex', '-1');
- data.fail.attr('role', 'region');
-
- if (!data.fail.attr('aria-label')) {
- data.fail.attr('aria-label', formName + ' failure');
- }
-
- var action = data.action = $el.attr('action');
- data.handler = null;
- data.redirect = $el.attr('data-redirect'); // MailChimp form
-
- if (chimpRegex.test(action)) {
- data.handler = submitMailChimp;
- return;
- } // Custom form action
-
-
- if (action) {
- return;
- } // Webflow forms for hosting accounts
-
-
- if (siteId) {
- data.handler = typeof hostedSubmitWebflow === 'function' ? hostedSubmitWebflow : exportedSubmitWebflow;
- return;
- } // Alert for disconnected Webflow forms
-
-
- disconnected();
- }
-
- function addListeners() {
- listening = true; // Handle form submission for Webflow forms
-
- $doc.on('submit', namespace + ' form', function (evt) {
- var data = $.data(this, namespace);
-
- if (data.handler) {
- data.evt = evt;
- data.handler(data);
- }
- }); // handle checked ui for custom checkbox and radio button
-
- var CHECKBOX_CLASS_NAME = '.w-checkbox-input';
- var RADIO_INPUT_CLASS_NAME = '.w-radio-input';
- var CHECKED_CLASS = 'w--redirected-checked';
- var FOCUSED_CLASS = 'w--redirected-focus';
- var FOCUSED_VISIBLE_CLASS = 'w--redirected-focus-visible';
- var focusVisibleSelectors = ':focus-visible, [data-wf-focus-visible]';
- var CUSTOM_CONTROLS = [['checkbox', CHECKBOX_CLASS_NAME], ['radio', RADIO_INPUT_CLASS_NAME]];
- $doc.on('change', namespace + " form input[type=\"checkbox\"]:not(" + CHECKBOX_CLASS_NAME + ')', function (evt) {
- $(evt.target).siblings(CHECKBOX_CLASS_NAME).toggleClass(CHECKED_CLASS);
- });
- $doc.on('change', namespace + " form input[type=\"radio\"]", function (evt) {
- $("input[name=\"".concat(evt.target.name, "\"]:not(").concat(CHECKBOX_CLASS_NAME, ")")).map(function (i, el) {
- return $(el).siblings(RADIO_INPUT_CLASS_NAME).removeClass(CHECKED_CLASS);
- });
- var $target = $(evt.target);
-
- if (!$target.hasClass('w-radio-input')) {
- $target.siblings(RADIO_INPUT_CLASS_NAME).addClass(CHECKED_CLASS);
- }
- });
- CUSTOM_CONTROLS.forEach(function (_ref) {
- var _ref2 = (0, _slicedToArray2["default"])(_ref, 2),
- controlType = _ref2[0],
- customControlClassName = _ref2[1];
-
- $doc.on('focus', namespace + " form input[type=\"".concat(controlType, "\"]:not(") + customControlClassName + ')', function (evt) {
- $(evt.target).siblings(customControlClassName).addClass(FOCUSED_CLASS);
- $(evt.target).filter(focusVisibleSelectors).siblings(customControlClassName).addClass(FOCUSED_VISIBLE_CLASS);
- });
- $doc.on('blur', namespace + " form input[type=\"".concat(controlType, "\"]:not(") + customControlClassName + ')', function (evt) {
- $(evt.target).siblings(customControlClassName).removeClass("".concat(FOCUSED_CLASS, " ").concat(FOCUSED_VISIBLE_CLASS));
- });
- });
- } // Reset data common to all submit handlers
-
-
- function reset(data) {
- var btn = data.btn = data.form.find(':input[type="submit"]');
- data.wait = data.btn.attr('data-wait') || null;
- data.success = false;
- btn.prop('disabled', false);
- data.label && btn.val(data.label);
- } // Disable submit button
-
-
- function disableBtn(data) {
- var btn = data.btn;
- var wait = data.wait;
- btn.prop('disabled', true); // Show wait text and store previous label
-
- if (wait) {
- data.label = btn.val();
- btn.val(wait);
- }
- } // Find form fields, validate, and set value pairs
-
-
- function findFields(form, result) {
- var status = null;
- result = result || {}; // The ":input" selector is a jQuery shortcut to select all inputs, selects, textareas
-
- form.find(':input:not([type="submit"]):not([type="file"])').each(function (i, el) {
- var field = $(el);
- var type = field.attr('type');
- var name = field.attr('data-name') || field.attr('name') || 'Field ' + (i + 1);
- var value = field.val();
-
- if (type === 'checkbox') {
- value = field.is(':checked');
- } else if (type === 'radio') {
- // Radio group value already processed
- if (result[name] === null || typeof result[name] === 'string') {
- return;
- }
-
- value = form.find('input[name="' + field.attr('name') + '"]:checked').val() || null;
- }
-
- if (typeof value === 'string') {
- value = $.trim(value);
- }
-
- result[name] = value;
- status = status || getStatus(field, type, name, value);
- });
- return status;
- }
-
- function findFileUploads(form) {
- var result = {};
- form.find(':input[type="file"]').each(function (i, el) {
- var field = $(el);
- var name = field.attr('data-name') || field.attr('name') || 'File ' + (i + 1);
- var value = field.attr('data-value');
-
- if (typeof value === 'string') {
- value = $.trim(value);
- }
-
- result[name] = value;
- });
- return result;
- }
-
- var trackingCookieNameMap = {
- _mkto_trk: 'marketo' // __hstc: 'hubspot',
-
- };
-
- function collectEnterpriseTrackingCookies() {
- var cookies = document.cookie.split('; ').reduce(function (acc, cookie) {
- var splitCookie = cookie.split('=');
- var name = splitCookie[0];
-
- if (name in trackingCookieNameMap) {
- var mappedName = trackingCookieNameMap[name];
- var value = splitCookie.slice(1).join('=');
- acc[mappedName] = value;
- }
-
- return acc;
- }, {});
- return cookies;
- }
-
- function getStatus(field, type, name, value) {
- var status = null;
-
- if (type === 'password') {
- status = 'Passwords cannot be submitted.';
- } else if (field.attr('required')) {
- if (!value) {
- status = 'Please fill out the required field: ' + name;
- } else if (emailField.test(field.attr('type'))) {
- if (!emailValue.test(value)) {
- status = 'Please enter a valid email address for: ' + name;
- }
- }
- } else if (name === 'g-recaptcha-response' && !value) {
- status = 'Please confirm you’re not a robot.';
- }
-
- return status;
- }
-
- function exportedSubmitWebflow(data) {
- preventDefault(data);
- afterSubmit(data);
- } // Submit form to MailChimp
-
-
- function submitMailChimp(data) {
- reset(data);
- var form = data.form;
- var payload = {}; // Skip Ajax submission if http/s mismatch, fallback to POST instead
-
- if (/^https/.test(loc.href) && !/^https/.test(data.action)) {
- form.attr('method', 'post');
- return;
- }
-
- preventDefault(data); // Find & populate all fields
-
- var status = findFields(form, payload);
-
- if (status) {
- return alert(status);
- } // Disable submit button
-
-
- disableBtn(data); // Use special format for MailChimp params
-
- var fullName;
-
- _.each(payload, function (value, key) {
- if (emailField.test(key)) {
- payload.EMAIL = value;
- }
-
- if (/^((full[ _-]?)?name)$/i.test(key)) {
- fullName = value;
- }
-
- if (/^(first[ _-]?name)$/i.test(key)) {
- payload.FNAME = value;
- }
-
- if (/^(last[ _-]?name)$/i.test(key)) {
- payload.LNAME = value;
- }
- });
-
- if (fullName && !payload.FNAME) {
- fullName = fullName.split(' ');
- payload.FNAME = fullName[0];
- payload.LNAME = payload.LNAME || fullName[1];
- } // Use the (undocumented) MailChimp jsonp api
-
-
- var url = data.action.replace('/post?', '/post-json?') + '&c=?'; // Add special param to prevent bot signups
-
- var userId = url.indexOf('u=') + 2;
- userId = url.substring(userId, url.indexOf('&', userId));
- var listId = url.indexOf('id=') + 3;
- listId = url.substring(listId, url.indexOf('&', listId));
- payload['b_' + userId + '_' + listId] = '';
- $.ajax({
- url: url,
- data: payload,
- dataType: 'jsonp'
- }).done(function (resp) {
- data.success = resp.result === 'success' || /already/.test(resp.msg);
-
- if (!data.success) {
- console.info('MailChimp error: ' + resp.msg);
- }
-
- afterSubmit(data);
- }).fail(function () {
- afterSubmit(data);
- });
- } // Common callback which runs after all Ajax submissions
-
-
- function afterSubmit(data) {
- var form = data.form;
- var redirect = data.redirect;
- var success = data.success; // Redirect to a success url if defined
-
- if (success && redirect) {
- Webflow.location(redirect);
- return;
- } // Show or hide status divs
-
-
- data.done.toggle(success);
- data.fail.toggle(!success);
-
- if (success) {
- data.done.focus();
- } else {
- data.fail.focus();
- } // Hide form on success
-
-
- form.toggle(!success); // Reset data and enable submit button
-
- reset(data);
- }
-
- function preventDefault(data) {
- data.evt && data.evt.preventDefault();
- data.evt = null;
- }
-
- function initFileUpload(i, form) {
- if (!form.fileUploads || !form.fileUploads[i]) {
- return;
- }
-
- var file;
- var $el = $(form.fileUploads[i]);
- var $defaultWrap = $el.find('> .w-file-upload-default');
- var $uploadingWrap = $el.find('> .w-file-upload-uploading');
- var $successWrap = $el.find('> .w-file-upload-success');
- var $errorWrap = $el.find('> .w-file-upload-error');
- var $input = $defaultWrap.find('.w-file-upload-input');
- var $label = $defaultWrap.find('.w-file-upload-label');
- var $labelChildren = $label.children();
- var $errorMsgEl = $errorWrap.find('.w-file-upload-error-msg');
- var $fileEl = $successWrap.find('.w-file-upload-file');
- var $removeEl = $successWrap.find('.w-file-remove-link');
- var $fileNameEl = $fileEl.find('.w-file-upload-file-name');
- var sizeErrMsg = $errorMsgEl.attr('data-w-size-error');
- var typeErrMsg = $errorMsgEl.attr('data-w-type-error');
- var genericErrMsg = $errorMsgEl.attr('data-w-generic-error'); // Accessiblity fixes
- // The file upload Input is not stylable by the designer, so we are
- // going to pretend the Label is the input. ¯\_(ツ)_/¯
-
- if (!inApp) {
- $label.on('click keydown', function (e) {
- if (e.type === 'keydown' && e.which !== 13 && e.which !== 32) {
- return;
- }
-
- e.preventDefault();
- $input.click();
- });
- } // Both of these are added through CSS
-
-
- $label.find('.w-icon-file-upload-icon').attr('aria-hidden', 'true');
- $removeEl.find('.w-icon-file-upload-remove').attr('aria-hidden', 'true');
-
- if (!inApp) {
- $removeEl.on('click keydown', function (e) {
- if (e.type === 'keydown') {
- if (e.which !== 13 && e.which !== 32) {
- return;
- }
-
- e.preventDefault();
- }
-
- $input.removeAttr('data-value');
- $input.val('');
- $fileNameEl.html('');
- $defaultWrap.toggle(true);
- $successWrap.toggle(false);
- $label.focus();
- });
- $input.on('change', function (e) {
- file = e.target && e.target.files && e.target.files[0];
-
- if (!file) {
- return;
- } // Show uploading
-
-
- $defaultWrap.toggle(false);
- $errorWrap.toggle(false);
- $uploadingWrap.toggle(true);
- $uploadingWrap.focus(); // Set filename
-
- $fileNameEl.text(file.name); // Disable submit button
-
- if (!isUploading()) {
- disableBtn(form);
- }
-
- form.fileUploads[i].uploading = true;
- signFile(file, afterSign);
- }); // Setting input width 1px and height equal label
- // This is so the browser required error will show up
-
- var height = $label.outerHeight();
- $input.height(height);
- $input.width(1);
- } else {
- $input.on('click', function (e) {
- e.preventDefault();
- });
- $label.on('click', function (e) {
- e.preventDefault();
- });
- $labelChildren.on('click', function (e) {
- e.preventDefault();
- });
- }
-
- function parseError(err) {
- var errorMsg = err.responseJSON && err.responseJSON.msg;
- var userError = genericErrMsg;
-
- if (typeof errorMsg === 'string' && errorMsg.indexOf('InvalidFileTypeError') === 0) {
- userError = typeErrMsg;
- } else if (typeof errorMsg === 'string' && errorMsg.indexOf('MaxFileSizeError') === 0) {
- userError = sizeErrMsg;
- }
-
- $errorMsgEl.text(userError);
- $input.removeAttr('data-value');
- $input.val('');
- $uploadingWrap.toggle(false);
- $defaultWrap.toggle(true);
- $errorWrap.toggle(true);
- $errorWrap.focus();
- form.fileUploads[i].uploading = false;
-
- if (!isUploading()) {
- reset(form);
- }
- }
-
- function afterSign(err, data) {
- if (err) {
- return parseError(err);
- }
-
- var fileName = data.fileName;
- var postData = data.postData;
- var fileId = data.fileId;
- var s3Url = data.s3Url;
- $input.attr('data-value', fileId);
- uploadS3(s3Url, postData, file, fileName, afterUpload);
- }
-
- function afterUpload(err) {
- if (err) {
- return parseError(err);
- } // Show success
-
-
- $uploadingWrap.toggle(false);
- $successWrap.css('display', 'inline-block');
- $successWrap.focus();
- form.fileUploads[i].uploading = false;
-
- if (!isUploading()) {
- reset(form);
- }
- }
-
- function isUploading() {
- var uploads = form.fileUploads && form.fileUploads.toArray() || [];
- return uploads.some(function (value) {
- return value.uploading;
- });
- }
- }
-
- function signFile(file, cb) {
- var payload = new URLSearchParams({
- name: file.name,
- size: file.size
- });
- $.ajax({
- type: 'GET',
- url: "".concat(signFileUrl, "?").concat(payload),
- crossDomain: true
- }).done(function (data) {
- cb(null, data);
- }).fail(function (err) {
- cb(err);
- });
- }
-
- function uploadS3(url, data, file, fileName, cb) {
- var formData = new FormData();
-
- for (var k in data) {
- formData.append(k, data[k]);
- }
-
- formData.append('file', file, fileName);
- $.ajax({
- type: 'POST',
- url: url,
- data: formData,
- processData: false,
- contentType: false
- }).done(function () {
- cb(null);
- }).fail(function (err) {
- cb(err);
- });
- } // Export module
-
-
- return api;
-});
-
-/***/ }),
-/* 14 */
-/***/ (function(module, exports, __webpack_require__) {
-
-var arrayWithHoles = __webpack_require__(15);
-
-var iterableToArrayLimit = __webpack_require__(16);
-
-var nonIterableRest = __webpack_require__(17);
-
-function _slicedToArray(arr, i) {
- return arrayWithHoles(arr) || iterableToArrayLimit(arr, i) || nonIterableRest();
-}
-
-module.exports = _slicedToArray;
-
-/***/ }),
-/* 15 */
-/***/ (function(module, exports) {
-
-function _arrayWithHoles(arr) {
- if (Array.isArray(arr)) return arr;
-}
-
-module.exports = _arrayWithHoles;
-
-/***/ }),
-/* 16 */
-/***/ (function(module, exports) {
-
-function _iterableToArrayLimit(arr, i) {
- var _arr = [];
- var _n = true;
- var _d = false;
- var _e = undefined;
-
- try {
- for (var _i = arr[Symbol.iterator](), _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["return"] != null) _i["return"]();
- } finally {
- if (_d) throw _e;
- }
- }
-
- return _arr;
-}
-
-module.exports = _iterableToArrayLimit;
-
-/***/ }),
-/* 17 */
-/***/ (function(module, exports) {
-
-function _nonIterableRest() {
- throw new TypeError("Invalid attempt to destructure non-iterable instance");
-}
-
-module.exports = _nonIterableRest;
-
-/***/ }),
-/* 18 */
-/***/ (function(module, exports, __webpack_require__) {
-
-"use strict";
- // @wf-will-never-add-flow-to-this-file
-
-/* globals window, document */
-
-/* eslint-disable no-var */
-
-/**
- * Webflow: Navbar component
- */
-
-var Webflow = __webpack_require__(0);
-
-var IXEvents = __webpack_require__(19);
-
-var KEY_CODES = {
- ARROW_LEFT: 37,
- ARROW_UP: 38,
- ARROW_RIGHT: 39,
- ARROW_DOWN: 40,
- ESCAPE: 27,
- SPACE: 32,
- ENTER: 13,
- HOME: 36,
- END: 35
-};
-Webflow.define('navbar', module.exports = function ($, _) {
- var api = {};
- var tram = $.tram;
- var $win = $(window);
- var $doc = $(document);
- var debounce = _.debounce;
- var $body;
- var $navbars;
- var designer;
- var inEditor;
- var inApp = Webflow.env();
- var overlay = '';
- var namespace = '.w-nav';
- var navbarOpenedButton = 'w--open';
- var navbarOpenedDropdown = 'w--nav-dropdown-open';
- var navbarOpenedDropdownToggle = 'w--nav-dropdown-toggle-open';
- var navbarOpenedDropdownList = 'w--nav-dropdown-list-open';
- var navbarOpenedLink = 'w--nav-link-open';
- var ix = IXEvents.triggers;
- var menuSibling = $(); // -----------------------------------
- // Module methods
-
- api.ready = api.design = api.preview = init;
-
- api.destroy = function () {
- menuSibling = $();
- removeListeners();
-
- if ($navbars && $navbars.length) {
- $navbars.each(teardown);
- }
- }; // -----------------------------------
- // Private methods
-
-
- function init() {
- designer = inApp && Webflow.env('design');
- inEditor = Webflow.env('editor');
- $body = $(document.body); // Find all instances on the page
-
- $navbars = $doc.find(namespace);
-
- if (!$navbars.length) {
- return;
- }
-
- $navbars.each(build); // Wire events
-
- removeListeners();
- addListeners();
- }
-
- function removeListeners() {
- Webflow.resize.off(resizeAll);
- }
-
- function addListeners() {
- Webflow.resize.on(resizeAll);
- }
-
- function resizeAll() {
- $navbars.each(resize);
- }
-
- function build(i, el) {
- var $el = $(el); // Store state in data
-
- var data = $.data(el, namespace);
-
- if (!data) {
- data = $.data(el, namespace, {
- open: false,
- el: $el,
- config: {},
- selectedIdx: -1
- });
- }
-
- data.menu = $el.find('.w-nav-menu');
- data.links = data.menu.find('.w-nav-link');
- data.dropdowns = data.menu.find('.w-dropdown');
- data.dropdownToggle = data.menu.find('.w-dropdown-toggle');
- data.dropdownList = data.menu.find('.w-dropdown-list');
- data.button = $el.find('.w-nav-button');
- data.container = $el.find('.w-container');
- data.overlayContainerId = 'w-nav-overlay-' + i;
- data.outside = outside(data); // If the brand links exists and is set to link to the homepage, the
- // default setting, then add an aria-label
-
- var navBrandLink = $el.find('.w-nav-brand');
-
- if (navBrandLink && navBrandLink.attr('href') === '/' && navBrandLink.attr('aria-label') == null) {
- navBrandLink.attr('aria-label', 'home');
- } // VoiceOver bug, when items that disallow user selection are focused
- // VoiceOver gets confused and scrolls to the end of the page. ¯\_(ツ)_/¯
-
-
- data.button.attr('style', '-webkit-user-select: text;'); // Add attributes to toggle element
-
- if (data.button.attr('aria-label') == null) {
- data.button.attr('aria-label', 'menu');
- }
-
- data.button.attr('role', 'button');
- data.button.attr('tabindex', '0');
- data.button.attr('aria-controls', data.overlayContainerId);
- data.button.attr('aria-haspopup', 'menu');
- data.button.attr('aria-expanded', 'false'); // Remove old events
-
- data.el.off(namespace);
- data.button.off(namespace);
- data.menu.off(namespace); // Set config from data attributes
-
- configure(data); // Add events based on mode
-
- if (designer) {
- removeOverlay(data);
- data.el.on('setting' + namespace, handler(data));
- } else {
- addOverlay(data);
- data.button.on('click' + namespace, toggle(data));
- data.menu.on('click' + namespace, 'a', navigate(data));
- data.button.on('keydown' + namespace, makeToggleButtonKeyboardHandler(data));
- data.el.on('keydown' + namespace, makeLinksKeyboardHandler(data));
- } // Trigger initial resize
-
-
- resize(i, el);
- }
-
- function teardown(i, el) {
- var data = $.data(el, namespace);
-
- if (data) {
- removeOverlay(data);
- $.removeData(el, namespace);
- }
- }
-
- function removeOverlay(data) {
- if (!data.overlay) {
- return;
- }
-
- close(data, true);
- data.overlay.remove();
- data.overlay = null;
- }
-
- function addOverlay(data) {
- if (data.overlay) {
- return;
- }
-
- data.overlay = $(overlay).appendTo(data.el);
- data.overlay.attr('id', data.overlayContainerId);
- data.parent = data.menu.parent();
- close(data, true);
- }
-
- function configure(data) {
- var config = {};
- var old = data.config || {}; // Set config options from data attributes
-
- var animation = config.animation = data.el.attr('data-animation') || 'default';
- config.animOver = /^over/.test(animation);
- config.animDirect = /left$/.test(animation) ? -1 : 1; // Re-open menu if the animation type changed
-
- if (old.animation !== animation) {
- data.open && _.defer(reopen, data);
- }
-
- config.easing = data.el.attr('data-easing') || 'ease';
- config.easing2 = data.el.attr('data-easing2') || 'ease';
- var duration = data.el.attr('data-duration');
- config.duration = duration != null ? Number(duration) : 400;
- config.docHeight = data.el.attr('data-doc-height'); // Store config in data
-
- data.config = config;
- }
-
- function handler(data) {
- return function (evt, options) {
- options = options || {};
- var winWidth = $win.width();
- configure(data);
- options.open === true && open(data, true);
- options.open === false && close(data, true); // Reopen if media query changed after setting
-
- data.open && _.defer(function () {
- if (winWidth !== $win.width()) {
- reopen(data);
- }
- });
- };
- }
-
- function makeToggleButtonKeyboardHandler(data) {
- return function (evt) {
- switch (evt.keyCode) {
- case KEY_CODES.SPACE:
- case KEY_CODES.ENTER:
- {
- // Toggle returns a function
- toggle(data)();
- evt.preventDefault();
- return evt.stopPropagation();
- }
-
- case KEY_CODES.ESCAPE:
- {
- close(data);
- evt.preventDefault();
- return evt.stopPropagation();
- }
-
- case KEY_CODES.ARROW_RIGHT:
- case KEY_CODES.ARROW_DOWN:
- case KEY_CODES.HOME:
- case KEY_CODES.END:
- {
- if (!data.open) {
- evt.preventDefault();
- return evt.stopPropagation();
- }
-
- if (evt.keyCode === KEY_CODES.END) {
- data.selectedIdx = data.links.length - 1;
- } else {
- data.selectedIdx = 0;
- }
-
- focusSelectedLink(data);
- evt.preventDefault();
- return evt.stopPropagation();
- }
- }
- };
- }
-
- function makeLinksKeyboardHandler(data) {
- return function (evt) {
- if (!data.open) {
- return;
- } // Realign selectedIdx with the menu item that is currently in focus.
- // We need this because we do not track the `Tab` key activity!
-
-
- data.selectedIdx = data.links.index(document.activeElement);
-
- switch (evt.keyCode) {
- case KEY_CODES.HOME:
- case KEY_CODES.END:
- {
- if (evt.keyCode === KEY_CODES.END) {
- data.selectedIdx = data.links.length - 1;
- } else {
- data.selectedIdx = 0;
- }
-
- focusSelectedLink(data);
- evt.preventDefault();
- return evt.stopPropagation();
- }
-
- case KEY_CODES.ESCAPE:
- {
- close(data); // Focus toggle button
-
- data.button.focus();
- evt.preventDefault();
- return evt.stopPropagation();
- }
-
- case KEY_CODES.ARROW_LEFT:
- case KEY_CODES.ARROW_UP:
- {
- data.selectedIdx = Math.max(-1, data.selectedIdx - 1);
- focusSelectedLink(data);
- evt.preventDefault();
- return evt.stopPropagation();
- }
-
- case KEY_CODES.ARROW_RIGHT:
- case KEY_CODES.ARROW_DOWN:
- {
- data.selectedIdx = Math.min(data.links.length - 1, data.selectedIdx + 1);
- focusSelectedLink(data);
- evt.preventDefault();
- return evt.stopPropagation();
- }
- }
- };
- }
-
- function focusSelectedLink(data) {
- if (data.links[data.selectedIdx]) {
- var selectedElement = data.links[data.selectedIdx];
- selectedElement.focus();
- navigate(selectedElement);
- }
- }
-
- function reopen(data) {
- if (!data.open) {
- return;
- }
-
- close(data, true);
- open(data, true);
- }
-
- function toggle(data) {
- // Debounce toggle to wait for accurate open state
- return debounce(function () {
- data.open ? close(data) : open(data);
- });
- }
-
- function navigate(data) {
- return function (evt) {
- var link = $(this);
- var href = link.attr('href'); // Avoid late clicks on touch devices
-
- if (!Webflow.validClick(evt.currentTarget)) {
- evt.preventDefault();
- return;
- } // Close when navigating to an in-page anchor
-
-
- if (href && href.indexOf('#') === 0 && data.open) {
- close(data);
- }
- };
- }
-
- function outside(data) {
- // Unbind previous click handler if it exists
- if (data.outside) {
- $doc.off('click' + namespace, data.outside);
- }
-
- return function (evt) {
- var $target = $(evt.target); // Ignore clicks on Editor overlay UI
-
- if (inEditor && $target.closest('.w-editor-bem-EditorOverlay').length) {
- return;
- } // Close menu when clicked outside, debounced to wait for state
-
-
- outsideDebounced(data, $target);
- };
- }
-
- var outsideDebounced = debounce(function (data, $target) {
- if (!data.open) {
- return;
- }
-
- var menu = $target.closest('.w-nav-menu');
-
- if (!data.menu.is(menu)) {
- close(data);
- }
- });
-
- function resize(i, el) {
- var data = $.data(el, namespace); // Check for collapsed state based on button display
-
- var collapsed = data.collapsed = data.button.css('display') !== 'none'; // Close menu if button is no longer visible (and not in designer)
-
- if (data.open && !collapsed && !designer) {
- close(data, true);
- } // Set max-width of links + dropdowns to match container
-
-
- if (data.container.length) {
- var updateEachMax = updateMax(data);
- data.links.each(updateEachMax);
- data.dropdowns.each(updateEachMax);
- } // If currently open, update height to match body
-
-
- if (data.open) {
- setOverlayHeight(data);
- }
- }
-
- var maxWidth = 'max-width';
-
- function updateMax(data) {
- // Set max-width of each element to match container
- var containMax = data.container.css(maxWidth);
-
- if (containMax === 'none') {
- containMax = '';
- }
-
- return function (i, link) {
- link = $(link);
- link.css(maxWidth, ''); // Don't set the max-width if an upstream value exists
-
- if (link.css(maxWidth) === 'none') {
- link.css(maxWidth, containMax);
- }
- };
- }
-
- function addMenuOpen(i, el) {
- el.setAttribute('data-nav-menu-open', '');
- }
-
- function removeMenuOpen(i, el) {
- el.removeAttribute('data-nav-menu-open');
- }
-
- function open(data, immediate) {
- if (data.open) {
- return;
- }
-
- data.open = true;
- data.menu.each(addMenuOpen);
- data.links.addClass(navbarOpenedLink);
- data.dropdowns.addClass(navbarOpenedDropdown);
- data.dropdownToggle.addClass(navbarOpenedDropdownToggle);
- data.dropdownList.addClass(navbarOpenedDropdownList);
- data.button.addClass(navbarOpenedButton);
- var config = data.config;
- var animation = config.animation;
-
- if (animation === 'none' || !tram.support.transform || config.duration <= 0) {
- immediate = true;
- }
-
- var bodyHeight = setOverlayHeight(data);
- var menuHeight = data.menu.outerHeight(true);
- var menuWidth = data.menu.outerWidth(true);
- var navHeight = data.el.height();
- var navbarEl = data.el[0];
- resize(0, navbarEl);
- ix.intro(0, navbarEl);
- Webflow.redraw.up(); // Listen for click outside events
-
- if (!designer) {
- $doc.on('click' + namespace, data.outside);
- } // No transition for immediate
-
-
- if (immediate) {
- complete();
- return;
- }
-
- var transConfig = 'transform ' + config.duration + 'ms ' + config.easing; // Add menu to overlay
-
- if (data.overlay) {
- menuSibling = data.menu.prev();
- data.overlay.show().append(data.menu);
- } // Over left/right
-
-
- if (config.animOver) {
- tram(data.menu).add(transConfig).set({
- x: config.animDirect * menuWidth,
- height: bodyHeight
- }).start({
- x: 0
- }).then(complete);
- data.overlay && data.overlay.width(menuWidth);
- return;
- } // Drop Down
-
-
- var offsetY = navHeight + menuHeight;
- tram(data.menu).add(transConfig).set({
- y: -offsetY
- }).start({
- y: 0
- }).then(complete);
-
- function complete() {
- data.button.attr('aria-expanded', 'true');
- }
- }
-
- function setOverlayHeight(data) {
- var config = data.config;
- var bodyHeight = config.docHeight ? $doc.height() : $body.height();
-
- if (config.animOver) {
- data.menu.height(bodyHeight);
- } else if (data.el.css('position') !== 'fixed') {
- bodyHeight -= data.el.outerHeight(true);
- }
-
- data.overlay && data.overlay.height(bodyHeight);
- return bodyHeight;
- }
-
- function close(data, immediate) {
- if (!data.open) {
- return;
- }
-
- data.open = false;
- data.button.removeClass(navbarOpenedButton);
- var config = data.config;
-
- if (config.animation === 'none' || !tram.support.transform || config.duration <= 0) {
- immediate = true;
- }
-
- ix.outro(0, data.el[0]); // Stop listening for click outside events
-
- $doc.off('click' + namespace, data.outside);
-
- if (immediate) {
- tram(data.menu).stop();
- complete();
- return;
- }
-
- var transConfig = 'transform ' + config.duration + 'ms ' + config.easing2;
- var menuHeight = data.menu.outerHeight(true);
- var menuWidth = data.menu.outerWidth(true);
- var navHeight = data.el.height(); // Over left/right
-
- if (config.animOver) {
- tram(data.menu).add(transConfig).start({
- x: menuWidth * config.animDirect
- }).then(complete);
- return;
- } // Drop Down
-
-
- var offsetY = navHeight + menuHeight;
- tram(data.menu).add(transConfig).start({
- y: -offsetY
- }).then(complete);
-
- function complete() {
- data.menu.height('');
- tram(data.menu).set({
- x: 0,
- y: 0
- });
- data.menu.each(removeMenuOpen);
- data.links.removeClass(navbarOpenedLink);
- data.dropdowns.removeClass(navbarOpenedDropdown);
- data.dropdownToggle.removeClass(navbarOpenedDropdownToggle);
- data.dropdownList.removeClass(navbarOpenedDropdownList);
-
- if (data.overlay && data.overlay.children().length) {
- // Move menu back to parent at the original location
- menuSibling.length ? data.menu.insertAfter(menuSibling) : data.menu.prependTo(data.parent);
- data.overlay.attr('style', '').hide();
- } // Trigger event so other components can hook in (dropdown)
-
-
- data.el.triggerHandler('w-close');
- data.button.attr('aria-expanded', 'false');
- }
- } // Export module
-
-
- return api;
-});
-
-/***/ }),
-/* 19 */
-/***/ (function(module, exports, __webpack_require__) {
-
-"use strict";
-// @wf-will-never-add-flow-to-this-file
-
-/* globals window, document */
-
-/* eslint-disable no-var */
-// eslint-disable-next-line strict
-
-
-var IXEvents = __webpack_require__(20);
-
-function dispatchCustomEvent(element, eventName) {
- var event = document.createEvent('CustomEvent');
- event.initCustomEvent(eventName, true, true, null);
- element.dispatchEvent(event);
-}
-/**
- * Webflow: IX Event triggers for other modules
- */
-
-
-var $ = window.jQuery;
-var api = {};
-var namespace = '.w-ix';
-var eventTriggers = {
- reset: function reset(i, el) {
- IXEvents.triggers.reset(i, el);
- },
- intro: function intro(i, el) {
- IXEvents.triggers.intro(i, el);
- dispatchCustomEvent(el, 'COMPONENT_ACTIVE');
- },
- outro: function outro(i, el) {
- IXEvents.triggers.outro(i, el);
- dispatchCustomEvent(el, 'COMPONENT_INACTIVE');
- }
-};
-api.triggers = {};
-api.types = {
- INTRO: 'w-ix-intro' + namespace,
- OUTRO: 'w-ix-outro' + namespace
-};
-$.extend(api.triggers, eventTriggers);
-module.exports = api;
-
-/***/ }),
-/* 20 */
-/***/ (function(module, exports, __webpack_require__) {
-
-"use strict";
-// @wf-will-never-add-flow-to-this-file
-
-/* globals window */
-
-/* eslint-disable no-var */
-
-/**
- * Webflow: IX Event triggers for other modules
- */
-// eslint-disable-next-line strict
-
-
-var $ = window.jQuery;
-var api = {};
-var eventQueue = [];
-var namespace = '.w-ix';
-var eventTriggers = {
- reset: function reset(i, el) {
- el.__wf_intro = null;
- },
- intro: function intro(i, el) {
- if (el.__wf_intro) {
- return;
- }
-
- el.__wf_intro = true;
- $(el).triggerHandler(api.types.INTRO);
- },
- outro: function outro(i, el) {
- if (!el.__wf_intro) {
- return;
- }
-
- el.__wf_intro = null;
- $(el).triggerHandler(api.types.OUTRO);
- }
-};
-api.triggers = {};
-api.types = {
- INTRO: 'w-ix-intro' + namespace,
- OUTRO: 'w-ix-outro' + namespace
-}; // Trigger any events in queue + restore trigger methods
-
-api.init = function () {
- var count = eventQueue.length;
-
- for (var i = 0; i < count; i++) {
- var memo = eventQueue[i];
- memo[0](0, memo[1]);
- }
-
- eventQueue = [];
- $.extend(api.triggers, eventTriggers);
-}; // Replace all triggers with async wrapper to queue events until init
-
-
-api.async = function () {
- for (var key in eventTriggers) {
- var func = eventTriggers[key];
-
- if (!eventTriggers.hasOwnProperty(key)) {
- continue;
- } // Replace trigger method with async wrapper
-
-
- api.triggers[key] = function (i, el) {
- eventQueue.push([func, el]);
- };
- }
-}; // Default triggers to async queue
-
-
-api.async();
-module.exports = api;
-
-/***/ })
-/******/ ]);
\ No newline at end of file