var script = function script(props) {
  var els = {
    el: null,
    readModeDiv: null,
    editModeDiv: null,
    editModeCTA: null,
    readModeCTA: null
  };

  var init = function init() {
    els.el = props.el;
    els.readModeDiv = els.el.querySelector('.readmode');
    els.editModeDiv = els.el.querySelector('.editmode');
    els.editModeCTA = els.el.querySelector('.edit-cta');
    els.readModeCTA = els.el.querySelector('.read-cta');
    addListeners();
  };

  var addListeners = function addListeners() {
    els.editModeCTA.addEventListener('click', function (e) {
      e.preventDefault();
      els.editModeDiv.classList.remove('hidden');
      els.readModeDiv.classList.add('hidden');
    });
    els.readModeCTA.addEventListener('click', function (e) {
      e.preventDefault(); // just reload the page to get any changes from server

      window.location.reload();
    });
  };

  return {
    init: init
  };
};

window.app.add({
  name: 'profileForm',
  script: script
});

function _toConsumableArray(arr) { return _arrayWithoutHoles(arr) || _iterableToArray(arr) || _unsupportedIterableToArray(arr) || _nonIterableSpread(); }

function _nonIterableSpread() { throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }

function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }

function _iterableToArray(iter) { if (typeof Symbol !== "undefined" && Symbol.iterator in Object(iter)) return Array.from(iter); }

function _arrayWithoutHoles(arr) { if (Array.isArray(arr)) return _arrayLikeToArray(arr); }

function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; }

function asyncGeneratorStep(gen, resolve, reject, _next, _throw, key, arg) { try { var info = gen[key](arg); var value = info.value; } catch (error) { reject(error); return; } if (info.done) { resolve(value); } else { Promise.resolve(value).then(_next, _throw); } }

function _asyncToGenerator(fn) { return function () { var self = this, args = arguments; return new Promise(function (resolve, reject) { var gen = fn.apply(self, args); function _next(value) { asyncGeneratorStep(gen, resolve, reject, _next, _throw, "next", value); } function _throw(err) { asyncGeneratorStep(gen, resolve, reject, _next, _throw, "throw", err); } _next(undefined); }); }; }

var script = function script(props) {
    // get page url
    var pageUrl = window.location.pathname; // fake for testing
    // pageUrl = '/staff/board-of-directors/simon-fraser';

    var init = function init() {
        // *** make api call, and generate content via frontend/alchemy-templates.js
        var fetchData = /*#__PURE__*/function () {
            var _ref = _asyncToGenerator( /*#__PURE__*/regeneratorRuntime.mark(function _callee() {
                var data;
                return regeneratorRuntime.wrap(function _callee$(_context) {
                    while (1) {
                        switch (_context.prev = _context.next) {
                            case 0:
                                _context.next = 2;
                                return props.fetchData(props.attributes);

                            case 2:
                                data = _context.sent;
                                parseData(data.payload.Result, props.attributes);

                            case 4:
                            case "end":
                                return _context.stop();
                        }
                    }
                }, _callee);
            }));

            return function fetchData() {
                return _ref.apply(this, arguments);
            };
        }();

        if (props.attributes.datasource) {
            fetchData();
        }
    }; // *** parsing specific to this component - if encountering a similar requirement consider refactoring into a utility


    var parseData = function parseData(data, options) {
        // set to empty array if nothing in results to choke errors
        if (!data) data = []; //exclude staff member from carousel if we are on the staff bio page

        var updated = [];
        updated = data.filter(function (item) {
            return item['Url'] != pageUrl;
        }); //compare pageurl excluding domain to staff href

        data = updated;
        var jsonMap = props.utils.attributeParser(props.el.getAttribute('data-json-mapping'));
        var criteria = []; // *** in this case we are splitting data into chunks relative to unique 'RoleId' sets

        data.map(function (item) {
            item[options.key].map(function (id) {
                criteria.push(id);
                return true;
            });
        });
        criteria = _toConsumableArray(new Set(criteria)); // *** unique values only
        // *** chunk data by criteria

        var chunks = criteria.map(function (value) {
            return data.filter(function (item) {
                return item[options.key].includes(value);
            });
        }); // *** build nodes from data

        var nodes = chunks.map(function (chunk) {
            return chunk.map(function (item) {
                return window.alchemyTemplates.getTemplate({
                    type: props.attributes.template || '',
                    map: jsonMap,
                    parent: props.el
                }, item);
            });
        });

        var getLabel = function getLabel(criteria) {
            var values = options.values.filter(function (item) {
                return item[0] === criteria;
            });

            if (values.length > 0) {
                return values[0][1];
            }

            return '...';
        }; // *** wrap output object and return


        var result = nodes.map(function (item, index) {
            return {
                label: getLabel(criteria[index]),
                nodes: nodes[index]
            };
        });
        build(result);
    }; // *** populate behaviours with generated content from api data


    var build = function build(nodes) {
        var defaultIndex = 0; // check if we actually have any nodes...

        var hasNoResults = nodes.length === 0; // if we have nothing dont proceed./

        if (hasNoResults) {
            showNoResults();
            return;
        } else {
            props.el.classList.remove('tabstack--noresults');
        } // *** data to populate tabswitcher and select


        var getTabButtons = function getTabButtons() {
            return nodes.map(function (item) {
                return {
                    label: item.label
                };
            });
        }; // *** TABSWITCHER


        var tabSwitcher = props.getBehaviour(props.el.querySelector('.tab-switcher-control'));
        tabSwitcher.inject(getTabButtons(), defaultIndex); // ...
        // *** SELECT

        var selectControl = props.getBehaviour(props.el.querySelector('.select-control'));
        selectControl.inject(getTabButtons(), defaultIndex); // ...
        // *** TABSTACK

        var tabStack = props.getBehaviour(props.el.querySelector('.tabstack'));
        tabStack.inject(nodes, defaultIndex); // ...
        // *** CAROUSEL

        var carousel = props.getBehaviour(props.el.querySelector('.carousel'));

        var updateCarousel = function updateCarousel(index) {
            var data = nodes[index].nodes.map(function (item) {
                return item.cloneNode(true); // *** clone node to use again, otherwise it will be removed from tabstack
            });
            carousel.inject(data, defaultIndex);
        }; // ...
        // *** use select control events to update carousel


        props.events.on('BEHAVIOUR_BINDING_SIGNAL', function (payload) {
            if (payload.sender !== tabSwitcher.getOptions().config.uid && payload.sender !== selectControl.getOptions().config.uid) return;
            updateCarousel(payload.data.index);
        });
        updateCarousel(defaultIndex);
    };

    var showNoResults = function showNoResults() {
        // const tabContainer = props.el.querySelector('.tabstack');
        // if nothing comes back from api lets append a message to tell user
        var noResultsDiv = document.createElement('div');
        var resultsText = props.attributes.noresult ? props.attributes.noresult : '';
        noResultsDiv.classList.add('tabstack__no-results');
        noResultsDiv.innerText = resultsText;
        props.el.appendChild(noResultsDiv); // hide anything we dont need with csss, like selects, etc

        props.el.classList.add('tabstack--noresults');

        
        // quick fix hide entire component if results are empty AND text is set to hide
        if (resultsText=="hide") {
            props.el.style.display = 'none';
    
        }
    };

    return {
        init: init
    };
};

window.app.add({
    name: 'staffCarousel',
    // *** ensure unique
    script: script
});

function _toConsumableArray(arr) { return _arrayWithoutHoles(arr) || _iterableToArray(arr) || _unsupportedIterableToArray(arr) || _nonIterableSpread(); }

function _nonIterableSpread() { throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }

function _iterableToArray(iter) { if (typeof Symbol !== "undefined" && Symbol.iterator in Object(iter)) return Array.from(iter); }

function _arrayWithoutHoles(arr) { if (Array.isArray(arr)) return _arrayLikeToArray(arr); }

function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }

function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }

function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }

function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; }

function _iterableToArrayLimit(arr, i) { if (typeof Symbol === "undefined" || !(Symbol.iterator in Object(arr))) return; 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; }

function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }

function asyncGeneratorStep(gen, resolve, reject, _next, _throw, key, arg) { try { var info = gen[key](arg); var value = info.value; } catch (error) { reject(error); return; } if (info.done) { resolve(value); } else { Promise.resolve(value).then(_next, _throw); } }

function _asyncToGenerator(fn) { return function () { var self = this, args = arguments; return new Promise(function (resolve, reject) { var gen = fn.apply(self, args); function _next(value) { asyncGeneratorStep(gen, resolve, reject, _next, _throw, "next", value); } function _throw(err) { asyncGeneratorStep(gen, resolve, reject, _next, _throw, "throw", err); } _next(undefined); }); }; }

var script = function script(props) {
    var init = function init() {
        // *** make api call, and generate content via frontend/alchemy-templates.js
        var fetchData = /*#__PURE__*/function () {
            var _ref = _asyncToGenerator( /*#__PURE__*/regeneratorRuntime.mark(function _callee() {
                var queryParams, _data, _data2;

                return regeneratorRuntime.wrap(function _callee$(_context) {
                    while (1) {
                        switch (_context.prev = _context.next) {
                            case 0:
                                // @ja pass tags through to queryparams
                                queryParams = getAllTags(props.attributes);

                                if (!queryParams) {
                                    _context.next = 8;
                                    break;
                                }

                                _context.next = 4;
                                return props.fetchData(props.attributes, queryParams);

                            case 4:
                                _data = _context.sent;
                                parseData(_data.payload.Result, props.attributes);
                                _context.next = 12;
                                break;

                            case 8:
                                _context.next = 10;
                                return props.fetchData(props.attributes);

                            case 10:
                                _data2 = _context.sent;
                                parseData(_data2.payload.Result, props.attributes);

                            case 12:
                            case "end":
                                return _context.stop();
                        }
                    }
                }, _callee);
            }));

            return function fetchData() {
                return _ref.apply(this, arguments);
            };
        }();

        if (props.attributes.datasource) {
            fetchData();
        }
    }; // *** @ja added in extra AllTags param to api for added filtering


    var getAllTags = function getAllTags(attrs) {
        if (!attrs.allTags) return null; // be present

        var rawTags = attrs.allTags;
        var regex = /\'/g;
        var tags = rawTags.replace(regex, '');
        if (typeof tags !== 'string' || tags === '') return null; // be a string and not empty

        if (tags.indexOf('|' > -1)) {
            var tagArray = tags.split('|');
            var str = tagArray.join(',');
            return {
                AllTags: str
            };
        } else {
            return {
                AllTags: tags
            };
        }
    }; // *** parsing specific to this component - if encountering a similar requirement consider refactoring into a utility


    var parseData = function parseData(data, options) {
        data.map(function (item, index) {
            // flatten out this reviewType obj so we can filter against it
            for (var _i = 0, _Object$entries = Object.entries(item['ReviewType']); _i < _Object$entries.length; _i++) {
                var _Object$entries$_i = _slicedToArray(_Object$entries[_i], 2),
                    key = _Object$entries$_i[0],
                    value = _Object$entries$_i[1];

                item[key] = value;
            } // if we have video information...


            if (item['VideoData'] && item['VideoData']['VideoType'] !== null) {
                // we need a unique carousel thumb id
                item['VideoUID'] = "video-carousel-thumb-".concat(index); // and we also need to construct the config string properly...

                item['VideoConfig'] = makeVideoConfigString(item['VideoData']);
            }
        });
        var jsonMap = props.utils.attributeParser(props.el.getAttribute('data-json-mapping'));
        var criteria = []; // *** in this case we are splitting data into chunks relative to unique 'RoleId' sets

        data.map(function (item) {
            criteria.push(item[options.key]); // *** get all values
        });
        criteria = _toConsumableArray(new Set(criteria)); // *** unique values only
        // *** chunk data by criteria

        var chunks = criteria.map(function (value) {
            return data.filter(function (item) {
                return item[options.key] === value;
            });
        }); // *** build nodes from data

        var nodes = chunks.map(function (chunk) {
            return chunk.map(function (item) {
                return window.alchemyTemplates.getTemplate({
                    type: props.attributes.template || '',
                    map: jsonMap,
                    parent: props.el
                }, item);
            });
        });

        var getLabel = function getLabel(criteria) {
            var values = options.values.filter(function (item) {
                return item[0] === criteria;
            });

            if (values.length > 0) {
                return values[0][1];
            }

            return '...';
        }; // *** wrap output object and return


        var result = nodes.map(function (item, index) {
            return {
                label: getLabel(criteria[index]),
                nodes: nodes[index]
            };
        });
        build(result);
    }; // *** populate behaviours with generated content from api data


    var build = function build(nodes) {
        var defaultIndex = 0; // check if we actually have any nodes...

        var hasNoResults = nodes.length === 0; // if we have nothing dont proceed./

        if (hasNoResults) {
            showNoResults();
            return;
        } else {
            props.el.classList.remove('tabstack--noresults');
        } // *** data to populate tabswitcher and select


        var getTabButtons = function getTabButtons() {
            return nodes.map(function (item) {
                return {
                    label: item.label
                };
            });
        }; // *** TABSWITCHER


        var tabSwitcher = props.getBehaviour(props.el.querySelector('.tab-switcher-control'));
        tabSwitcher.inject(getTabButtons(), defaultIndex); // ...
        // *** SELECT

        var selectControl = props.getBehaviour(props.el.querySelector('.select-control'));
        selectControl.inject(getTabButtons(), defaultIndex); // *** TABSTACK

        var tabStack = props.getBehaviour(props.el.querySelector('.tabstack'));
        tabStack.inject(nodes, defaultIndex); // ...
        // *** CAROUSEL

        var carousel = props.getBehaviour(props.el.querySelector('.carousel'));

        var updateCarousel = function updateCarousel(index) {
            var data = nodes[index].nodes.map(function (item) {
                return item.cloneNode(true); // *** clone node to use again, otherwise it will be removed from tabstack
            });
            carousel.inject(data, defaultIndex); // an array of thumb items

            var thumbs = data.map(function (item) {
                return item.querySelector("[data-behaviour=\"video-player\"]");
            });
            var clipboards = data.map(function (item) {
                return item.querySelector("[data-behaviour=\"clipboard\"]");
            });
            var shareBTNS = data.map(function (item) {
                return item.querySelector("[data-behaviour=\"asset-share\"]");
            });
            var filtered = thumbs.filter(function (item) {
                return item !== null;
            });
            var filterClipboard = clipboards.filter(function (item) {
                return item !== null;
            });
            var filterShareBTN = shareBTNS.filter(function (item) {
                return item !== null;
            });
            carousel.inject(data, defaultIndex); // have to register these event handlers manually now..

            setTimeout(function () {
                primeThumbs(filtered);
                primeClipboards(filterClipboard);
                primeShareBTNS(filterShareBTN);
            }, 1000);
        }; // ...
        // *** use select control events to update carousel


        props.events.on('BEHAVIOUR_BINDING_SIGNAL', function (payload) {
            if (payload.sender !== tabSwitcher.getOptions().config.uid && payload.sender !== selectControl.getOptions().config.uid) return;
            updateCarousel(payload.data.index);
        });
        updateCarousel(defaultIndex);
    };

    var showNoResults = function showNoResults() {
        // const tabContainer = props.el.querySelector('.tabstack');
        // if nothing comes back from api lets append a message to tell user
        var noResultsDiv = document.createElement('div');
        var resultsText = props.attributes.noresult ? props.attributes.noresult : '';
        noResultsDiv.classList.add('tabstack__no-results');
        noResultsDiv.innerText = resultsText;
        props.el.appendChild(noResultsDiv); // hide anything we dont need with csss, like selects, etc

        props.el.classList.add('tabstack--noresults');

        // quick fix hide entire component if results are empty AND text is set to hide
        if (resultsText == "hide") {
            props.el.style.display = 'none';

            const anchor = props.el.querySelector('.offset-anchor');
            if (anchor) {
                if (anchor.id) {
                    // fire an event for the stickynav to pickup
                    props.events.emit('STICKYNAV_REMOVE_ITEM', {
                        id: anchor.id,
                    });
                }
            }
        }
    };

    var makeVideoConfigString = function makeVideoConfigString(obj) {
        var returnStr;
        var type = obj['VideoType'];

        switch (type) {
            case 'contenthub':
                returnStr = "type: html5, src: ".concat(obj['VideoUrl']);
                break;

            case 'youtube':
                returnStr = "type: youtube, ytVideoId: ".concat(obj['VideoId']);
                break;

            case 'vimeo':
                returnStr = "type: vimeo, vimVideoId: ".concat(obj['VideoId']);
                break;

            case 'brightcove':
                returnStr = "type: brightcove, bcVideoId: ".concat(obj['VideoId'], ", bcAccountId: ").concat(obj['VideoAccountId'], ", bcPlayerId: ").concat(obj['VideoPlayerId']);
                break;
        } // add poster img if present..


        if (obj['VideoPoster'] && obj['VideoPoster'] !== null) returnStr += ", poster: ".concat(obj['VideoPoster']);
        return returnStr;
    };

    var primeThumbs = function primeThumbs(thumbs) {
        var videoThumbs = _toConsumableArray(thumbs); // Manually register these thumb items with the VideoPlayer behaviour


        videoThumbs.map(function (item, index) {
            item.getAttribute('data-behaviour-uid');
            props.registerBehaviour(item);
        });
    };

    var primeClipboards = function primeClipboards(clipboards) {
        var videoClipboards = _toConsumableArray(clipboards); // Manually register these thumb items with the VideoPlayer behaviour


        videoClipboards.map(function (item, index) {
            item.getAttribute('data-behaviour-uid');
            props.registerBehaviour(item);
        });
    };

    var primeShareBTNS = function primeShareBTNS(shareBTNS) {
        var videoShareBTNS = _toConsumableArray(shareBTNS); // Manually register these thumb items with the VideoPlayer behaviour


        videoShareBTNS.map(function (item, index) {
            item.getAttribute('data-behaviour-uid');
            props.registerBehaviour(item);
        });
    };

    return {
        init: init
    };
};

window.app.add({
    name: 'videoThumbsCarousel',
    // *** ensure unique
    script: script
});
function _toConsumableArray(arr) { return _arrayWithoutHoles(arr) || _iterableToArray(arr) || _unsupportedIterableToArray(arr) || _nonIterableSpread(); }

function _nonIterableSpread() { throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }

function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }

function _iterableToArray(iter) { if (typeof Symbol !== "undefined" && Symbol.iterator in Object(iter)) return Array.from(iter); }

function _arrayWithoutHoles(arr) { if (Array.isArray(arr)) return _arrayLikeToArray(arr); }

function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; }

/**
 * simple script to toggle accordion - consider creating a generic utility for this functionality, ensuring namespacing
 */
var script = function script(props) {
    var els = {};

    var init = function init() {
        // *** keep references to els
        els.accordion = props.el.querySelector('.accordion');
        els.textInputs = _toConsumableArray(els.accordion.querySelectorAll('input[type=checkbox]')); // *** add listeners

        els.textInputs.map(function (item) {
            item.addEventListener('click', function () {
                update(item.getAttribute('id'));
            });
        });
    };

    var update = function update(id) {
        els.textInputs.map(function (item) {
            if (item.getAttribute('id') !== id) {
                item.checked = false;
            }
        });
    };

    return {
        init: init
    };
};

window.app.add({
    name: 'featuredGeographicalRegion',
    // *** ensure unique
    script: script
});

function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }

// *** TODO refactor into easily reusable object for all heroes to avoid duplicating this script
var script = function script(props) {
    var els = _defineProperty({
        el: null,
        ctaButton: null,
        selectField1: null
    }, "selectField1", null);

    var init = function init() {
        els.el = props.el;
        els.ctaButton = els.el.querySelector(".timeline-nav-tab");
        els.dropdown = els.el.querySelector(".dropdown__button--timeline");
        els.selectField1 = els.dropdown.querySelector("#timelineDropdpwn");
        els.selectField1.addEventListener("change", function (e) {
            if (e.target.value != "") {
                selectedOption(e.target.value);
            }
        });
        Tabs();
    };

    var Tabs = function Tabs() {
        var bindAll = function bindAll() {
            var menuElements = document.querySelectorAll('[data-tab]');

            for (var i = 0; i < menuElements.length; i++) {
                menuElements[i].addEventListener('click', change, false);
            }
        };

        var clear = function clear() {
            var menuElements = document.querySelectorAll('[data-tab]');

            for (var i = 0; i < menuElements.length; i++) {
                menuElements[i].classList.remove('active');
                var id = menuElements[i].getAttribute('data-tab');
                document.getElementById(id).classList.remove('active');
            }
        };

        var change = function change(e) {
            clear();
            e.target.classList.add('active');
            var id = e.currentTarget.getAttribute('data-tab');
            document.getElementById(id).classList.add('active');
        };

        bindAll();
    };

    var selectedOption = function selectedOption(e) {
        console.log("i m indise");

        if (document.querySelector('#papa div.active') !== null) {
            document.querySelector('#papa div.active').classList.remove('active');
        }

        var tabarea = e;
        console.log(tabarea, "area");
        document.getElementById(tabarea).classList.add('active');
    };

    return {
        init: init
    };
};

window.app.add({
    name: "timeline",
    script: script
});

var script = function script(props) {

    var init = function init() {
        const countryAddressLinksList = [...document.body.querySelectorAll(`.countryAddressLink`)];
        const languageConfirmationYes = document.getElementById('language-confirmation-yes');
        const languageConfirmationText = document.getElementById('languageConfirmationText');
        const confirmationPopupText = document.getElementById('confirmationPopupText');
        if (confirmationPopupText && confirmationPopupText.value) {
            languageConfirmationText.innerHTML = confirmationPopupText.value;
        }
        countryAddressLinksList.map((item) => {
            item.onclick = function () {
                languageConfirmationYes.dataset.redirectionUrl = `${item.dataset.redirectionUrl}`;
                languageConfirmationYes.dataset.iscountryPage = `true`;
            }
        })
    };

    return {
        init: init
    };
};

window.app.add({
    name: 'countryAddressPage',
    // *** ensure unique
    script: script
});
/**
 * Example component script
 * Component scripts are managed by an instance of `src/core/js/view/AbstractComponent.js` which mediates
 * between the core and the components, injecting components with configuration, events etc
 * import statements here are allowed but must be used with caution TODO explain how and why
 * @param {Object} props - TODO
 * @return {{init: init, foo: foo}}
 */
var script = function script(props) {
  // *** mandatory function - called by `AbstractComponent` on instantiation
  var init = function init() {
    console.log('/_example/ -init ', props);
  }; // *** some functions in `AbstractComponent` can be overridden here TODO document which ones


  var canOverrideThis = function canOverrideThis(args) {
    console.log('/_example/ -canOverrideThis', args);
  };

  return {
    init: init,
    canOverrideThis: canOverrideThis
  };
};
/**
 * Component scripts are registered with the core like this.
 * Ensure that the value of `name` is unique, and matches the `data-component` attribute
 * in `index.html` for this component
 */


window.app.add({
  name: '_example',
  // *** ensure unique
  script: script
});

/**
 * consent-revealer
 * finds all elements with the class 'consent-revealer' and adds a click event listener to radio buttons
 *  consenting sets a session cookie and hides the consent
 *  declining diverts user to a url - url is set in the data-component-props="redirect: 'https://www.google.com'">

 * @param {Object} props - TODO
 * @return {{init: init, foo: foo}}
 */
var script = function script(props) {
    // *** mandatory function - called by `AbstractComponent` on instantiation
    var subProps = {};
    var els = {
        el: null,
        wrapper: null,
        intro: null,
        content: null,
        consent: null,
        agree: null,
        disagree: null
    };
    var cookieSet = false;

    var init = function init() {
        console.log('/consent-revealer/ -init ', props);
        els.el = props.el;
        els.wrapper = els.el.querySelector(".consent-revealer--wrapper");
        els.intro = els.wrapper.querySelector(".consent-revealer--text");
        els.consent = els.wrapper.querySelector(".consent-revealer--cta");
        els.agree = els.consent.querySelector("input#agree");
        els.disagree = els.consent.querySelector("input#disagree");
        els.content = els.el.querySelector(".consent-revealer--content");
        props.attributes.redirect;
        checkACookieExists();
        addListeners();
    };

    var addListeners = function addListeners() {
        els.agree.addEventListener("click", function () {
            cookieSet = true;
            setSessionCookie();
            toggleReveal(cookieSet);
        });
        els.disagree.addEventListener("click", function () {// *** @as removed - SMIT-3578. no requirement to do anything with this action...
            // redirect(redirectUrl);
        });
    }; // set cookie function


    var setSessionCookie = function setSessionCookie() {
        document.cookie = "S&N-investor-consent=true";
    };

    var checkACookieExists = function checkACookieExists() {
        if (document.cookie.split(';').some(function (item) {
            return item.trim().startsWith('S&N-investor-consent=true');
        })) {
            cookieSet = true;
        }

        setTimeout(function () {
            toggleReveal(cookieSet);
        }, 100);
    }; // show hide consent function


    var toggleReveal = function toggleReveal(consent) {
        if (consent) {
            els.wrapper.classList.add("hide");
            els.content.classList.remove("hide");
            if (!subProps.tableScroller) {
                subProps.tableScroller = props.getBehaviour(props.el.querySelector('.table-scroller'));
            }
            let tables = [...els.content.querySelectorAll('table')];
            if (tables.length) {
                tables.map((table) => {
                    subProps.tableScroller.update(table.id);
                })
            } else {
                subProps.tableScroller.update();
            }
        } else {
            els.wrapper.classList.remove("hide");
            els.content.classList.add("hide");
        }
    };

    return {
        init: init
    };
};
/**
 * Component scripts are registered with the core like this.
 * Ensure that the value of `name` is unique, and matches the `data-component` attribute
 * in `index.html` for this component
 */


window.app.add({
    name: 'consent-revealer',
    script: script
});

function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; }

function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { _defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }

function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }

function _toConsumableArray(arr) { return _arrayWithoutHoles(arr) || _iterableToArray(arr) || _unsupportedIterableToArray(arr) || _nonIterableSpread(); }

function _nonIterableSpread() { throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }

function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }

function _iterableToArray(iter) { if (typeof Symbol !== "undefined" && Symbol.iterator in Object(iter)) return Array.from(iter); }

function _arrayWithoutHoles(arr) { if (Array.isArray(arr)) return _arrayLikeToArray(arr); }

function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; }

/**
 * Homepage tabs
 * API endpoint set in component, and html is injected into the tab content
 * behaviours need tobe reinitiatlised on load
 * @param {Object} props - TODO
 * @return {{init: init, foo: foo}}
 */
var script = function script(props) {
    var els = {
        el: null,
        navHeader: null,
        breadcrumbs: null,
        tabGroup: null,
        tabContent: null,
        content: null,
        viewportInner: null
    };
    var tabs,
        endpoint,
        tabGroupHeight,
        breadcrumbs,
        tabContentObjects = [];

    var init = function init() {
        // console.log('/homepage-tabs/ -init ', props);
        els.el = props.el;
        els.tabGroup = els.el.querySelector('.tab-group');
        els.navHeader = document.querySelector('header');
        els.breadcrumbs = document.querySelector('.breadcrumbs');
        els.viewportInner = document.querySelector('.viewport__inner');
        els.tabContent = document.querySelector('.tab-content-wrapper');
        tabs = els.el.querySelectorAll('.tab');
        endpoint = els.el.getAttribute('data-component-props');
        generateTabs() // only run once

        setUpTabs(); // can be re run on resize etc

        props.events.on(props.config.eventNames.APP_RESIZE_END, function (payload) {
            setUpTabs();
        });
    }; // *** @as refactored


    var generateTabs = function generateTabs() {
        var defaultIndex = 0; // *** tab index to arrive at

        var _tabs = _toConsumableArray(tabs); // *** cast to array


        var numTabs = _tabs.length;
        var numTabsReady = 0; // *** count tabs cooked

        _tabs.map(function (tab, index) {
            tab.addEventListener('click', function () {
                handleTabClick(tab);
            });
            var panel = document.createElement('div');
            panel.classList.add('tab-content--panel');
            panel.setAttribute('id', tab.getAttribute('id'));
            els.tabContent.append(panel);
            tabContentObjects.push({
                tabId: tab.getAttribute('id'),
                loaded: false
            }); //  store tab status

            loadFromApi(tab.getAttribute("id"), endpoint + tab.dataset.attributeUrl + "?sc_mode=normal", els.tabContent); // *** mutation observer - fires when content rendered from api call
            var observer = new MutationObserver(function (entries) {
                if (!!entries) {
                    observer.disconnect();

                    _toConsumableArray(panel.querySelectorAll('[data-behaviour]')).map(function (item) {
                        props.registerBehaviour(item); // *** initialise behaviour
                    });

                    handleTabClick(tab); // *** initialise tab : TODO visible tab switching on pageload, hide everything until done

                    numTabsReady += 1;

                    if (numTabsReady === numTabs) {
                        // *** now content rendered and behaviours init'd
                        handleTabClick(_tabs[defaultIndex]);
                    }
                }
            });
            observer.observe(panel, {
                subtree: true,
                childList: true
            });
        });
    };

    var setUpTabs = function setUpTabs() {
        // calc height of tabgroup and set position
        tabGroupHeight = outerHeight(els.tabGroup);
        outerHeight(els.navHeader);
        getPosition(els.tabContent);
        breadcrumbs = outerHeight(els.breadcrumbs);
        setTabGroupPosition(tabGroupHeight);
        setViewportHeight(breadcrumbs);
    };

    var setTabGroupPosition = function setTabGroupPosition(tabGroupHeight) {
        props.events.on(props.config.eventNames.APP_BREAKPOINT_READY, function (payload) {
            if (payload.breakpoint == 'mobile') {
                els.el.style = '';
            }

            if (payload.breakpoint == 'tablet-portrait') {
                els.el.style.bottom = tabGroupHeight + 16 + 'px'; // need to make this more dynamic

                els.el.style.marginBottom = '-' + parseInt(tabGroupHeight) + 'px'; // this fixes gap below tabs
            }

            if (payload.breakpoint == 'desktop' || payload.breakpoint == 'tablet-landscape') {
                els.el.style.bottom = tabGroupHeight + 20 + 'px'; // need to make this more dynamic

                els.el.style.marginBottom = '-' + parseInt(tabGroupHeight) + 'px'; // this fixes gap below tabs

                els.el.style.overflow = 'hidden';
            }
        });
    };

    var setViewportHeight = function setViewportHeight(breadcrumbs) {
        els.viewportInner.style.marginTop = '-' + 1.5 * breadcrumbs + 'px';
    };

    var getPosition = function getPosition(el) {
        return el.getBoundingClientRect().top;
    };

    var handleTabClick = function handleTabClick(clicked) {
        // console.log('/index/ -handleTabClick', clicked);
        // reset selected class
        Array.from(document.querySelectorAll('.tab')).forEach(function (el) {
            el.classList.remove('selected');
        });
        clicked.classList.add('selected');
        var id = clicked.getAttribute('id');
        showTabContent(id);
    };

    var showTabContent = function showTabContent(id) {
        // console.log('/index/ -showTabContent', id);
        var elems = document.querySelectorAll('.tab-content--panel');
        [].forEach.call(elems, function (el) {
            el.classList.remove('active');
        });
        els.tabContent.querySelector("#".concat(id)).classList.add('active'); // scrollTo(els.tabContent, tabContentPos, 500);
        // inject behaviour on first display
        //

        if (findObject(id).loaded == false || findObject(id).loaded == 'undefined') {
            // console.log('/index/ -showTabContent READY?'); // injectBehaviours(els.tabContent.querySelector(`#${id}`)); // only run once per load // TEST

            findObject(id).loaded = true;
        }

        props.events.emit(props.config.eventNames.APP_BREAKPOINT_READY, _objectSpread(_objectSpread({}, props.utils.mediaQueries.getValue()), {}, {
            isArtificialOrigin: true // *** subscriber can interpret this

        }));
    };

    var loadFromApi = function loadFromApi(id, endpoint, destination) {
        // console.log('/index/ -loadFromApi', id, endpoint);
        fetch(endpoint).then(function (response) {
            if (response.ok) {
                return response.text();
            }

            throw new Error('no tab URL found');
        }).then(function (text) {
            if (text != '') {
                destination.querySelector("#".concat(id)).innerHTML = text;
                if (endpoint.toLowerCase().includes('/tabs/education')) {
                    setTimeout(() => { inspectGenericButtonAction() }, 2000);
                }
                // lazy load images
                let lazyImageObserver = new IntersectionObserver(function (entries, observer) {
                    entries.forEach(function (entry) {
                        if (entry.isIntersecting) {
                            let lazyImage = entry.target;
                            if (lazyImage.dataset.src) {
                                lazyImage.src = lazyImage.dataset.src;
                            }
                            lazyImageObserver.unobserve(lazyImage);
                        }
                    });
                });
                var lazyImages = [...els.tabContent.querySelectorAll("img")];
                lazyImages.forEach(function (lazyImage) {
                    lazyImageObserver.observe(lazyImage);
                });

            }
        })["catch"](function (error) {
            // catch
            console.warn('Request failed', error);
        });
    }; //

    var inspectGenericButtonAction = function inspectGenericButtonAction() {
        var actions = [props.config.eventNames.LAUNCH_POPOVER, props.config.eventNames.CLOSE_POPOVER, 'FOLLOW_LINK', 'AWAIT_FETCH'];

        _toConsumableArray(document.body.querySelectorAll("[data-button-action]")).map(function (item) {
            var action = item.getAttribute('data-button-action');
            if (!action) return;
            var args = props.utils.attributeParser(action, null, 'json');
            var key = Object.keys(args)[0];
            if (!actions.includes(key)) return;
            item.addEventListener('click', function () {
                //console.log('/popover/ -button click:', key, args[key]);
                props.events.emit(key, {
                    args: args
                });
                if (item.dataset.exploreExternalPopup === 'true') {
                    const languageConfirmationYes = document.getElementById('language-confirmation-yes');
                    const confirmationPopupText = document.getElementById('confirmationPopupText');
                    if (confirmationPopupText && confirmationPopupText.value) {
                        languageConfirmationText.innerHTML = confirmationPopupText.value;
                    }
                    languageConfirmationYes.dataset.redirectionUrl = `${item.dataset.redirectionUrl}`;
                    languageConfirmationYes.dataset.exploreExternalPopup = `${item.dataset.exploreExternalPopup}`;
                }
            });
        });
    }; // *** manage item scripts if present


    var findObject = function findObject(id) {
        // find object in array
        return tabContentObjects.find(function (obj) {
            return obj.tabId == id;
        });
    };


    var outerHeight = function outerHeight(element) {
        // @ja bugfix:: return 0 if no element
        if (!element) return 0;
        var height = element.offsetHeight,
            style = window.getComputedStyle(element);
        return height + parseFloat(style.paddingTop) + parseFloat(style.paddingBottom) + parseFloat(style.borderBottom);
    };

    return {
        init: init
    };
};
/**
 * Component scripts are registered with the core like this.
 * Ensure that the value of `name` is unique, and matches the `data-component` attribute
 * in `index.html` for this component
 */

window.app.add({
    name: 'homepage-tabs',
    // *** ensure unique
    script: script
});

function _createForOfIteratorHelper(o, allowArrayLike) { var it; if (typeof Symbol === "undefined" || o[Symbol.iterator] == null) { if (Array.isArray(o) || (it = _unsupportedIterableToArray(o)) || allowArrayLike && o && typeof o.length === "number") { if (it) o = it; var i = 0; var F = function F() { }; return { s: F, n: function n() { if (i >= o.length) return { done: true }; return { done: false, value: o[i++] }; }, e: function e(_e) { throw _e; }, f: F }; } throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } var normalCompletion = true, didErr = false, err; return { s: function s() { it = o[Symbol.iterator](); }, n: function n() { var step = it.next(); normalCompletion = step.done; return step; }, e: function e(_e2) { didErr = true; err = _e2; }, f: function f() { try { if (!normalCompletion && it["return"] != null) it["return"](); } finally { if (didErr) throw err; } } }; }

function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }

function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; }

/**
 * 
 * @param {Object} props - TODO
 * @return {{init: init, foo: foo}}
 */
var script = function script(props) {
    var els = {
        el: null,
        select: null,
        cardstacks: [],
        selectOptions: {}
    }; // *** mandatory function - called by `AbstractComponent` on instantiation

    var init = function init() {
        console.log('/static-dd-module/ -init ', props);
        els.el = props.el;
        els.select = els.el.querySelector("select");
        els.cardstacks = els.el.querySelectorAll(".cardstack.makeDropdown");
        generateSelect(els.cardstacks);
        initDisplay(els.cardstacks);
    };

    var generateSelect = function generateSelect(cardstacks) {
        // generate select
        var _iterator = _createForOfIteratorHelper(cardstacks),
            _step;

        try {
            for (_iterator.s(); !(_step = _iterator.n()).done;) {
                var cardstack = _step.value;
                els.select.insertAdjacentHTML('beforeend', "<option value=\"".concat(cardstack.getAttribute("id"), "\">").concat(cardstack.dataset.selectnamegen, "</option>"));
            }
        } catch (err) {
            _iterator.e(err);
        } finally {
            _iterator.f();
        }

        els.select.firstElementChild.selected = true;
    };

    var initDisplay = function initDisplay(cardstacks) {
        els.cardstacks.item(0).classList.add("active");
        els.select.addEventListener("change", function (e) {
            var _iterator2 = _createForOfIteratorHelper(cardstacks),
                _step2;

            try {
                for (_iterator2.s(); !(_step2 = _iterator2.n()).done;) {
                    var cardstack = _step2.value;
                    cardstack.classList.remove("active");
                }
            } catch (err) {
                _iterator2.e(err);
            } finally {
                _iterator2.f();
            }

            els.el.querySelector("#".concat(e.target.value)).classList.add("active");
        });
    };

    return {
        init: init
    };
};
/**
 * Component scripts are registered with the core like this.
 * Ensure that the value of `name` is unique, and matches the `data-component` attribute
 * in `index.html` for this component
 */


window.app.add({
    name: 'static-dd-module',
    // *** ensure unique
    script: script
});

const MegaMenu = (props) => {
    const els = {};

    const classes = {
        main: 'header__mega-menu',
        isExpanded: 'header__mega-menu--is-expanded',
        inner: 'mega-menu__inner',
        item: 'mega-menu__item',
        itemIsActive: 'mega-menu__item--is-active',
    };

    const state = {
        items: [],
        isExpanded: false,
        currentIndex: null,
    };

    const init = () => {
        els.el = props.el.querySelector(`.${classes.main}`);
        els.inner = props.el.querySelector(`.${classes.inner}`);
        state.items = [...els.el.querySelectorAll(`.${classes.item}`)];
    };

    const update = (itemIndex) => {
        itemIndex = itemIndex - 1; // *** to avoid index: 0 in markup
        if (state.currentIndex === itemIndex) return;
        state.items.map((item, index) => {
            if (index === itemIndex) {
                showItem(item);
                state.currentIndex = itemIndex;
            } else {
                hideItem(item);
            }
        });
    };

    const expand = (item) => {
        let startHeight;
        let time;
        let easeType;
        if (state.isExpanded) {
            startHeight = els.inner.getBoundingClientRect().height;
            time = 0.25;
            easeType = 'power2.in';
        } else {
            startHeight = 0;
            time = props.config.timings.animation.medium() / 1.25;
            easeType = 'power2.out';
        }

        const height = item.getBoundingClientRect().height;

        props.TweenMax.set(els.inner, { height: startHeight, opacity: 1 });
        props.TweenMax.to(els.inner, time, {
            height: `${height}px`,
            opacity: 1,
            ease: easeType,
            onStart: () => {
                state.isExpanded = true;
                els.el.classList.add(classes.isExpanded);
            }
        });
    };

    const collapse = () => {
        const time = props.config.timings.animation.short();

        props.TweenMax.to(els.inner, time, {
            height: 0,
            opacity: 1,
            ease: 'power2.out',
            onStart: () => {
                state.isExpanded = false;
                els.inner.style.overflow = 'hidden';
                state.currentIndex = null;
            },
            onComplete: () => {
                els.el.classList.remove(classes.isExpanded);
            },
        });
    };

    const showItem = (item) => {
        const time = props.config.timings.animation.medium();
        const delay = props.config.timings.animation.short() / 2;
        const child = item.children[0];

        props.TweenMax.set(child, { opacity: 0, y: '-70px', scale: 1 });
        props.TweenMax.to(child, time, {
            opacity: 1,
            y: 0,
            ease: 'power1.out',
            delay,
            onStart: () => {
                item.classList.add(classes.itemIsActive);
                expand(item);
            },
        });
    };

    const hideItem = (item) => {
        const time = props.config.timings.animation.medium() / 1.25;
        const child = item.children[0];
        const delay = 0;

        props.TweenMax.to(child, time, {
            opacity: 0,
            y: '+40px',
            scale: 0.97,
            ease: 'power2.out',
            delay,
            onStart: () => { },
            onComplete: () => {
                item.classList.remove(classes.itemIsActive);
            },
        });
    };

    return {
        init,
        update,
        collapse,
    };
};

const SearchResults = (props) => {

    const els = {
        main: null,
        inner: null,

        mobileHeader: null,
    };

    const classes = {
        main: 'search-results',
        inner: 'search-results__inner',
        isActive: 'search-results--is-active',
        mobileHeader: 'mobile-header',
    };

    const state = {
        isMobile: false,
    };

    const init = () => {
        els.main = props.el.querySelector(`.${classes.main}`);
        els.inner = els.main.querySelector(`.${classes.inner}`);
        els.mobileHeader = props.el.querySelector(`.${classes.mobileHeader}`);

        props.events.on(props.config.eventNames.APP_BREAKPOINT_READY, (payload) => {
            state.isMobile = (payload.breakpoint === 'mobile');
        });
    };

    const update = () => {
        //console.log('/SearchResults/ -update');
    };

    const expand = () => {

        if (state.isMobile) {
            expandMobile();
            return;
        }

        // *** fixes some nasty scroll height issue, but need to tidy this up!
        const ref = props.el.querySelector('.search-panel__background-fill');
        const h = ref.getBoundingClientRect().height;
        const viewHeight = window.innerHeight - h;

        const time = props.config.timings.animation.long() / 2;
        const delay = props.config.timings.animation.long() / 1.5;

        props.TweenMax.set(els.main, { height: 0, opacity: 0, y: '-30px' });
        props.TweenMax.to(els.main, time, {
            height: `${viewHeight}px`,
            opacity: 1,
            y: 0,
            ease: 'Expo.inout',
            delay,
            onStart: () => {
                els.main.classList.add(classes.isActive);
                els.inner.scroll(0, 0);
            }
        });
    };

    const collapse = () => {

        if (state.isMobile) {
            collapseMobile();
            return;
        }

        const time = props.config.timings.animation.long() / 2.5;
        const delay = props.config.timings.animation.long() / 4;

        props.TweenMax.to(els.main, time, {
            height: 0,
            opacity: 0,
            y: '-20px',
            ease: 'Expo.out',
            delay,
            onStart: () => {
                els.main.classList.add(classes.isActive);
            }
        });
    };

    const expandMobile = () => {

        const offsetY = els.mobileHeader.getBoundingClientRect().height;
        const y = `-${offsetY * 2}px`;

        // *** fixes some nasty scroll height issue, but need to tidy this up!
        const ref1 = props.el.querySelector('.mobile-header');
        const ref2 = props.el.querySelector('.mobile__search-panel');
        const h = ref1.getBoundingClientRect().height + ref2.getBoundingClientRect().height;
        const viewHeight = window.innerHeight - h;

        const time = props.config.timings.animation.short();

        props.TweenMax.set(els.main, { height: `${viewHeight}px`, opacity: 1, y });
        props.TweenMax.to(els.main, time, {
            y: 0,
            ease: 'Expo.out',
            delay: 0,
            onStart: () => {
                els.main.classList.add(classes.isActive);
                els.inner.scroll(0, 0);
            }
        });
    };

    const collapseMobile = () => {

        const time = 0;

        props.TweenMax.to(els.main, time, {
            height: 0,
            opacity: 0,
            ease: 'Expo.out',
            delay: 0,
            onStart: () => { },
            onComplete: () => {
                els.main.classList.add(classes.isActive);
            }
        });
    };

    return {
        init,
        update,
        expand,
        collapse,
    }
};

const SearchRequest = (props) => {

    const els = {
        input: null,
        submitButton: null,
    };

    const classes = {
        submitButtonIsActive: 'search-panel__button-submit--is-active',
        inputIsBusy: 'search-panel__input--is-busy',
    };

    const state = {
        inputValueDefault: '',
        inputValueCurrent: '',
    };

    const subProps = {
        minLength: 3,
    };

    const init = (options) => {

        if (!props.attributes) {
            //console.warn('/SearchRequest/ -no search props provided!');
            return;
        }

        const { searchUrl, lang, queryKey } = props.attributes;
        const hasQuery = (searchUrl && lang && queryKey);
        if (!hasQuery) {
            //console.warn('/SearchRequest/ -query not declared on header, quitting');
            return;
        }

        els.input = options.input;
        els.submitButton = options.submitButton;

        els.input.addEventListener('keyup', (e) => {
            state.inputValueCurrent = e.target.value;
            toggleUi();
            if (e.keyCode !== 13) return;
            submit();
        });

        els.submitButton.addEventListener('click', (e) => {
            submit();
        });
    };

    const toggleUi = () => {
        if (state.inputValueCurrent.length >= subProps.minLength) {
            els.submitButton.classList.add(classes.submitButtonIsActive);
        } else {
            els.submitButton.classList.remove(classes.submitButtonIsActive);
        }
    };

    const clear = () => {
        state.inputValueCurrent = state.inputValueDefault;
        els.input.value = state.inputValueCurrent;
        toggleUi();
    };

    /**
     *
     * @param expression = optionally passed in from predictive search
     * @return {Promise<void>}
     */
    const submit = async (expression = null) => {

        //console.log('/SearchRequest/ -submit', expression);

        if (expression && expression.value) {
            state.inputValueCurrent = expression.value;
        }

        if (state.inputValueCurrent.length < subProps.minLength) return;
        const { searchUrl, lang, queryKey } = props.attributes;

        // analytics
        analytics.sendIt({ "event": "search_submitted", "search_term": state.inputValueCurrent});

        // *** local testing - i think Justin set up a dev/prod thing, will check but please test with this one
        // const query = `https://mc-00dafe5d-1d07-4fef-8351-590422-cd.azurewebsites.net${searchUrl}#${queryKey}=${state.inputValueCurrent}&lang=${lang}`;
        // *** production
        const query = `${searchUrl}?${queryKey}=${state.inputValueCurrent}&lang=${lang}`;
        window.location.href = query; // *** ~redirect
        els.input.classList.add(classes.inputIsBusy);
        clear();

        // *** API request version...
        /*const fetchOptions = {
          datasource: query,
          caller: props.name,
        };
      
        const data = await props.fetchData(fetchOptions);
        
        if (data.status === 'fail') {
          console.log('/SearchRequest/ -submit FAIL', data);
          els.input.value = data.payload;
        } else {
          console.log('/SearchRequest/ -submit OK', data);
          // *** now what?
        }*/
    };

    return {
        init,
        clear,
        submit,
    }
};

/**
 * example attribute blob on parent root:
 *     data-predictive-search='
 *      {"datasource": "https://uat-cd.smith-nephew.com/en/api/coveo/getcoveoautocompleteresult",
 *      "queryKey1": "SearchText={*}",
 *      "queryKey2": "SearchHub=mainSearch",
 *      "throttleMs": "333"}'
 *
 * TODO restrict special chars? handle empty string?
 * @param props
 * @param _els
 * @return {{init: init}}
 * @constructor
 */

const PredictiveSearch = (props, _els) => {

    let els = {};

    const classes = {
        panel: 'predictive-search-results',
        panelIsActive: 'predictive-search-results--is-active',
        inner: 'predictive-search-results__inner',
        item: 'predictive-search-results__item',
        itemLabel: 'predictive-search-results__item__label',
        itemLabelHighlight: 'predictive-search-results__item__label--highlight',
    };

    const state = {
        inputValue: '',
        panelIsActive: false,
        submitCallback: null,
        isMobile: false,
    };

    const subProps = {
        replaceChar: '{*}',
        submitDelayMs: 333, // *** pause before firing off to submit callback, feels like slightly better ux
        timer: null,
        throttleMs: 0,
        datasource: null,
        queryKey1: null,
        queryKey2: null,
    };

    /**
     *
     * @param submitCallback = fn to route user selection to submit (in SearchRequest.js)
     */
    const init = (submitCallback) => {

        els = _els;
        state.submitCallback = submitCallback; // *** from parent

        // console.log('/PredictiveSearch/ -init', props, els);

        // *** parse @data-predictive-search on parent root
        const attr = props.el.getAttribute('data-predictive-search');
        if (!attr) {
            //console.warn('/PredictiveSearch/ -init --please configure @data-predictive-search, quitting');
            return;
        }

        const parsedAttr = props.utils.attributeParser(attr, null, 'json');
        subProps.datasource = parsedAttr['datasource'] || null;
        subProps.queryKey1 = parsedAttr['queryKey1'] || null;
        subProps.queryKey2 = parsedAttr['queryKey2'] || null;
        subProps.throttleMs = parseInt(parsedAttr['throttleMs'] || 0, 10);
        // *** TODO more safety checks?

        scaffold();

        els.input.addEventListener('keyup', (e) => {
            if (validate()) {
                startTimer();
            }
        });

        props.events.on(props.config.eventNames.APP_BREAKPOINT_READY, (payload) => {
            state.isMobile = (payload.breakpoint === 'mobile');
        });

        document.body.addEventListener('click', (e) => {
            const isThis = e.target.classList.contains(classes.panel);
            if (!isThis) toggleExpand(false);
        });
    };


    const scaffold = () => {

        els.panel = props.el.querySelector(`.${classes.panel}`);

        // *** TODO remove duplicate inner

        const stub = document.createElement('div');
        stub.innerHTML = `<div class="${classes.inner}"></div>`;

        els.inner = stub.firstElementChild;
        els.panel.append(els.inner);
    };


    // *** add validation rules here if required
    const validate = () => {

        let isValid = true;
        state.inputValue = els.input.value;
        if (state.inputValue.length === 0) isValid = false;

        if (!isValid) {
            toggleExpand(false);
        }

        return isValid;
    };

    // *** throttle requests
    const startTimer = () => {
        clearTimeout(subProps.timer);
        subProps.timer = setTimeout(() => {
            dispatch();
        }, subProps.throttleMs);

    };

    // *** call api and handle response
    const dispatch = () => {

        const { datasource, queryKey1, queryKey2, replaceChar } = subProps;

        const formQuery = () => {
            return queryKey1.replace(replaceChar, state.inputValue);
        };

        const fetchOptions = {
            datasource: `${datasource}?${formQuery()}&${queryKey2}`,
            caller: props.name,
        };

        const call = async () => {
            const data = await props.fetchData(fetchOptions);
            if (data.status === 'fail') {
                //console.warn('/PredictiveSearch/ -submit FAIL', data);
                // toggleExpand(false);
            } else {
                update(data);
            }
        };
        call();
    };

    const update = (data) => {

        // *** clear items
        while (els.inner.lastChild) {
            els.inner.removeChild(els.inner.lastChild);
        }

        const results = data.payload.Result.completions;

        if (!results.length) {
            toggleExpand(false);
            return;
        }

        results.map((item) => {
            const itemEl = renderItemTemplate(item);
            els.inner.appendChild(itemEl);

            itemEl.addEventListener('click', () => {
                onItemSelected(item);
            });
        });

        toggleExpand(true);
    };

    const onItemSelected = (item) => {
        els.input.value = item.expression;

        // *** pause submission (for effect), allows user to see input field text reflect the suggestion they just clicked on
        setTimeout(() => {
            state.submitCallback({
                value: item.expression,
                origin: 'predictive-search',
            });
        }, subProps.submitDelayMs);

        toggleExpand(false);
    };

    const renderItemTemplate = (item) => {

        const getLabel = () => {

            let s1 = item.highlighted.match(/{(.*?)}/g) || []; // *** between {.}
            let s2 = item.highlighted.match(/\[(.*?)\]/g) || []; // *** between [.]
            let finalLabel = item.highlighted;
            // *** remove delimiters manually, ios safari doesn't support regex lookahead...
            if (s1[0]) {
                let markedUpLabel = s1[0].replaceAll('{', `<span class="${classes.itemLabelHighlight}">`).replace('}', `</span>`);
                finalLabel = finalLabel.replaceAll(s1[0], markedUpLabel);
            }
            if (s2[0]) {
                finalLabel = finalLabel.replaceAll('[', '');
                finalLabel = finalLabel.replaceAll(']', '');
            }

            if (s1[0]) {
                return finalLabel
            }
            return `<span class="${classes.itemLabelHighlight}">${item.expression}</span>`
        };

        const stub = document.createElement('div');
        const tmpl = `
      <div class="${classes.item}">
        <span class="sn-icon-search"></span>
        <div class="${classes.itemLabel}">
          ${getLabel()}
        </div>
      </div>
    `;

        stub.innerHTML = tmpl;
        return stub.firstElementChild;
    };

    const setPanelWidth = () => {
        if (state.isMobile) return;
        const rect = els.inputWrapper.getBoundingClientRect();
        els.panel.style.width = `${rect.width}px`;
    };

    const toggleExpand = (bool) => {
        const time = props.config.timings.animation.short();

        if (bool) {
            props.TweenMax.to(els.panel, time / 2, {
                opacity: 1,
                onStart: () => {
                    els.panel.classList.add(classes.panelIsActive);
                    setPanelWidth();
                }
            });
            return;
        }

        props.TweenMax.to(els.panel, time, {
            opacity: 0,
            onComplete: () => {
                els.panel.classList.remove(classes.panelIsActive);
            }
        });
    };

    return {
        init,
        toggleExpand,
    }
};

const SearchHead = (props) => {

    const els = {
        main: null,
        fill: null,
        searchButton: null,
        inputWrapper: null,
        input: null,
    };

    const classes = {
        parent: 'user-nav__search-panel',
        main: 'search-panel__inner',
        fill: 'search-panel__background-fill',
        searchButton: 'search-panel__button',
        searchButtonCloseState: 'search-panel__button--close-state',
        searchInputWrapper: 'search-panel__input-wrapper',
        isActive: 'user-nav__search-panel--is-active',
        preventScroll: 'scrolling--prevent',

        headerSearchIsActive: 'header--search-is-active', // *** for mobile header ui

        submitButton: 'search-panel__button-submit',

        // *** for calculations only
        globalNav: 'header__global-nav',
        breadcrumbs: 'breadcrumbs',
    };

    const state = {
        isExpanded: false,
        defaultHeight: null,
    };

    const components = {
        searchResults: null,
        searchRequest: null,
        predictiveSearch: null,
    };

    const init = () => {
        //console.log('/SearchHead/ -init', props);

        els.parent = props.el.querySelector(`.${classes.parent}`);
        els.main = props.el.querySelector(`.${classes.main}`);
        els.searchButton = props.el.querySelector(`.${classes.searchButton}`);
        els.inputWrapper = props.el.querySelector(`.${classes.searchInputWrapper}`);
        els.submitButton = props.el.querySelector(`.${classes.submitButton}`);
        els.input = els.inputWrapper.querySelector('input');

        els.fill = document.createElement('div');
        els.fill.classList.add(classes.fill);
        els.main.append(els.fill);

        components.searchResults = SearchResults(props);
        components.searchResults.init();

        components.searchRequest = SearchRequest(props);
        components.searchRequest.init({
            input: els.input,
            submitButton: els.submitButton,
        });

        components.predictiveSearch = PredictiveSearch(props, {
            input: els.input,
            inputWrapper: els.inputWrapper,
        });
        components.predictiveSearch.init(forceSubmit); // *** pass in callback to route user selection to fire request
    };

    const forceSubmit = (data) => {
        //console.log('/SearchHead/ -forceSubmit', data);
        components.searchRequest.submit(data);
    };

    /**
     *
     * @param action
     * @param callback - inform index.js of state change
     */
    const update = (action, callback) => {

        if (!state.isExpanded) {
            disableScrolling(true);
            expand();
            components.searchResults.expand();
            callback({ searchIsActive: true });

        } else {
            disableScrolling(false);
            collapse();
            components.searchResults.collapse();
            components.searchRequest.clear();
            components.predictiveSearch.toggleExpand(false);
            callback({ searchIsActive: false });
        }
    };

    const disableScrolling = (bool) => {
        if (bool) {
            document.body.classList.add(classes.preventScroll);
        } else {
            document.body.classList.remove(classes.preventScroll);
        }
    };

    /**
     * EXPAND
     */
    const expand = () => {

        const globalNavRect = props.el.querySelector(`.${classes.globalNav}`).getBoundingClientRect();
        const headerRect = props.el.getBoundingClientRect();

        // *** defense - breadcrumbs may not be present
        const breadcrumbsEl = props.el.querySelector(`.${classes.breadcrumbs}`);
        let breadcrumbsHeight = 0;
        if (breadcrumbsEl) breadcrumbsHeight = breadcrumbsEl.getBoundingClientRect().height;


        state.defaultHeight = els.main.getBoundingClientRect().height;

        const height = `${headerRect.height - breadcrumbsHeight}px`;
        const yOffset = `${-globalNavRect.height}px`;

        const totalTime = props.config.timings.animation.long() / 1.5;
        const time1 = totalTime / 1.25;
        const time2 = totalTime / 3;

        // *** setup
        props.TweenMax.set(els.fill, {
            transformOrigin: 'right top',
            skewX: 30,
            height: state.defaultHeight,
            y: 0,
        });

        // *** fill slide
        props.TweenMax.to(els.fill, time1, {
            width: '100%',
            height: `${height - 10}px`,
            ease: 'Back.inout',
            skewX: 0,
            onStart: () => {
                state.isExpanded = true; // *** set state
                els.parent.classList.add(classes.isActive);
                props.el.classList.add(classes.headerSearchIsActive);
                els.searchButton.style.pointerEvents = 'none';
            },
            onComplete: () => {
                els.searchButton.style.pointerEvents = 'all';
                els.searchButton.classList.add(classes.searchButtonCloseState);
            }
        });

        // *** fill y
        props.TweenMax.to(els.fill, time2, {
            height,
            y: yOffset,
            ease: 'Expo.inout',
            delay: time1,
        });

        // *** fadein input
        props.TweenMax.set(els.inputWrapper, { opacity: 0 });
        props.TweenMax.to(els.inputWrapper, time1, {
            opacity: 1,
            ease: 'Expo.out',
            delay: time1,
            onComplete: () => {
                els.input.focus();
            }
        });
    };

    /**
     * COLLAPSE
     */
    const collapse = () => {

        const totalTime = props.config.timings.animation.long() / 1.3;
        const time1 = totalTime / 1.25;

        // *** slide out fill
        props.TweenMax.set(els.fill, {
            transformOrigin: 'right top',
            skewX: 0,
        });
        props.TweenMax.to(els.fill, totalTime, {
            width: 0,
            skewX: 30,
            ease: 'Expo.in',
            onStart: () => {
                state.isExpanded = false; // *** set state
                els.parent.classList.remove(classes.isActive);
                props.el.classList.remove(classes.headerSearchIsActive);
                els.searchButton.classList.remove(classes.searchButtonCloseState);
                els.searchButton.style.pointerEvents = 'none';
            },
            onComplete: () => {
                els.searchButton.style.pointerEvents = 'all';
            }
        });

        // *** fade out input
        props.TweenMax.to(els.inputWrapper, time1 / 2, {
            opacity: 0,
            ease: 'Expo.out',
            delay: 0,
        });
    };

    return {
        init,
        update,
    }
};

const Mobile = (props) => {

    const els = {

        hamburgerButton: null,
        inner: null,

        input: null,
        submitButton: null,

        inputWrapper: null,
    };

    const components = {
        searchRequest: null,
        predictiveSearch: null,
    };

    const classes = {
        preventScroll: 'scrolling--prevent',
        inner: 'header__inner',
        hamburgerButton: 'mobile-header__hamburger-button',
        mobileMenuExpanded: 'header--mobile__is-expanded',

        input: 'mobile__search-panel__input',
        submitButton: 'mobile__search-panel__button-submit',

        inputWrapper: 'mobile__search-panel__input-wrapper',
    };

    const state = {
        isMobile: false,
        isMobileMenuExpanded: false,
    };

    const init = () => {

        props.events.on(props.config.eventNames.APP_BREAKPOINT_READY, (payload) => {
            state.isMobile = (payload.breakpoint === 'mobile');
        });

        els.inner = props.el.querySelector(`.${classes.inner}`);
        els.hamburgerButton = props.el.querySelector(`.${classes.hamburgerButton}`);

        els.input = props.el.querySelector(`.${classes.input}`);
        els.submitButton = props.el.querySelector(`.${classes.submitButton}`);

        els.inputWrapper = props.el.querySelector(`.${classes.inputWrapper}`);

        components.searchRequest = SearchRequest(props);
        components.searchRequest.init({
            input: els.input,
            submitButton: els.submitButton,
        });

        components.predictiveSearch = PredictiveSearch(props, {
            input: els.input,
            inputWrapper: els.inputWrapper,
        });
        components.predictiveSearch.init(forceSubmit); // *** pass in callback to route user selection to fire request

        els.hamburgerButton.addEventListener('click', (e) => {
            if (!state.isMobileMenuExpanded) {
                expand();
                disableScrolling(true);
            } else {
                collapse();
                disableScrolling(false);
                components.searchRequest.clear();
            }
        });
    };

    const forceSubmit = (data) => {
        //console.log('/Mobile/ -forceSubmit', data);
        components.searchRequest.submit(data);
    };

    const update = (action) => {
        if (!state.isMobile) return;
        if (action['searchIsActive']) {
            collapse();
            components.searchRequest.clear();
        }
    };

    const expand = () => {

        const time = props.config.timings.animation.medium() / 1.5;

        props.TweenMax.set(els.inner, { height: 0 });
        props.TweenMax.to(els.inner, time, {
            height: '100vh',
            ease: 'Expo.inout',
            onStart: () => {
                state.isMobileMenuExpanded = true;
                props.el.classList.add(classes.mobileMenuExpanded);
            },
            onComplete: () => {
                els.input.focus();
            }
        });
    };

    const collapse = () => {
        const time = props.config.timings.animation.medium() / 2;

        props.TweenMax.to(els.inner, time, {
            height: 0,
            ease: 'Expo.inout',
            onStart: () => { },
            onComplete: () => {
                state.isMobileMenuExpanded = false;
                props.el.classList.remove(classes.mobileMenuExpanded);
            }
        });
    };

    const disableScrolling = (bool) => {
        if (bool) {
            document.body.classList.add(classes.preventScroll);
        } else {
            document.body.classList.remove(classes.preventScroll);
        }
    };

    return {
        init,
        update,
    }

};

const LoginControl = (props) => {

    const classes = {
        loggedIn: 'user-nav__logged-in',
        expandButton: 'user-nav__profile-options-button',
        expandedView: 'user-nav__logged-in__options',
        expandedViewIsActive: 'user-nav__logged-in__options--is-expanded',
    };

    const els = {
        el: null,
        expandButton: null,
        expandButtonClone: null,
        expandedView: null,
    };

    const state = {
        isEnabled: false,
        isExpanded: false,
    };

    const init = () => {
        els.el = props.el.querySelector(`.${classes.loggedIn}`);

        if (!els.el) return; // *** user logged out, quit

        state.isEnabled = true;

        els.expandButton = els.el.querySelector(`.${classes.expandButton}`);
        els.expandedView = els.el.querySelector(`.${classes.expandedView}`);
        els.expandButtonClone = els.expandButton.cloneNode(true);
        els.expandButtonClone.classList.add(`${classes.expandButton}--clone`);

        els.expandedView.prepend(els.expandButtonClone);

        els.expandButton.addEventListener('click', () => {
            toggleExpand(true);
        });

        els.expandButtonClone.addEventListener('click', () => {
            toggleExpand(false);
        });
    };

    const toggleExpand = (bool) => {

        if (!state.isEnabled) return;

        const time = props.config.timings.animation.short();

        if (bool) {
            props.TweenMax.to(els.expandedView, time, {
                opacity: 1,
                onStart: () => {
                    els.expandedView.classList.add(classes.expandedViewIsActive);
                }
            });
            return;
        }

        props.TweenMax.to(els.expandedView, time / 2, {
            opacity: 0,
            onComplete: () => {
                els.expandedView.classList.remove(classes.expandedViewIsActive);
            }
        });
    };

    return {
        init,
        toggleExpand,
    }
};

function _toConsumableArray(arr) { return _arrayWithoutHoles(arr) || _iterableToArray(arr) || _unsupportedIterableToArray(arr) || _nonIterableSpread(); }

function _nonIterableSpread() { throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }

function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }

function _iterableToArray(iter) { if (typeof Symbol !== "undefined" && Symbol.iterator in Object(iter)) return Array.from(iter); }

function _arrayWithoutHoles(arr) { if (Array.isArray(arr)) return _arrayLikeToArray(arr); }

function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; }

var script = function script(props) {
    var els = {
        pillarNav: null,
        searchButton: null,
        mobileSearchButton: null
    };
    var components = {
        megaMenu: null,
        search: null,
        mobile: null,
        loginControl: null
    };
    var state = {
        pillarNavButtons: []
    };
    var classes = {
        pillarNavButton: 'pillar-nav__button',
        pillarNavButtonSelected: 'pillar-nav__button--selected',
        megaMenuItem: 'mega-menu__item',
        searchButton: 'search-panel__button',
        mobileSearchButton: 'mobile-header__search-panel__button',
        isInitialising: 'header--is-initialising',
        enableAnimationFlag: 'feature--header-animation',
        loginControlButton: 'user-nav__profile-options-button'
    };

    var init = function init() {
        // console.log('/header/ -init', props);
        components.megaMenu = MegaMenu(props);
        components.megaMenu.init();
        components.search = SearchHead(props);
        components.search.init();
        components.mobile = Mobile(props);
        components.mobile.init();
        components.loginControl = LoginControl(props);
        components.loginControl.init();
        props.events.on(props.config.eventNames.APP_BREAKPOINT_READY, function (payload) { }); // *** click off listener to close open items

        document.body.addEventListener('click', function (e) {
            var isPillarNav = e.target.classList.contains(classes.pillarNavButton);
            var isMegaMenuItem = e.target.classList.contains(classes.megaMenuItem);
            var isLoginControl = false;

            try {
                isLoginControl = e.target.parentNode.classList.contains(classes.loginControlButton);
            } catch (e) {// *** do nothing, catches strange misfire when clicking on accordion tab
            }

            if (!isPillarNav && !isMegaMenuItem && !isLoginControl) {
                collapseElements();
            }

            if (isPillarNav) components.loginControl.toggleExpand(false); // TODO slight overlap, might need to force a delay

            if (isLoginControl) {
                components.megaMenu.collapse();
                updatePillarNavSelection(0);
            }
        });
        window.addEventListener('scroll', function (e) {
            collapseElements();
        });

        var collapseElements = function collapseElements() {
            components.megaMenu.collapse();
            components.loginControl.toggleExpand(false);
            updatePillarNavSelection(0);
        }; // @as TODO close meganav on scroll


        initPillarNav();
        initSearchPanel(); // *** animation is enabled by inclusion of 'feature--header-animation' class on body
        initCorporatePageLink(); // open confirmation popup for corporate page link
        showCustomerPortalLink(); //Checking customer portal Link based on Cookie
        if (document.body.classList.contains(classes.enableAnimationFlag)) {
            tweenIn();
        } else {
            props.el.classList.remove(classes.isInitialising);
        }
    };

    var tweenIn = function tweenIn() {
        var time = props.config.timings.animation.longest() * 1.3;
        var predelay = time / 4;
        var inner = props.el.querySelector('.header__inner');

        var children = _toConsumableArray(inner.children).reverse();

        props.TweenMax.set(props.el, {
            y: '-150px'
        });
        props.TweenMax.to(props.el, time, {
            y: 0,
            opacity: 1,
            // ease: 'Sine.out',
            ease: 'expo.out',
            delay: 0
        });
        children.map(function (item, index) {
            props.TweenMax.set(item, {
                y: '+40px',
                opacity: 0
            });
            props.TweenMax.to(item, time / 1.5, {
                y: 0,
                opacity: 1,
                // ease: 'Sine.out',
                ease: 'expo.out',
                delay: predelay + index / 8
            });
        });
        props.el.classList.remove(classes.isInitialising);
    };

    var showCustomerPortalLink = function showCustomerPortalLink() {
        const cookieArr = document.cookie.split(';');
        const customerPortalLink = 'CustomerPortalUser='
        for (let i = 0; i < cookieArr.length; i++) {
            let cookieName = cookieArr[i];
            while (cookieName.charAt(0) == ' ') {
                cookieName = cookieName.substring(1);
            }
            if (cookieName.indexOf(customerPortalLink) !== -1 && cookieName.substring(customerPortalLink.length, cookieName.length) == 'true') {
                const customerPortalLinkEl = document.getElementById('customer-portal-link');
                if (customerPortalLinkEl) {
                    customerPortalLinkEl.style.display = 'flex'
                }
            }
        }
    }

    var initCorporatePageLink = function initCorporatePageLink() {
        const corporatePageLinks = [...document.querySelectorAll('[data-corporate-page-link="true"]')];
        corporatePageLinks.map((item) => {
            item.onclick = function () {
                props.events.emit('LAUNCH_POPOVER', {
                    args: {
                        "LAUNCH_POPOVER": 'language-confirmation',
                    },
                });
                const languageConfirmationYes = document.getElementById('language-confirmation-yes');
                const languageConfirmationText = document.getElementById('languageConfirmationText');
                const confirmationPopupText = document.getElementById('confirmationPopupText');
                if (item.dataset.languageConfirmationText) {
                    languageConfirmationText.innerHTML = `${item.dataset.languageConfirmationText}`
                } else if (confirmationPopupText && confirmationPopupText.value) {
                    languageConfirmationText.innerHTML = confirmationPopupText.value;
                }
                languageConfirmationYes.dataset.redirectionUrl = `${item.dataset.redirectionUrl}`;
                languageConfirmationYes.dataset.corporatePageLink = `${item.dataset.corporatePageLink}`;
            }
        })
    }

    var initPillarNav = function initPillarNav() {
        state.pillarNavButtons = _toConsumableArray(props.el.querySelectorAll(".".concat(classes.pillarNavButton)));
        state.pillarNavButtons.map(function (item, index) {
            item.addEventListener('click', function (e) {
                onSelection(item);
            });
        });

        var onSelection = function onSelection(target) {
            var action = props.utils.attributeParser(target.getAttribute('data-button-action'));
            components.megaMenu.update(action.index);
            updatePillarNavSelection(action.index);
        };
    }; // *** pass 0 to clear all


    var updatePillarNavSelection = function updatePillarNavSelection(index) {
        // console.log('/index/ -updatePillarNavSelection', index);
        state.pillarNavButtons.map(function (item, itemIndex) {
            if (itemIndex === index - 1) {
                item.classList.add(classes.pillarNavButtonSelected);
            } else {
                item.classList.remove(classes.pillarNavButtonSelected);
            }
        });
    };

    var initSearchPanel = function initSearchPanel() {
        els.searchButton = props.el.querySelector(".".concat(classes.searchButton));
        els.mobileSearchButton = props.el.querySelector(".".concat(classes.mobileSearchButton)); // *** desktop

        els.searchButton.addEventListener('click', function (e) {
            var action = props.utils.attributeParser(e.currentTarget.getAttribute('data-button-action'));
            components.search.update(action, function (state) {
                analyticsHandler(state);
            });
        }); // *** mobile

        els.mobileSearchButton.addEventListener('click', function (e) {
            var action = props.utils.attributeParser(e.currentTarget.getAttribute('data-button-action'));
            components.search.update(action, function (args) {
                components.mobile.update(args); // *** will cause mobile nav to close if currently open

                analyticsHandler(args);
            });
        });
    }; // here for now


    var analyticsHandler = function analyticsHandler(state) {
        if (state.searchIsActive) {
            analytics.sendIt({
                "event": "search_started"
            });
        } else {
            analytics.sendIt({
                "event": "closeSearch",
                "searchLocation": 'topNavigation'
            });
        }
    };

    return {
        init: init
    };
};

window.app.add({
    name: 'header_4348986efc58',
    // *** ensure unique
    script: script
});

function _toConsumableArray(arr) { return _arrayWithoutHoles(arr) || _iterableToArray(arr) || _unsupportedIterableToArray(arr) || _nonIterableSpread(); }

function _nonIterableSpread() { throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }

function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }

function _iterableToArray(iter) { if (typeof Symbol !== "undefined" && Symbol.iterator in Object(iter)) return Array.from(iter); }

function _arrayWithoutHoles(arr) { if (Array.isArray(arr)) return _arrayLikeToArray(arr); }

function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; }

function asyncGeneratorStep(gen, resolve, reject, _next, _throw, key, arg) { try { var info = gen[key](arg); var value = info.value; } catch (error) { reject(error); return; } if (info.done) { resolve(value); } else { Promise.resolve(value).then(_next, _throw); } }

function _asyncToGenerator(fn) { return function () { var self = this, args = arguments; return new Promise(function (resolve, reject) { var gen = fn.apply(self, args); function _next(value) { asyncGeneratorStep(gen, resolve, reject, _next, _throw, "next", value); } function _throw(err) { asyncGeneratorStep(gen, resolve, reject, _next, _throw, "throw", err); } _next(undefined); }); }; }

var script = function script(props) {
  var els = {
    el: null,
    textBlock: null,
    cardstack: null,
    spinner: null
  };
  var state = {
    currentApiId: null
  };
  var subProps = {
    paginator: null
  };

  var init = function init() {
    els.el = props.el;
    els.textBlock = els.el.querySelector('.text-block');
    els.cardstack = els.el.querySelector('.cardstack');
    els.spinner = document.createElement('div');
    els.spinner.classList.add('spinner');
    els.spinner.classList.add('ellipsis-spinner');
    els.el.insertBefore(els.spinner, els.cardstack); // *** from hero dropdown

    props.events.on(props.config.eventNames.HERO_DROPDOWN_SELECTION, function (payload) {
      state.currentApiId = payload.selection.id;
      getData({
        id: state.currentApiId,
        pageNumber: 1
      });
      updateTextBlock(payload.selection);
    }); // from paginator

    props.events.on('BEHAVIOUR_BINDING_SIGNAL', function (payload) {
      if (payload.sender !== subProps.paginator.getOptions().config.uid) return;
      getData({
        id: state.currentApiId,
        pageNumber: payload.data.pageNumber
      });
    }); // *** for spinner

    props.events.on(props.config.eventNames.APP_NETWORK_ACTIVITY, function (payload) {
      if (payload.caller !== props.name) return;

      switch (payload.state) {
        case 'start':
          els.spinner.classList.add('spinner--is-active');
          break;

        case 'end':
          els.spinner.classList.remove('spinner--is-active');
          break;
      }
    });
  }; // *** called on event change


  var getData = function getData(options) {
    var fetchOptions = {
      datasource: "".concat(props.attributes.datasource),
      caller: props.name
    }; // *** base request for new API schema, update 'PageNumber' dynamically

    var requestParams = props.requestModel.format({
      Key: props.attributes.key,
      Values: options.id,
      Paginate: props.attributes.paginate,
      PageSize: props.attributes.pageSize,
      PageNumber: options.pageNumber
    }); // *** make api call, and generate content via frontend/alchemy-templates.js

    var fetchData = /*#__PURE__*/function () {
      var _ref = _asyncToGenerator( /*#__PURE__*/regeneratorRuntime.mark(function _callee() {
        var data;
        return regeneratorRuntime.wrap(function _callee$(_context) {
          while (1) {
            switch (_context.prev = _context.next) {
              case 0:
                _context.next = 2;
                return props.fetchData(fetchOptions, requestParams);

              case 2:
                data = _context.sent;
                updateList(data.payload.Result, props.attributes.template);
                updatePaginator(data.payload);

              case 5:
              case "end":
                return _context.stop();
            }
          }
        }, _callee);
      }));

      return function fetchData() {
        return _ref.apply(this, arguments);
      };
    }();

    if (props.attributes.datasource) {
      fetchData();
    }
  };

  var updatePaginator = function updatePaginator(data) {
    if (!subProps.paginator) {
      subProps.paginator = props.getBehaviour(props.el.querySelector('.paginator'));
    }

    subProps.paginator.update(data, state.currentApiId);
  };

  var updateTextBlock = function updateTextBlock(data) {
    // console.log('/index/ -updateTextBlock', data);
    var time = props.config.timings.animation["short"](); // *** fade out and update content

    props.TweenMax.to(els.textBlock, time, {
      opacity: 0,
      onComplete: function onComplete() {
        els.textBlock.innerHTML = "\n          <h2>".concat(data.title || '', "</h2>\n          <div class=\"paragraphs\">\n            <p>").concat(data.description || '', "</p>\n          </div>\n      ");
      }
    }); // *** fade back in

    props.TweenMax.to(els.textBlock, time, {
      opacity: 1,
      delay: time,
      onStart: function onStart() {
        props.el.scrollIntoView();
      }
    });
  };

  var updateList = function updateList(data, template) {
    console.log('/index/ -update', data);
    var jsonMap = props.utils.attributeParser(props.el.getAttribute('data-json-mapping'));
    var nodes = data.map(function (item) {
      return window.alchemyTemplates.getTemplate({
        type: template || '',
        map: jsonMap,
        parent: props.el
      }, item);
    });
    var time = props.config.timings.animation["short"](); // *** fade out container

    props.TweenMax.to(els.cardstack, time, {
      opacity: 0,
      onComplete: function onComplete() {
        // *** destroy
        _toConsumableArray(els.cardstack.children).map(function (item) {
          item.remove();
        }); // *** create


        nodes.map(function (item) {
          els.cardstack.append(item);
        });
      }
    }); // *** fade in container

    props.TweenMax.to(els.cardstack, time, {
      opacity: 1,
      delay: time,
      onStart: function onStart() {
        props.el.scrollIntoView();
      }
    });
  };

  return {
    init: init
  };
};

window.app.add({
  name: 'treatmentOptionsBody_a2df88c3d3ae',
  // *** ensure unique
  script: script
});

function _toConsumableArray(arr) { return _arrayWithoutHoles(arr) || _iterableToArray(arr) || _unsupportedIterableToArray(arr) || _nonIterableSpread(); }

function _nonIterableSpread() { throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }

function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }

function _iterableToArray(iter) { if (typeof Symbol !== "undefined" && Symbol.iterator in Object(iter)) return Array.from(iter); }

function _arrayWithoutHoles(arr) { if (Array.isArray(arr)) return _arrayLikeToArray(arr); }

function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; }

function asyncGeneratorStep(gen, resolve, reject, _next, _throw, key, arg) { try { var info = gen[key](arg); var value = info.value; } catch (error) { reject(error); return; } if (info.done) { resolve(value); } else { Promise.resolve(value).then(_next, _throw); } }

function _asyncToGenerator(fn) { return function () { var self = this, args = arguments; return new Promise(function (resolve, reject) { var gen = fn.apply(self, args); function _next(value) { asyncGeneratorStep(gen, resolve, reject, _next, _throw, "next", value); } function _throw(err) { asyncGeneratorStep(gen, resolve, reject, _next, _throw, "throw", err); } _next(undefined); }); }; }

var script = function script(props) {
  var els = {
    el: null,
    textBlock: null,
    cardstack: null,
    spinner: null
  };
  var state = {
    currentApiId: null
  };
  var subProps = {
    paginator: null
  };

  var init = function init() {
    els.el = props.el;
    els.textBlock = els.el.querySelector('.text-block');
    els.cardstack = els.el.querySelector('.cardstack');
    els.spinner = document.createElement('div');
    els.spinner.classList.add('spinner');
    els.spinner.classList.add('ellipsis-spinner');
    els.el.insertBefore(els.spinner, els.cardstack);
    console.log('*** /index/ -init HCP', props.name);
    props.events.on(props.config.eventNames.HERO_DROPDOWN_SELECTION, function (payload) {
      console.log('/index/ -HERO_DROPDOWN_SELECTION', payload);
      state.currentApiId = payload.selection.id;
      getData({
        id: payload.selection.id
      });
      updateTextBlock(payload.selection);
    }); // from paginator

    props.events.on('BEHAVIOUR_BINDING_SIGNAL', function (payload) {
      if (payload.sender !== subProps.paginator.getOptions().config.uid) return;
      getData({
        id: state.currentApiId,
        pageNumber: payload.data.pageNumber
      });
    });
    props.events.on(props.config.eventNames.APP_NETWORK_ACTIVITY, function (payload) {
      if (payload.caller !== props.name) return;

      switch (payload.state) {
        case 'start':
          els.spinner.classList.add('spinner--is-active');
          break;

        case 'end':
          els.spinner.classList.remove('spinner--is-active');
          break;
      }
    });
  };

  var getData = function getData(options) {
    var fetchOptions = {
      datasource: "".concat(props.attributes.datasource),
      caller: props.name
    }; // *** base request for new API schema, update 'PageNumber' dynamically

    var requestParams = props.requestModel.format({
      Key: props.attributes.key,
      Values: options.id,
      Paginate: props.attributes.paginate,
      PageSize: props.attributes.pageSize,
      PageNumber: options.pageNumber
    }); // *** make api call, and generate content via frontend/alchemy-templates.js

    var fetchData = /*#__PURE__*/function () {
      var _ref = _asyncToGenerator( /*#__PURE__*/regeneratorRuntime.mark(function _callee() {
        var data;
        return regeneratorRuntime.wrap(function _callee$(_context) {
          while (1) {
            switch (_context.prev = _context.next) {
              case 0:
                _context.next = 2;
                return props.fetchData(fetchOptions, requestParams);

              case 2:
                data = _context.sent;
                updateList(data.payload.Result, props.attributes.template);
                updatePaginator(data.payload);

              case 5:
              case "end":
                return _context.stop();
            }
          }
        }, _callee);
      }));

      return function fetchData() {
        return _ref.apply(this, arguments);
      };
    }();

    if (props.attributes.datasource) {
      fetchData();
    }
  };

  var updatePaginator = function updatePaginator(data) {
    if (!subProps.paginator) {
      subProps.paginator = props.getBehaviour(props.el.querySelector('.paginator'));
    }

    subProps.paginator.update(data, state.currentApiId);
  };

  var updateTextBlock = function updateTextBlock(data) {
    console.log('/index/ -updateTextBlock', data);
    var time = props.config.timings.animation["short"](); // *** fade out and update content

    props.TweenMax.to(els.textBlock, time, {
      opacity: 0,
      onComplete: function onComplete() {
        els.textBlock.innerHTML = "\n          <h2>".concat(data.title || '', "</h2>\n          <div class=\"paragraphs\">\n            <p>").concat(data.description || '', "</p>\n          </div>\n      ");
      }
    }); // *** fade back in

    props.TweenMax.to(els.textBlock, time, {
      opacity: 1,
      delay: time,
      onStart: function onStart() {
        props.el.scrollIntoView();
      }
    });
  };

  var updateList = function updateList(data, template) {
    console.log('/index/ -update', data);
    var jsonMap = props.utils.attributeParser(props.el.getAttribute('data-json-mapping'));
    var nodes = data.map(function (item) {
      return window.alchemyTemplates.getTemplate({
        type: template || '',
        map: jsonMap,
        parent: props.el
      }, item);
    });
    var time = props.config.timings.animation["short"](); // *** fade out container

    props.TweenMax.to(els.cardstack, time, {
      opacity: 0,
      onComplete: function onComplete() {
        // *** destroy
        _toConsumableArray(els.cardstack.children).map(function (item) {
          item.remove();
        }); // *** create


        nodes.map(function (item) {
          els.cardstack.append(item);
        });
      }
    }); // *** fade in container

    props.TweenMax.to(els.cardstack, time, {
      opacity: 1,
      delay: time,
      onStart: function onStart() {
        props.el.scrollIntoView();
      }
    });
  };

  return {
    init: init
  };
};

window.app.add({
  name: 'treatmentOptionsBody_de326844dbbd',
  // *** ensure unique
  script: script
});

function _toConsumableArray(arr) { return _arrayWithoutHoles(arr) || _iterableToArray(arr) || _unsupportedIterableToArray(arr) || _nonIterableSpread(); }

function _nonIterableSpread() { throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }

function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }

function _iterableToArray(iter) { if (typeof Symbol !== "undefined" && Symbol.iterator in Object(iter)) return Array.from(iter); }

function _arrayWithoutHoles(arr) { if (Array.isArray(arr)) return _arrayLikeToArray(arr); }

function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; }

var script = function script(props) {
    var state = {
        showText: 'Show videos',
        hideText: 'Hide videos',
        accordionOpen: true,
        thumbsInitialised: false,
        classes: {
            accordionLabel: '.accordion__tab',
            accordionText: '.accordion__tab-label',
            thumb: '.image-wrapper--video',
            active: 'image-wrapper--active',
            accordionCheckbox: '#video-carousel-1',
            player: 'videoplayer',
            inner: 'videoplayer__inner',
            errorMessage: 'videoplayer__error-message',
            hasError: 'videoplayer--has-error'
        },
        autoOpenAccordion: true
    };
    var els = {
        el: null,
        thumbs: null,
        carousel: null,
        accordionLabel: null,
        accordionText: null,
        accordionCheckbox: null
    };

    var init = function init() {
        els.el = props.el;
        els.accordionLabel = els.el.querySelector(state.classes.accordionLabel);
        els.accordionText = els.el.querySelector(state.classes.accordionText);
        els.carousel = els.el.querySelector('.carousel'); // *** automate accordion expansion

        els.accordionCheckbox = els.el.querySelector(state.classes.accordionCheckbox);
        els.accordionCheckbox.setAttribute('checked', 'yes');
        var text = state.accordionOpen ? state.hideText : state.showText;
        els.accordionText.innerHTML = "<h5>".concat(text, "</h5>");
        els.accordionText.addEventListener('click', function () {
            toggleExpand();
        }, false);

        var toggleExpand = function toggleExpand() {
            console.log('/index/ -toggleExpand');
            state.accordionOpen = !state.accordionOpen;
            var text = state.accordionOpen ? state.hideText : state.showText;
            els.accordionText.innerHTML = "<h5>".concat(text, "</h5>");
        }; // *** use select control events to update carousel


        props.events.on('BEHAVIOUR_BINDING_SIGNAL', function (payload) {
            var carouselUID = els.carousel.getAttribute('data-behaviour-uid');
            if (payload.sender !== carouselUID) return;
            if (payload.type === 'CAROUSEL_UPDATING') primeThumbs();
        });
        addErrorMessage();
    };
    /**
     * @as NOTE prob should add this as a decorator elsewhere
     * controller (such as this file) is responsible for rendering error message
     * in response to `videoplayer--has-error` class which is added by video behaviours
     */


    var addErrorMessage = function addErrorMessage() {
        if (!props.attributes || !props.attributes.errorMessage) {
            // console.warn('/index/ -addErrorMessage NO ERROR DEFINED');
            return;
        } // *** observe when new video is triggered


        var observer = new MutationObserver(function (entries) {
            if (!!entries) {
                var nodes = _toConsumableArray(entries[0].addedNodes);

                if (nodes[0] && nodes[0].nodeName.toLowerCase() === 'div') {
                    if (nodes[0].classList.contains("".concat(state.classes.player))) {
                        exec();
                    }
                }
            }
        });
        observer.observe(els.el, {
            subtree: true,
            childList: true
        }); // *** add markup, consumes props.attributes.errorMessage, e.g. data-component-props="errorMessage: We couldn't play that video"

        var exec = function exec() {
            els.inner = els.el.querySelector(".".concat(state.classes.inner));
            if (els.inner.querySelector(".".concat(state.classes.errorMessage))) return;
            var stub = document.createElement('div');
            var message = document.createElement('p');
            stub.classList.add("".concat(state.classes.errorMessage));
            message.innerText = props.attributes.errorMessage;
            stub.appendChild(message);
            els.inner.appendChild(stub);
        };
    };

    var removeBorders = function removeBorders() {
        els.thumbs.map(function (item) {
            item.classList.remove(state.classes.active);
        });
    };

    var primeThumbs = function primeThumbs() {
        if (state.thumbsInitialised) return;
        state.thumbsInitialised = true;
        els.thumbs = _toConsumableArray(els.el.querySelectorAll(state.classes.thumb));
        els.thumbs[0].classList.add(state.classes.active);
        els.thumbs.map(function (item) {
            item.addEventListener('click', function (e) {
                e.preventDefault();
                removeBorders();
                item.classList.add(state.classes.active);
            });
        });
    };

    return {
        init: init
    };
};

window.app.add({
    name: 'videoCarousel',
    // *** ensure unique
    script: script
});

var script = function script(props) {
    var state = {
        tabIndex: 0
    };
    var els = {
        el: null,
        tabstack: 0
    };

    var init = function init() {
        els.el = props.el;
        els.tabstack = els.el.querySelector('.tabstack');
        props.events.on('BEHAVIOUR_BINDING_SIGNAL', function (payload) {
            var tabstackUID = els.tabstack.getAttribute('data-behaviour-uid');
            if (payload.sender !== tabstackUID) return;

            if (payload.type === 'TABSWITCHER_UPDATING') {
                if (state.tabIndex != payload.data.index) {
                    props.events.emit(props.config.eventNames.PAUSE_OTHER_VIDEOS, {
                        player: 999 // nb set out of range to ignore

                    });
                    state.tabIndex = payload.data.index;
                }
            }
        });
    };

    return {
        init: init
    };
};

window.app.add({
    name: 'videoTabs',
    script: script
});

function _toConsumableArray(arr) { return _arrayWithoutHoles(arr) || _iterableToArray(arr) || _unsupportedIterableToArray(arr) || _nonIterableSpread(); }

function _nonIterableSpread() { throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }

function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }

function _iterableToArray(iter) { if (typeof Symbol !== "undefined" && Symbol.iterator in Object(iter)) return Array.from(iter); }

function _arrayWithoutHoles(arr) { if (Array.isArray(arr)) return _arrayLikeToArray(arr); }

function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; }

function asyncGeneratorStep(gen, resolve, reject, _next, _throw, key, arg) { try { var info = gen[key](arg); var value = info.value; } catch (error) { reject(error); return; } if (info.done) { resolve(value); } else { Promise.resolve(value).then(_next, _throw); } }

function _asyncToGenerator(fn) { return function () { var self = this, args = arguments; return new Promise(function (resolve, reject) { var gen = fn.apply(self, args); function _next(value) { asyncGeneratorStep(gen, resolve, reject, _next, _throw, "next", value); } function _throw(err) { asyncGeneratorStep(gen, resolve, reject, _next, _throw, "throw", err); } _next(undefined); }); }; }

var script = function script(props) {
  var init = function init() {
    // *** make api call, and generate content via frontend/alchemy-templates.js
    var fetchData = /*#__PURE__*/function () {
      var _ref = _asyncToGenerator( /*#__PURE__*/regeneratorRuntime.mark(function _callee() {
        var data;
        return regeneratorRuntime.wrap(function _callee$(_context) {
          while (1) {
            switch (_context.prev = _context.next) {
              case 0:
                _context.next = 2;
                return props.fetchData(props.attributes);

              case 2:
                data = _context.sent;
                parseData(data.payload.Result, props.attributes);

              case 4:
              case "end":
                return _context.stop();
            }
          }
        }, _callee);
      }));

      return function fetchData() {
        return _ref.apply(this, arguments);
      };
    }();

    if (props.attributes.datasource) {
      fetchData();
    }
  };

  var parseData = function parseData(data, options) {
    var jsonMap = props.utils.attributeParser(props.el.getAttribute('data-json-mapping'));
    var criteria = []; // *** in this case we are splitting data into chunks relative to unique 'RoleId' sets

    data.map(function (item) {
      item[options.key].map(function (id) {
        criteria.push(id);
        return true;
      });
    });
    criteria = _toConsumableArray(new Set(criteria)); // *** unique values only
    // *** chunk data by criteria

    var chunks = criteria.map(function (value) {
      return data.filter(function (item) {
        return item[options.key].includes(value);
      });
    }); // *** build nodes from data

    var nodes = chunks.map(function (chunk) {
      return chunk.map(function (item) {
        return window.alchemyTemplates.getTemplate({
          type: props.attributes.template || '',
          map: jsonMap,
          parent: props.el
        }, item);
      });
    });

    var getLabel = function getLabel(criteria) {
      var values = options.values.filter(function (item) {
        return item[0] === criteria;
      });

      if (values.length > 0) {
        return values[0][1];
      }

      return '...';
    }; // *** wrap output object and return


    var result = nodes.map(function (item, index) {
      return {
        label: getLabel(criteria[index]),
        nodes: nodes[index]
      };
    });
    build(result);
  }; // *** populate behaviours with generated content from api data


  var build = function build(nodes) {
    var defaultIndex = 0; // check if we actually have any nodes...

    var hasNoResults = nodes.length === 0; // if we have nothing dont proceed./

    if (hasNoResults) {
      showNoResults();
      return;
    } else {
      props.el.classList.remove('tabstack--noresults');
    } // *** data to populate tabswitcher and select


    var getTabButtons = function getTabButtons() {
      return nodes.map(function (item) {
        return {
          label: item.label
        };
      });
    }; // *** TABSWITCHER


    var tabSwitcher = props.getBehaviour(props.el.querySelector('.tab-switcher-control'));
    tabSwitcher.inject(getTabButtons(), defaultIndex); // ...
    // *** SELECT

    var selectControl = props.getBehaviour(props.el.querySelector('.select-control'));
    selectControl.inject(getTabButtons(), defaultIndex); // ...
    // *** TABSTACK

    var tabstackEl = props.el.querySelector('.tabstack');
    var tabStack = props.getBehaviour(tabstackEl);
    tabStack.inject(nodes, defaultIndex); // *** @as - a little untidy, but this method is new, should improve the above to use the output of this method
    // *** @as removed (SMIT-2688), reverting to default behaviour (non scrollfader)
    // const tabstackOptions = props.getBehaviourRaw(tabstackEl).options;
    // tabstackOptions.state.selfAnimate = false; // *** causes this tabstack to rely on scrollfader to animate cards
    // ...
    // *** CAROUSEL

    var carousel = props.getBehaviour(props.el.querySelector('.carousel'));

    var updateCarousel = function updateCarousel(index) {
      var data = nodes[index].nodes.map(function (item) {
        return item.cloneNode(true); // *** clone node to use again, otherwise it will be removed from tabstack
      });
      carousel.inject(data);
    }; // *** use select control events to update carousel


    props.events.on('BEHAVIOUR_BINDING_SIGNAL', function (payload) {
      if (payload.sender !== selectControl.getOptions().config.uid) return;
      updateCarousel(payload.data.index);
    });
    updateCarousel(defaultIndex);
  };

  var showNoResults = function showNoResults() {
    // const tabContainer = props.el.querySelector('.tabstack');
    // if nothing comes back from api lets append a message to tell user
    var noResultsDiv = document.createElement('div');
    var resultsText = props.attributes.noresult ? props.attributes.noresult : '';
    noResultsDiv.classList.add('tabstack__no-results');
    noResultsDiv.innerText = resultsText;
    props.el.appendChild(noResultsDiv); // hide anything we dont need with csss, like selects, etc

    props.el.classList.add('tabstack--noresults');
  };

  return {
    init: init
  };
};

window.app.add({
  name: 'adaptiveDynamicTabstack',
  // *** ensure unique
  script: script
});

/*! jQuery v3.7.1 | (c) OpenJS Foundation and other contributors | jquery.org/license */
!function (e, t) { "use strict"; "object" == typeof module && "object" == typeof module.exports ? module.exports = e.document ? t(e, !0) : function (e) { if (!e.document) throw new Error("jQuery requires a window with a document"); return t(e) } : t(e) }("undefined" != typeof window ? window : this, function (ie, e) { "use strict"; var oe = [], r = Object.getPrototypeOf, ae = oe.slice, g = oe.flat ? function (e) { return oe.flat.call(e) } : function (e) { return oe.concat.apply([], e) }, s = oe.push, se = oe.indexOf, n = {}, i = n.toString, ue = n.hasOwnProperty, o = ue.toString, a = o.call(Object), le = {}, v = function (e) { return "function" == typeof e && "number" != typeof e.nodeType && "function" != typeof e.item }, y = function (e) { return null != e && e === e.window }, C = ie.document, u = { type: !0, src: !0, nonce: !0, noModule: !0 }; function m(e, t, n) { var r, i, o = (n = n || C).createElement("script"); if (o.text = e, t) for (r in u) (i = t[r] || t.getAttribute && t.getAttribute(r)) && o.setAttribute(r, i); n.head.appendChild(o).parentNode.removeChild(o) } function x(e) { return null == e ? e + "" : "object" == typeof e || "function" == typeof e ? n[i.call(e)] || "object" : typeof e } var t = "3.7.1", l = /HTML$/i, ce = function (e, t) { return new ce.fn.init(e, t) }; function c(e) { var t = !!e && "length" in e && e.length, n = x(e); return !v(e) && !y(e) && ("array" === n || 0 === t || "number" == typeof t && 0 < t && t - 1 in e) } function fe(e, t) { return e.nodeName && e.nodeName.toLowerCase() === t.toLowerCase() } ce.fn = ce.prototype = { jquery: t, constructor: ce, length: 0, toArray: function () { return ae.call(this) }, get: function (e) { return null == e ? ae.call(this) : e < 0 ? this[e + this.length] : this[e] }, pushStack: function (e) { var t = ce.merge(this.constructor(), e); return t.prevObject = this, t }, each: function (e) { return ce.each(this, e) }, map: function (n) { return this.pushStack(ce.map(this, function (e, t) { return n.call(e, t, e) })) }, slice: function () { return this.pushStack(ae.apply(this, arguments)) }, first: function () { return this.eq(0) }, last: function () { return this.eq(-1) }, even: function () { return this.pushStack(ce.grep(this, function (e, t) { return (t + 1) % 2 })) }, odd: function () { return this.pushStack(ce.grep(this, function (e, t) { return t % 2 })) }, eq: function (e) { var t = this.length, n = +e + (e < 0 ? t : 0); return this.pushStack(0 <= n && n < t ? [this[n]] : []) }, end: function () { return this.prevObject || this.constructor() }, push: s, sort: oe.sort, splice: oe.splice }, ce.extend = ce.fn.extend = function () { var e, t, n, r, i, o, a = arguments[0] || {}, s = 1, u = arguments.length, l = !1; for ("boolean" == typeof a && (l = a, a = arguments[s] || {}, s++), "object" == typeof a || v(a) || (a = {}), s === u && (a = this, s--); s < u; s++)if (null != (e = arguments[s])) for (t in e) r = e[t], "__proto__" !== t && a !== r && (l && r && (ce.isPlainObject(r) || (i = Array.isArray(r))) ? (n = a[t], o = i && !Array.isArray(n) ? [] : i || ce.isPlainObject(n) ? n : {}, i = !1, a[t] = ce.extend(l, o, r)) : void 0 !== r && (a[t] = r)); return a }, ce.extend({ expando: "jQuery" + (t + Math.random()).replace(/\D/g, ""), isReady: !0, error: function (e) { throw new Error(e) }, noop: function () { }, isPlainObject: function (e) { var t, n; return !(!e || "[object Object]" !== i.call(e)) && (!(t = r(e)) || "function" == typeof (n = ue.call(t, "constructor") && t.constructor) && o.call(n) === a) }, isEmptyObject: function (e) { var t; for (t in e) return !1; return !0 }, globalEval: function (e, t, n) { m(e, { nonce: t && t.nonce }, n) }, each: function (e, t) { var n, r = 0; if (c(e)) { for (n = e.length; r < n; r++)if (!1 === t.call(e[r], r, e[r])) break } else for (r in e) if (!1 === t.call(e[r], r, e[r])) break; return e }, text: function (e) { var t, n = "", r = 0, i = e.nodeType; if (!i) while (t = e[r++]) n += ce.text(t); return 1 === i || 11 === i ? e.textContent : 9 === i ? e.documentElement.textContent : 3 === i || 4 === i ? e.nodeValue : n }, makeArray: function (e, t) { var n = t || []; return null != e && (c(Object(e)) ? ce.merge(n, "string" == typeof e ? [e] : e) : s.call(n, e)), n }, inArray: function (e, t, n) { return null == t ? -1 : se.call(t, e, n) }, isXMLDoc: function (e) { var t = e && e.namespaceURI, n = e && (e.ownerDocument || e).documentElement; return !l.test(t || n && n.nodeName || "HTML") }, merge: function (e, t) { for (var n = +t.length, r = 0, i = e.length; r < n; r++)e[i++] = t[r]; return e.length = i, e }, grep: function (e, t, n) { for (var r = [], i = 0, o = e.length, a = !n; i < o; i++)!t(e[i], i) !== a && r.push(e[i]); return r }, map: function (e, t, n) { var r, i, o = 0, a = []; if (c(e)) for (r = e.length; o < r; o++)null != (i = t(e[o], o, n)) && a.push(i); else for (o in e) null != (i = t(e[o], o, n)) && a.push(i); return g(a) }, guid: 1, support: le }), "function" == typeof Symbol && (ce.fn[Symbol.iterator] = oe[Symbol.iterator]), ce.each("Boolean Number String Function Array Date RegExp Object Error Symbol".split(" "), function (e, t) { n["[object " + t + "]"] = t.toLowerCase() }); var pe = oe.pop, de = oe.sort, he = oe.splice, ge = "[\\x20\\t\\r\\n\\f]", ve = new RegExp("^" + ge + "+|((?:^|[^\\\\])(?:\\\\.)*)" + ge + "+$", "g"); ce.contains = function (e, t) { var n = t && t.parentNode; return e === n || !(!n || 1 !== n.nodeType || !(e.contains ? e.contains(n) : e.compareDocumentPosition && 16 & e.compareDocumentPosition(n))) }; var f = /([\0-\x1f\x7f]|^-?\d)|^-$|[^\x80-\uFFFF\w-]/g; function p(e, t) { return t ? "\0" === e ? "\ufffd" : e.slice(0, -1) + "\\" + e.charCodeAt(e.length - 1).toString(16) + " " : "\\" + e } ce.escapeSelector = function (e) { return (e + "").replace(f, p) }; var ye = C, me = s; !function () { var e, b, w, o, a, T, r, C, d, i, k = me, S = ce.expando, E = 0, n = 0, s = W(), c = W(), u = W(), h = W(), l = function (e, t) { return e === t && (a = !0), 0 }, f = "checked|selected|async|autofocus|autoplay|controls|defer|disabled|hidden|ismap|loop|multiple|open|readonly|required|scoped", t = "(?:\\\\[\\da-fA-F]{1,6}" + ge + "?|\\\\[^\\r\\n\\f]|[\\w-]|[^\0-\\x7f])+", p = "\\[" + ge + "*(" + t + ")(?:" + ge + "*([*^$|!~]?=)" + ge + "*(?:'((?:\\\\.|[^\\\\'])*)'|\"((?:\\\\.|[^\\\\\"])*)\"|(" + t + "))|)" + ge + "*\\]", g = ":(" + t + ")(?:\\((('((?:\\\\.|[^\\\\'])*)'|\"((?:\\\\.|[^\\\\\"])*)\")|((?:\\\\.|[^\\\\()[\\]]|" + p + ")*)|.*)\\)|)", v = new RegExp(ge + "+", "g"), y = new RegExp("^" + ge + "*," + ge + "*"), m = new RegExp("^" + ge + "*([>+~]|" + ge + ")" + ge + "*"), x = new RegExp(ge + "|>"), j = new RegExp(g), A = new RegExp("^" + t + "$"), D = { ID: new RegExp("^#(" + t + ")"), CLASS: new RegExp("^\\.(" + t + ")"), TAG: new RegExp("^(" + t + "|[*])"), ATTR: new RegExp("^" + p), PSEUDO: new RegExp("^" + g), CHILD: new RegExp("^:(only|first|last|nth|nth-last)-(child|of-type)(?:\\(" + ge + "*(even|odd|(([+-]|)(\\d*)n|)" + ge + "*(?:([+-]|)" + ge + "*(\\d+)|))" + ge + "*\\)|)", "i"), bool: new RegExp("^(?:" + f + ")$", "i"), needsContext: new RegExp("^" + ge + "*[>+~]|:(even|odd|eq|gt|lt|nth|first|last)(?:\\(" + ge + "*((?:-\\d)?\\d*)" + ge + "*\\)|)(?=[^-]|$)", "i") }, N = /^(?:input|select|textarea|button)$/i, q = /^h\d$/i, L = /^(?:#([\w-]+)|(\w+)|\.([\w-]+))$/, H = /[+~]/, O = new RegExp("\\\\[\\da-fA-F]{1,6}" + ge + "?|\\\\([^\\r\\n\\f])", "g"), P = function (e, t) { var n = "0x" + e.slice(1) - 65536; return t || (n < 0 ? String.fromCharCode(n + 65536) : String.fromCharCode(n >> 10 | 55296, 1023 & n | 56320)) }, M = function () { V() }, R = J(function (e) { return !0 === e.disabled && fe(e, "fieldset") }, { dir: "parentNode", next: "legend" }); try { k.apply(oe = ae.call(ye.childNodes), ye.childNodes), oe[ye.childNodes.length].nodeType } catch (e) { k = { apply: function (e, t) { me.apply(e, ae.call(t)) }, call: function (e) { me.apply(e, ae.call(arguments, 1)) } } } function I(t, e, n, r) { var i, o, a, s, u, l, c, f = e && e.ownerDocument, p = e ? e.nodeType : 9; if (n = n || [], "string" != typeof t || !t || 1 !== p && 9 !== p && 11 !== p) return n; if (!r && (V(e), e = e || T, C)) { if (11 !== p && (u = L.exec(t))) if (i = u[1]) { if (9 === p) { if (!(a = e.getElementById(i))) return n; if (a.id === i) return k.call(n, a), n } else if (f && (a = f.getElementById(i)) && I.contains(e, a) && a.id === i) return k.call(n, a), n } else { if (u[2]) return k.apply(n, e.getElementsByTagName(t)), n; if ((i = u[3]) && e.getElementsByClassName) return k.apply(n, e.getElementsByClassName(i)), n } if (!(h[t + " "] || d && d.test(t))) { if (c = t, f = e, 1 === p && (x.test(t) || m.test(t))) { (f = H.test(t) && U(e.parentNode) || e) == e && le.scope || ((s = e.getAttribute("id")) ? s = ce.escapeSelector(s) : e.setAttribute("id", s = S)), o = (l = Y(t)).length; while (o--) l[o] = (s ? "#" + s : ":scope") + " " + Q(l[o]); c = l.join(",") } try { return k.apply(n, f.querySelectorAll(c)), n } catch (e) { h(t, !0) } finally { s === S && e.removeAttribute("id") } } } return re(t.replace(ve, "$1"), e, n, r) } function W() { var r = []; return function e(t, n) { return r.push(t + " ") > b.cacheLength && delete e[r.shift()], e[t + " "] = n } } function F(e) { return e[S] = !0, e } function $(e) { var t = T.createElement("fieldset"); try { return !!e(t) } catch (e) { return !1 } finally { t.parentNode && t.parentNode.removeChild(t), t = null } } function B(t) { return function (e) { return fe(e, "input") && e.type === t } } function _(t) { return function (e) { return (fe(e, "input") || fe(e, "button")) && e.type === t } } function z(t) { return function (e) { return "form" in e ? e.parentNode && !1 === e.disabled ? "label" in e ? "label" in e.parentNode ? e.parentNode.disabled === t : e.disabled === t : e.isDisabled === t || e.isDisabled !== !t && R(e) === t : e.disabled === t : "label" in e && e.disabled === t } } function X(a) { return F(function (o) { return o = +o, F(function (e, t) { var n, r = a([], e.length, o), i = r.length; while (i--) e[n = r[i]] && (e[n] = !(t[n] = e[n])) }) }) } function U(e) { return e && "undefined" != typeof e.getElementsByTagName && e } function V(e) { var t, n = e ? e.ownerDocument || e : ye; return n != T && 9 === n.nodeType && n.documentElement && (r = (T = n).documentElement, C = !ce.isXMLDoc(T), i = r.matches || r.webkitMatchesSelector || r.msMatchesSelector, r.msMatchesSelector && ye != T && (t = T.defaultView) && t.top !== t && t.addEventListener("unload", M), le.getById = $(function (e) { return r.appendChild(e).id = ce.expando, !T.getElementsByName || !T.getElementsByName(ce.expando).length }), le.disconnectedMatch = $(function (e) { return i.call(e, "*") }), le.scope = $(function () { return T.querySelectorAll(":scope") }), le.cssHas = $(function () { try { return T.querySelector(":has(*,:jqfake)"), !1 } catch (e) { return !0 } }), le.getById ? (b.filter.ID = function (e) { var t = e.replace(O, P); return function (e) { return e.getAttribute("id") === t } }, b.find.ID = function (e, t) { if ("undefined" != typeof t.getElementById && C) { var n = t.getElementById(e); return n ? [n] : [] } }) : (b.filter.ID = function (e) { var n = e.replace(O, P); return function (e) { var t = "undefined" != typeof e.getAttributeNode && e.getAttributeNode("id"); return t && t.value === n } }, b.find.ID = function (e, t) { if ("undefined" != typeof t.getElementById && C) { var n, r, i, o = t.getElementById(e); if (o) { if ((n = o.getAttributeNode("id")) && n.value === e) return [o]; i = t.getElementsByName(e), r = 0; while (o = i[r++]) if ((n = o.getAttributeNode("id")) && n.value === e) return [o] } return [] } }), b.find.TAG = function (e, t) { return "undefined" != typeof t.getElementsByTagName ? t.getElementsByTagName(e) : t.querySelectorAll(e) }, b.find.CLASS = function (e, t) { if ("undefined" != typeof t.getElementsByClassName && C) return t.getElementsByClassName(e) }, d = [], $(function (e) { var t; r.appendChild(e).innerHTML = "<a id='" + S + "' href='' disabled='disabled'></a><select id='" + S + "-\r\\' disabled='disabled'><option selected=''></option></select>", e.querySelectorAll("[selected]").length || d.push("\\[" + ge + "*(?:value|" + f + ")"), e.querySelectorAll("[id~=" + S + "-]").length || d.push("~="), e.querySelectorAll("a#" + S + "+*").length || d.push(".#.+[+~]"), e.querySelectorAll(":checked").length || d.push(":checked"), (t = T.createElement("input")).setAttribute("type", "hidden"), e.appendChild(t).setAttribute("name", "D"), r.appendChild(e).disabled = !0, 2 !== e.querySelectorAll(":disabled").length && d.push(":enabled", ":disabled"), (t = T.createElement("input")).setAttribute("name", ""), e.appendChild(t), e.querySelectorAll("[name='']").length || d.push("\\[" + ge + "*name" + ge + "*=" + ge + "*(?:''|\"\")") }), le.cssHas || d.push(":has"), d = d.length && new RegExp(d.join("|")), l = function (e, t) { if (e === t) return a = !0, 0; var n = !e.compareDocumentPosition - !t.compareDocumentPosition; return n || (1 & (n = (e.ownerDocument || e) == (t.ownerDocument || t) ? e.compareDocumentPosition(t) : 1) || !le.sortDetached && t.compareDocumentPosition(e) === n ? e === T || e.ownerDocument == ye && I.contains(ye, e) ? -1 : t === T || t.ownerDocument == ye && I.contains(ye, t) ? 1 : o ? se.call(o, e) - se.call(o, t) : 0 : 4 & n ? -1 : 1) }), T } for (e in I.matches = function (e, t) { return I(e, null, null, t) }, I.matchesSelector = function (e, t) { if (V(e), C && !h[t + " "] && (!d || !d.test(t))) try { var n = i.call(e, t); if (n || le.disconnectedMatch || e.document && 11 !== e.document.nodeType) return n } catch (e) { h(t, !0) } return 0 < I(t, T, null, [e]).length }, I.contains = function (e, t) { return (e.ownerDocument || e) != T && V(e), ce.contains(e, t) }, I.attr = function (e, t) { (e.ownerDocument || e) != T && V(e); var n = b.attrHandle[t.toLowerCase()], r = n && ue.call(b.attrHandle, t.toLowerCase()) ? n(e, t, !C) : void 0; return void 0 !== r ? r : e.getAttribute(t) }, I.error = function (e) { throw new Error("Syntax error, unrecognized expression: " + e) }, ce.uniqueSort = function (e) { var t, n = [], r = 0, i = 0; if (a = !le.sortStable, o = !le.sortStable && ae.call(e, 0), de.call(e, l), a) { while (t = e[i++]) t === e[i] && (r = n.push(i)); while (r--) he.call(e, n[r], 1) } return o = null, e }, ce.fn.uniqueSort = function () { return this.pushStack(ce.uniqueSort(ae.apply(this))) }, (b = ce.expr = { cacheLength: 50, createPseudo: F, match: D, attrHandle: {}, find: {}, relative: { ">": { dir: "parentNode", first: !0 }, " ": { dir: "parentNode" }, "+": { dir: "previousSibling", first: !0 }, "~": { dir: "previousSibling" } }, preFilter: { ATTR: function (e) { return e[1] = e[1].replace(O, P), e[3] = (e[3] || e[4] || e[5] || "").replace(O, P), "~=" === e[2] && (e[3] = " " + e[3] + " "), e.slice(0, 4) }, CHILD: function (e) { return e[1] = e[1].toLowerCase(), "nth" === e[1].slice(0, 3) ? (e[3] || I.error(e[0]), e[4] = +(e[4] ? e[5] + (e[6] || 1) : 2 * ("even" === e[3] || "odd" === e[3])), e[5] = +(e[7] + e[8] || "odd" === e[3])) : e[3] && I.error(e[0]), e }, PSEUDO: function (e) { var t, n = !e[6] && e[2]; return D.CHILD.test(e[0]) ? null : (e[3] ? e[2] = e[4] || e[5] || "" : n && j.test(n) && (t = Y(n, !0)) && (t = n.indexOf(")", n.length - t) - n.length) && (e[0] = e[0].slice(0, t), e[2] = n.slice(0, t)), e.slice(0, 3)) } }, filter: { TAG: function (e) { var t = e.replace(O, P).toLowerCase(); return "*" === e ? function () { return !0 } : function (e) { return fe(e, t) } }, CLASS: function (e) { var t = s[e + " "]; return t || (t = new RegExp("(^|" + ge + ")" + e + "(" + ge + "|$)")) && s(e, function (e) { return t.test("string" == typeof e.className && e.className || "undefined" != typeof e.getAttribute && e.getAttribute("class") || "") }) }, ATTR: function (n, r, i) { return function (e) { var t = I.attr(e, n); return null == t ? "!=" === r : !r || (t += "", "=" === r ? t === i : "!=" === r ? t !== i : "^=" === r ? i && 0 === t.indexOf(i) : "*=" === r ? i && -1 < t.indexOf(i) : "$=" === r ? i && t.slice(-i.length) === i : "~=" === r ? -1 < (" " + t.replace(v, " ") + " ").indexOf(i) : "|=" === r && (t === i || t.slice(0, i.length + 1) === i + "-")) } }, CHILD: function (d, e, t, h, g) { var v = "nth" !== d.slice(0, 3), y = "last" !== d.slice(-4), m = "of-type" === e; return 1 === h && 0 === g ? function (e) { return !!e.parentNode } : function (e, t, n) { var r, i, o, a, s, u = v !== y ? "nextSibling" : "previousSibling", l = e.parentNode, c = m && e.nodeName.toLowerCase(), f = !n && !m, p = !1; if (l) { if (v) { while (u) { o = e; while (o = o[u]) if (m ? fe(o, c) : 1 === o.nodeType) return !1; s = u = "only" === d && !s && "nextSibling" } return !0 } if (s = [y ? l.firstChild : l.lastChild], y && f) { p = (a = (r = (i = l[S] || (l[S] = {}))[d] || [])[0] === E && r[1]) && r[2], o = a && l.childNodes[a]; while (o = ++a && o && o[u] || (p = a = 0) || s.pop()) if (1 === o.nodeType && ++p && o === e) { i[d] = [E, a, p]; break } } else if (f && (p = a = (r = (i = e[S] || (e[S] = {}))[d] || [])[0] === E && r[1]), !1 === p) while (o = ++a && o && o[u] || (p = a = 0) || s.pop()) if ((m ? fe(o, c) : 1 === o.nodeType) && ++p && (f && ((i = o[S] || (o[S] = {}))[d] = [E, p]), o === e)) break; return (p -= g) === h || p % h == 0 && 0 <= p / h } } }, PSEUDO: function (e, o) { var t, a = b.pseudos[e] || b.setFilters[e.toLowerCase()] || I.error("unsupported pseudo: " + e); return a[S] ? a(o) : 1 < a.length ? (t = [e, e, "", o], b.setFilters.hasOwnProperty(e.toLowerCase()) ? F(function (e, t) { var n, r = a(e, o), i = r.length; while (i--) e[n = se.call(e, r[i])] = !(t[n] = r[i]) }) : function (e) { return a(e, 0, t) }) : a } }, pseudos: { not: F(function (e) { var r = [], i = [], s = ne(e.replace(ve, "$1")); return s[S] ? F(function (e, t, n, r) { var i, o = s(e, null, r, []), a = e.length; while (a--) (i = o[a]) && (e[a] = !(t[a] = i)) }) : function (e, t, n) { return r[0] = e, s(r, null, n, i), r[0] = null, !i.pop() } }), has: F(function (t) { return function (e) { return 0 < I(t, e).length } }), contains: F(function (t) { return t = t.replace(O, P), function (e) { return -1 < (e.textContent || ce.text(e)).indexOf(t) } }), lang: F(function (n) { return A.test(n || "") || I.error("unsupported lang: " + n), n = n.replace(O, P).toLowerCase(), function (e) { var t; do { if (t = C ? e.lang : e.getAttribute("xml:lang") || e.getAttribute("lang")) return (t = t.toLowerCase()) === n || 0 === t.indexOf(n + "-") } while ((e = e.parentNode) && 1 === e.nodeType); return !1 } }), target: function (e) { var t = ie.location && ie.location.hash; return t && t.slice(1) === e.id }, root: function (e) { return e === r }, focus: function (e) { return e === function () { try { return T.activeElement } catch (e) { } }() && T.hasFocus() && !!(e.type || e.href || ~e.tabIndex) }, enabled: z(!1), disabled: z(!0), checked: function (e) { return fe(e, "input") && !!e.checked || fe(e, "option") && !!e.selected }, selected: function (e) { return e.parentNode && e.parentNode.selectedIndex, !0 === e.selected }, empty: function (e) { for (e = e.firstChild; e; e = e.nextSibling)if (e.nodeType < 6) return !1; return !0 }, parent: function (e) { return !b.pseudos.empty(e) }, header: function (e) { return q.test(e.nodeName) }, input: function (e) { return N.test(e.nodeName) }, button: function (e) { return fe(e, "input") && "button" === e.type || fe(e, "button") }, text: function (e) { var t; return fe(e, "input") && "text" === e.type && (null == (t = e.getAttribute("type")) || "text" === t.toLowerCase()) }, first: X(function () { return [0] }), last: X(function (e, t) { return [t - 1] }), eq: X(function (e, t, n) { return [n < 0 ? n + t : n] }), even: X(function (e, t) { for (var n = 0; n < t; n += 2)e.push(n); return e }), odd: X(function (e, t) { for (var n = 1; n < t; n += 2)e.push(n); return e }), lt: X(function (e, t, n) { var r; for (r = n < 0 ? n + t : t < n ? t : n; 0 <= --r;)e.push(r); return e }), gt: X(function (e, t, n) { for (var r = n < 0 ? n + t : n; ++r < t;)e.push(r); return e }) } }).pseudos.nth = b.pseudos.eq, { radio: !0, checkbox: !0, file: !0, password: !0, image: !0 }) b.pseudos[e] = B(e); for (e in { submit: !0, reset: !0 }) b.pseudos[e] = _(e); function G() { } function Y(e, t) { var n, r, i, o, a, s, u, l = c[e + " "]; if (l) return t ? 0 : l.slice(0); a = e, s = [], u = b.preFilter; while (a) { for (o in n && !(r = y.exec(a)) || (r && (a = a.slice(r[0].length) || a), s.push(i = [])), n = !1, (r = m.exec(a)) && (n = r.shift(), i.push({ value: n, type: r[0].replace(ve, " ") }), a = a.slice(n.length)), b.filter) !(r = D[o].exec(a)) || u[o] && !(r = u[o](r)) || (n = r.shift(), i.push({ value: n, type: o, matches: r }), a = a.slice(n.length)); if (!n) break } return t ? a.length : a ? I.error(e) : c(e, s).slice(0) } function Q(e) { for (var t = 0, n = e.length, r = ""; t < n; t++)r += e[t].value; return r } function J(a, e, t) { var s = e.dir, u = e.next, l = u || s, c = t && "parentNode" === l, f = n++; return e.first ? function (e, t, n) { while (e = e[s]) if (1 === e.nodeType || c) return a(e, t, n); return !1 } : function (e, t, n) { var r, i, o = [E, f]; if (n) { while (e = e[s]) if ((1 === e.nodeType || c) && a(e, t, n)) return !0 } else while (e = e[s]) if (1 === e.nodeType || c) if (i = e[S] || (e[S] = {}), u && fe(e, u)) e = e[s] || e; else { if ((r = i[l]) && r[0] === E && r[1] === f) return o[2] = r[2]; if ((i[l] = o)[2] = a(e, t, n)) return !0 } return !1 } } function K(i) { return 1 < i.length ? function (e, t, n) { var r = i.length; while (r--) if (!i[r](e, t, n)) return !1; return !0 } : i[0] } function Z(e, t, n, r, i) { for (var o, a = [], s = 0, u = e.length, l = null != t; s < u; s++)(o = e[s]) && (n && !n(o, r, i) || (a.push(o), l && t.push(s))); return a } function ee(d, h, g, v, y, e) { return v && !v[S] && (v = ee(v)), y && !y[S] && (y = ee(y, e)), F(function (e, t, n, r) { var i, o, a, s, u = [], l = [], c = t.length, f = e || function (e, t, n) { for (var r = 0, i = t.length; r < i; r++)I(e, t[r], n); return n }(h || "*", n.nodeType ? [n] : n, []), p = !d || !e && h ? f : Z(f, u, d, n, r); if (g ? g(p, s = y || (e ? d : c || v) ? [] : t, n, r) : s = p, v) { i = Z(s, l), v(i, [], n, r), o = i.length; while (o--) (a = i[o]) && (s[l[o]] = !(p[l[o]] = a)) } if (e) { if (y || d) { if (y) { i = [], o = s.length; while (o--) (a = s[o]) && i.push(p[o] = a); y(null, s = [], i, r) } o = s.length; while (o--) (a = s[o]) && -1 < (i = y ? se.call(e, a) : u[o]) && (e[i] = !(t[i] = a)) } } else s = Z(s === t ? s.splice(c, s.length) : s), y ? y(null, t, s, r) : k.apply(t, s) }) } function te(e) { for (var i, t, n, r = e.length, o = b.relative[e[0].type], a = o || b.relative[" "], s = o ? 1 : 0, u = J(function (e) { return e === i }, a, !0), l = J(function (e) { return -1 < se.call(i, e) }, a, !0), c = [function (e, t, n) { var r = !o && (n || t != w) || ((i = t).nodeType ? u(e, t, n) : l(e, t, n)); return i = null, r }]; s < r; s++)if (t = b.relative[e[s].type]) c = [J(K(c), t)]; else { if ((t = b.filter[e[s].type].apply(null, e[s].matches))[S]) { for (n = ++s; n < r; n++)if (b.relative[e[n].type]) break; return ee(1 < s && K(c), 1 < s && Q(e.slice(0, s - 1).concat({ value: " " === e[s - 2].type ? "*" : "" })).replace(ve, "$1"), t, s < n && te(e.slice(s, n)), n < r && te(e = e.slice(n)), n < r && Q(e)) } c.push(t) } return K(c) } function ne(e, t) { var n, v, y, m, x, r, i = [], o = [], a = u[e + " "]; if (!a) { t || (t = Y(e)), n = t.length; while (n--) (a = te(t[n]))[S] ? i.push(a) : o.push(a); (a = u(e, (v = o, m = 0 < (y = i).length, x = 0 < v.length, r = function (e, t, n, r, i) { var o, a, s, u = 0, l = "0", c = e && [], f = [], p = w, d = e || x && b.find.TAG("*", i), h = E += null == p ? 1 : Math.random() || .1, g = d.length; for (i && (w = t == T || t || i); l !== g && null != (o = d[l]); l++) { if (x && o) { a = 0, t || o.ownerDocument == T || (V(o), n = !C); while (s = v[a++]) if (s(o, t || T, n)) { k.call(r, o); break } i && (E = h) } m && ((o = !s && o) && u--, e && c.push(o)) } if (u += l, m && l !== u) { a = 0; while (s = y[a++]) s(c, f, t, n); if (e) { if (0 < u) while (l--) c[l] || f[l] || (f[l] = pe.call(r)); f = Z(f) } k.apply(r, f), i && !e && 0 < f.length && 1 < u + y.length && ce.uniqueSort(r) } return i && (E = h, w = p), c }, m ? F(r) : r))).selector = e } return a } function re(e, t, n, r) { var i, o, a, s, u, l = "function" == typeof e && e, c = !r && Y(e = l.selector || e); if (n = n || [], 1 === c.length) { if (2 < (o = c[0] = c[0].slice(0)).length && "ID" === (a = o[0]).type && 9 === t.nodeType && C && b.relative[o[1].type]) { if (!(t = (b.find.ID(a.matches[0].replace(O, P), t) || [])[0])) return n; l && (t = t.parentNode), e = e.slice(o.shift().value.length) } i = D.needsContext.test(e) ? 0 : o.length; while (i--) { if (a = o[i], b.relative[s = a.type]) break; if ((u = b.find[s]) && (r = u(a.matches[0].replace(O, P), H.test(o[0].type) && U(t.parentNode) || t))) { if (o.splice(i, 1), !(e = r.length && Q(o))) return k.apply(n, r), n; break } } } return (l || ne(e, c))(r, t, !C, n, !t || H.test(e) && U(t.parentNode) || t), n } G.prototype = b.filters = b.pseudos, b.setFilters = new G, le.sortStable = S.split("").sort(l).join("") === S, V(), le.sortDetached = $(function (e) { return 1 & e.compareDocumentPosition(T.createElement("fieldset")) }), ce.find = I, ce.expr[":"] = ce.expr.pseudos, ce.unique = ce.uniqueSort, I.compile = ne, I.select = re, I.setDocument = V, I.tokenize = Y, I.escape = ce.escapeSelector, I.getText = ce.text, I.isXML = ce.isXMLDoc, I.selectors = ce.expr, I.support = ce.support, I.uniqueSort = ce.uniqueSort }(); var d = function (e, t, n) { var r = [], i = void 0 !== n; while ((e = e[t]) && 9 !== e.nodeType) if (1 === e.nodeType) { if (i && ce(e).is(n)) break; r.push(e) } return r }, h = function (e, t) { for (var n = []; e; e = e.nextSibling)1 === e.nodeType && e !== t && n.push(e); return n }, b = ce.expr.match.needsContext, w = /^<([a-z][^\/\0>:\x20\t\r\n\f]*)[\x20\t\r\n\f]*\/?>(?:<\/\1>|)$/i; function T(e, n, r) { return v(n) ? ce.grep(e, function (e, t) { return !!n.call(e, t, e) !== r }) : n.nodeType ? ce.grep(e, function (e) { return e === n !== r }) : "string" != typeof n ? ce.grep(e, function (e) { return -1 < se.call(n, e) !== r }) : ce.filter(n, e, r) } ce.filter = function (e, t, n) { var r = t[0]; return n && (e = ":not(" + e + ")"), 1 === t.length && 1 === r.nodeType ? ce.find.matchesSelector(r, e) ? [r] : [] : ce.find.matches(e, ce.grep(t, function (e) { return 1 === e.nodeType })) }, ce.fn.extend({ find: function (e) { var t, n, r = this.length, i = this; if ("string" != typeof e) return this.pushStack(ce(e).filter(function () { for (t = 0; t < r; t++)if (ce.contains(i[t], this)) return !0 })); for (n = this.pushStack([]), t = 0; t < r; t++)ce.find(e, i[t], n); return 1 < r ? ce.uniqueSort(n) : n }, filter: function (e) { return this.pushStack(T(this, e || [], !1)) }, not: function (e) { return this.pushStack(T(this, e || [], !0)) }, is: function (e) { return !!T(this, "string" == typeof e && b.test(e) ? ce(e) : e || [], !1).length } }); var k, S = /^(?:\s*(<[\w\W]+>)[^>]*|#([\w-]+))$/; (ce.fn.init = function (e, t, n) { var r, i; if (!e) return this; if (n = n || k, "string" == typeof e) { if (!(r = "<" === e[0] && ">" === e[e.length - 1] && 3 <= e.length ? [null, e, null] : S.exec(e)) || !r[1] && t) return !t || t.jquery ? (t || n).find(e) : this.constructor(t).find(e); if (r[1]) { if (t = t instanceof ce ? t[0] : t, ce.merge(this, ce.parseHTML(r[1], t && t.nodeType ? t.ownerDocument || t : C, !0)), w.test(r[1]) && ce.isPlainObject(t)) for (r in t) v(this[r]) ? this[r](t[r]) : this.attr(r, t[r]); return this } return (i = C.getElementById(r[2])) && (this[0] = i, this.length = 1), this } return e.nodeType ? (this[0] = e, this.length = 1, this) : v(e) ? void 0 !== n.ready ? n.ready(e) : e(ce) : ce.makeArray(e, this) }).prototype = ce.fn, k = ce(C); var E = /^(?:parents|prev(?:Until|All))/, j = { children: !0, contents: !0, next: !0, prev: !0 }; function A(e, t) { while ((e = e[t]) && 1 !== e.nodeType); return e } ce.fn.extend({ has: function (e) { var t = ce(e, this), n = t.length; return this.filter(function () { for (var e = 0; e < n; e++)if (ce.contains(this, t[e])) return !0 }) }, closest: function (e, t) { var n, r = 0, i = this.length, o = [], a = "string" != typeof e && ce(e); if (!b.test(e)) for (; r < i; r++)for (n = this[r]; n && n !== t; n = n.parentNode)if (n.nodeType < 11 && (a ? -1 < a.index(n) : 1 === n.nodeType && ce.find.matchesSelector(n, e))) { o.push(n); break } return this.pushStack(1 < o.length ? ce.uniqueSort(o) : o) }, index: function (e) { return e ? "string" == typeof e ? se.call(ce(e), this[0]) : se.call(this, e.jquery ? e[0] : e) : this[0] && this[0].parentNode ? this.first().prevAll().length : -1 }, add: function (e, t) { return this.pushStack(ce.uniqueSort(ce.merge(this.get(), ce(e, t)))) }, addBack: function (e) { return this.add(null == e ? this.prevObject : this.prevObject.filter(e)) } }), ce.each({ parent: function (e) { var t = e.parentNode; return t && 11 !== t.nodeType ? t : null }, parents: function (e) { return d(e, "parentNode") }, parentsUntil: function (e, t, n) { return d(e, "parentNode", n) }, next: function (e) { return A(e, "nextSibling") }, prev: function (e) { return A(e, "previousSibling") }, nextAll: function (e) { return d(e, "nextSibling") }, prevAll: function (e) { return d(e, "previousSibling") }, nextUntil: function (e, t, n) { return d(e, "nextSibling", n) }, prevUntil: function (e, t, n) { return d(e, "previousSibling", n) }, siblings: function (e) { return h((e.parentNode || {}).firstChild, e) }, children: function (e) { return h(e.firstChild) }, contents: function (e) { return null != e.contentDocument && r(e.contentDocument) ? e.contentDocument : (fe(e, "template") && (e = e.content || e), ce.merge([], e.childNodes)) } }, function (r, i) { ce.fn[r] = function (e, t) { var n = ce.map(this, i, e); return "Until" !== r.slice(-5) && (t = e), t && "string" == typeof t && (n = ce.filter(t, n)), 1 < this.length && (j[r] || ce.uniqueSort(n), E.test(r) && n.reverse()), this.pushStack(n) } }); var D = /[^\x20\t\r\n\f]+/g; function N(e) { return e } function q(e) { throw e } function L(e, t, n, r) { var i; try { e && v(i = e.promise) ? i.call(e).done(t).fail(n) : e && v(i = e.then) ? i.call(e, t, n) : t.apply(void 0, [e].slice(r)) } catch (e) { n.apply(void 0, [e]) } } ce.Callbacks = function (r) { var e, n; r = "string" == typeof r ? (e = r, n = {}, ce.each(e.match(D) || [], function (e, t) { n[t] = !0 }), n) : ce.extend({}, r); var i, t, o, a, s = [], u = [], l = -1, c = function () { for (a = a || r.once, o = i = !0; u.length; l = -1) { t = u.shift(); while (++l < s.length) !1 === s[l].apply(t[0], t[1]) && r.stopOnFalse && (l = s.length, t = !1) } r.memory || (t = !1), i = !1, a && (s = t ? [] : "") }, f = { add: function () { return s && (t && !i && (l = s.length - 1, u.push(t)), function n(e) { ce.each(e, function (e, t) { v(t) ? r.unique && f.has(t) || s.push(t) : t && t.length && "string" !== x(t) && n(t) }) }(arguments), t && !i && c()), this }, remove: function () { return ce.each(arguments, function (e, t) { var n; while (-1 < (n = ce.inArray(t, s, n))) s.splice(n, 1), n <= l && l-- }), this }, has: function (e) { return e ? -1 < ce.inArray(e, s) : 0 < s.length }, empty: function () { return s && (s = []), this }, disable: function () { return a = u = [], s = t = "", this }, disabled: function () { return !s }, lock: function () { return a = u = [], t || i || (s = t = ""), this }, locked: function () { return !!a }, fireWith: function (e, t) { return a || (t = [e, (t = t || []).slice ? t.slice() : t], u.push(t), i || c()), this }, fire: function () { return f.fireWith(this, arguments), this }, fired: function () { return !!o } }; return f }, ce.extend({ Deferred: function (e) { var o = [["notify", "progress", ce.Callbacks("memory"), ce.Callbacks("memory"), 2], ["resolve", "done", ce.Callbacks("once memory"), ce.Callbacks("once memory"), 0, "resolved"], ["reject", "fail", ce.Callbacks("once memory"), ce.Callbacks("once memory"), 1, "rejected"]], i = "pending", a = { state: function () { return i }, always: function () { return s.done(arguments).fail(arguments), this }, "catch": function (e) { return a.then(null, e) }, pipe: function () { var i = arguments; return ce.Deferred(function (r) { ce.each(o, function (e, t) { var n = v(i[t[4]]) && i[t[4]]; s[t[1]](function () { var e = n && n.apply(this, arguments); e && v(e.promise) ? e.promise().progress(r.notify).done(r.resolve).fail(r.reject) : r[t[0] + "With"](this, n ? [e] : arguments) }) }), i = null }).promise() }, then: function (t, n, r) { var u = 0; function l(i, o, a, s) { return function () { var n = this, r = arguments, e = function () { var e, t; if (!(i < u)) { if ((e = a.apply(n, r)) === o.promise()) throw new TypeError("Thenable self-resolution"); t = e && ("object" == typeof e || "function" == typeof e) && e.then, v(t) ? s ? t.call(e, l(u, o, N, s), l(u, o, q, s)) : (u++, t.call(e, l(u, o, N, s), l(u, o, q, s), l(u, o, N, o.notifyWith))) : (a !== N && (n = void 0, r = [e]), (s || o.resolveWith)(n, r)) } }, t = s ? e : function () { try { e() } catch (e) { ce.Deferred.exceptionHook && ce.Deferred.exceptionHook(e, t.error), u <= i + 1 && (a !== q && (n = void 0, r = [e]), o.rejectWith(n, r)) } }; i ? t() : (ce.Deferred.getErrorHook ? t.error = ce.Deferred.getErrorHook() : ce.Deferred.getStackHook && (t.error = ce.Deferred.getStackHook()), ie.setTimeout(t)) } } return ce.Deferred(function (e) { o[0][3].add(l(0, e, v(r) ? r : N, e.notifyWith)), o[1][3].add(l(0, e, v(t) ? t : N)), o[2][3].add(l(0, e, v(n) ? n : q)) }).promise() }, promise: function (e) { return null != e ? ce.extend(e, a) : a } }, s = {}; return ce.each(o, function (e, t) { var n = t[2], r = t[5]; a[t[1]] = n.add, r && n.add(function () { i = r }, o[3 - e][2].disable, o[3 - e][3].disable, o[0][2].lock, o[0][3].lock), n.add(t[3].fire), s[t[0]] = function () { return s[t[0] + "With"](this === s ? void 0 : this, arguments), this }, s[t[0] + "With"] = n.fireWith }), a.promise(s), e && e.call(s, s), s }, when: function (e) { var n = arguments.length, t = n, r = Array(t), i = ae.call(arguments), o = ce.Deferred(), a = function (t) { return function (e) { r[t] = this, i[t] = 1 < arguments.length ? ae.call(arguments) : e, --n || o.resolveWith(r, i) } }; if (n <= 1 && (L(e, o.done(a(t)).resolve, o.reject, !n), "pending" === o.state() || v(i[t] && i[t].then))) return o.then(); while (t--) L(i[t], a(t), o.reject); return o.promise() } }); var H = /^(Eval|Internal|Range|Reference|Syntax|Type|URI)Error$/; ce.Deferred.exceptionHook = function (e, t) { ie.console && ie.console.warn && e && H.test(e.name) && ie.console.warn("jQuery.Deferred exception: " + e.message, e.stack, t) }, ce.readyException = function (e) { ie.setTimeout(function () { throw e }) }; var O = ce.Deferred(); function P() { C.removeEventListener("DOMContentLoaded", P), ie.removeEventListener("load", P), ce.ready() } ce.fn.ready = function (e) { return O.then(e)["catch"](function (e) { ce.readyException(e) }), this }, ce.extend({ isReady: !1, readyWait: 1, ready: function (e) { (!0 === e ? --ce.readyWait : ce.isReady) || (ce.isReady = !0) !== e && 0 < --ce.readyWait || O.resolveWith(C, [ce]) } }), ce.ready.then = O.then, "complete" === C.readyState || "loading" !== C.readyState && !C.documentElement.doScroll ? ie.setTimeout(ce.ready) : (C.addEventListener("DOMContentLoaded", P), ie.addEventListener("load", P)); var M = function (e, t, n, r, i, o, a) { var s = 0, u = e.length, l = null == n; if ("object" === x(n)) for (s in i = !0, n) M(e, t, s, n[s], !0, o, a); else if (void 0 !== r && (i = !0, v(r) || (a = !0), l && (a ? (t.call(e, r), t = null) : (l = t, t = function (e, t, n) { return l.call(ce(e), n) })), t)) for (; s < u; s++)t(e[s], n, a ? r : r.call(e[s], s, t(e[s], n))); return i ? e : l ? t.call(e) : u ? t(e[0], n) : o }, R = /^-ms-/, I = /-([a-z])/g; function W(e, t) { return t.toUpperCase() } function F(e) { return e.replace(R, "ms-").replace(I, W) } var $ = function (e) { return 1 === e.nodeType || 9 === e.nodeType || !+e.nodeType }; function B() { this.expando = ce.expando + B.uid++ } B.uid = 1, B.prototype = { cache: function (e) { var t = e[this.expando]; return t || (t = {}, $(e) && (e.nodeType ? e[this.expando] = t : Object.defineProperty(e, this.expando, { value: t, configurable: !0 }))), t }, set: function (e, t, n) { var r, i = this.cache(e); if ("string" == typeof t) i[F(t)] = n; else for (r in t) i[F(r)] = t[r]; return i }, get: function (e, t) { return void 0 === t ? this.cache(e) : e[this.expando] && e[this.expando][F(t)] }, access: function (e, t, n) { return void 0 === t || t && "string" == typeof t && void 0 === n ? this.get(e, t) : (this.set(e, t, n), void 0 !== n ? n : t) }, remove: function (e, t) { var n, r = e[this.expando]; if (void 0 !== r) { if (void 0 !== t) { n = (t = Array.isArray(t) ? t.map(F) : (t = F(t)) in r ? [t] : t.match(D) || []).length; while (n--) delete r[t[n]] } (void 0 === t || ce.isEmptyObject(r)) && (e.nodeType ? e[this.expando] = void 0 : delete e[this.expando]) } }, hasData: function (e) { var t = e[this.expando]; return void 0 !== t && !ce.isEmptyObject(t) } }; var _ = new B, z = new B, X = /^(?:\{[\w\W]*\}|\[[\w\W]*\])$/, U = /[A-Z]/g; function V(e, t, n) { var r, i; if (void 0 === n && 1 === e.nodeType) if (r = "data-" + t.replace(U, "-$&").toLowerCase(), "string" == typeof (n = e.getAttribute(r))) { try { n = "true" === (i = n) || "false" !== i && ("null" === i ? null : i === +i + "" ? +i : X.test(i) ? JSON.parse(i) : i) } catch (e) { } z.set(e, t, n) } else n = void 0; return n } ce.extend({ hasData: function (e) { return z.hasData(e) || _.hasData(e) }, data: function (e, t, n) { return z.access(e, t, n) }, removeData: function (e, t) { z.remove(e, t) }, _data: function (e, t, n) { return _.access(e, t, n) }, _removeData: function (e, t) { _.remove(e, t) } }), ce.fn.extend({ data: function (n, e) { var t, r, i, o = this[0], a = o && o.attributes; if (void 0 === n) { if (this.length && (i = z.get(o), 1 === o.nodeType && !_.get(o, "hasDataAttrs"))) { t = a.length; while (t--) a[t] && 0 === (r = a[t].name).indexOf("data-") && (r = F(r.slice(5)), V(o, r, i[r])); _.set(o, "hasDataAttrs", !0) } return i } return "object" == typeof n ? this.each(function () { z.set(this, n) }) : M(this, function (e) { var t; if (o && void 0 === e) return void 0 !== (t = z.get(o, n)) ? t : void 0 !== (t = V(o, n)) ? t : void 0; this.each(function () { z.set(this, n, e) }) }, null, e, 1 < arguments.length, null, !0) }, removeData: function (e) { return this.each(function () { z.remove(this, e) }) } }), ce.extend({ queue: function (e, t, n) { var r; if (e) return t = (t || "fx") + "queue", r = _.get(e, t), n && (!r || Array.isArray(n) ? r = _.access(e, t, ce.makeArray(n)) : r.push(n)), r || [] }, dequeue: function (e, t) { t = t || "fx"; var n = ce.queue(e, t), r = n.length, i = n.shift(), o = ce._queueHooks(e, t); "inprogress" === i && (i = n.shift(), r--), i && ("fx" === t && n.unshift("inprogress"), delete o.stop, i.call(e, function () { ce.dequeue(e, t) }, o)), !r && o && o.empty.fire() }, _queueHooks: function (e, t) { var n = t + "queueHooks"; return _.get(e, n) || _.access(e, n, { empty: ce.Callbacks("once memory").add(function () { _.remove(e, [t + "queue", n]) }) }) } }), ce.fn.extend({ queue: function (t, n) { var e = 2; return "string" != typeof t && (n = t, t = "fx", e--), arguments.length < e ? ce.queue(this[0], t) : void 0 === n ? this : this.each(function () { var e = ce.queue(this, t, n); ce._queueHooks(this, t), "fx" === t && "inprogress" !== e[0] && ce.dequeue(this, t) }) }, dequeue: function (e) { return this.each(function () { ce.dequeue(this, e) }) }, clearQueue: function (e) { return this.queue(e || "fx", []) }, promise: function (e, t) { var n, r = 1, i = ce.Deferred(), o = this, a = this.length, s = function () { --r || i.resolveWith(o, [o]) }; "string" != typeof e && (t = e, e = void 0), e = e || "fx"; while (a--) (n = _.get(o[a], e + "queueHooks")) && n.empty && (r++, n.empty.add(s)); return s(), i.promise(t) } }); var G = /[+-]?(?:\d*\.|)\d+(?:[eE][+-]?\d+|)/.source, Y = new RegExp("^(?:([+-])=|)(" + G + ")([a-z%]*)$", "i"), Q = ["Top", "Right", "Bottom", "Left"], J = C.documentElement, K = function (e) { return ce.contains(e.ownerDocument, e) }, Z = { composed: !0 }; J.getRootNode && (K = function (e) { return ce.contains(e.ownerDocument, e) || e.getRootNode(Z) === e.ownerDocument }); var ee = function (e, t) { return "none" === (e = t || e).style.display || "" === e.style.display && K(e) && "none" === ce.css(e, "display") }; function te(e, t, n, r) { var i, o, a = 20, s = r ? function () { return r.cur() } : function () { return ce.css(e, t, "") }, u = s(), l = n && n[3] || (ce.cssNumber[t] ? "" : "px"), c = e.nodeType && (ce.cssNumber[t] || "px" !== l && +u) && Y.exec(ce.css(e, t)); if (c && c[3] !== l) { u /= 2, l = l || c[3], c = +u || 1; while (a--) ce.style(e, t, c + l), (1 - o) * (1 - (o = s() / u || .5)) <= 0 && (a = 0), c /= o; c *= 2, ce.style(e, t, c + l), n = n || [] } return n && (c = +c || +u || 0, i = n[1] ? c + (n[1] + 1) * n[2] : +n[2], r && (r.unit = l, r.start = c, r.end = i)), i } var ne = {}; function re(e, t) { for (var n, r, i, o, a, s, u, l = [], c = 0, f = e.length; c < f; c++)(r = e[c]).style && (n = r.style.display, t ? ("none" === n && (l[c] = _.get(r, "display") || null, l[c] || (r.style.display = "")), "" === r.style.display && ee(r) && (l[c] = (u = a = o = void 0, a = (i = r).ownerDocument, s = i.nodeName, (u = ne[s]) || (o = a.body.appendChild(a.createElement(s)), u = ce.css(o, "display"), o.parentNode.removeChild(o), "none" === u && (u = "block"), ne[s] = u)))) : "none" !== n && (l[c] = "none", _.set(r, "display", n))); for (c = 0; c < f; c++)null != l[c] && (e[c].style.display = l[c]); return e } ce.fn.extend({ show: function () { return re(this, !0) }, hide: function () { return re(this) }, toggle: function (e) { return "boolean" == typeof e ? e ? this.show() : this.hide() : this.each(function () { ee(this) ? ce(this).show() : ce(this).hide() }) } }); var xe, be, we = /^(?:checkbox|radio)$/i, Te = /<([a-z][^\/\0>\x20\t\r\n\f]*)/i, Ce = /^$|^module$|\/(?:java|ecma)script/i; xe = C.createDocumentFragment().appendChild(C.createElement("div")), (be = C.createElement("input")).setAttribute("type", "radio"), be.setAttribute("checked", "checked"), be.setAttribute("name", "t"), xe.appendChild(be), le.checkClone = xe.cloneNode(!0).cloneNode(!0).lastChild.checked, xe.innerHTML = "<textarea>x</textarea>", le.noCloneChecked = !!xe.cloneNode(!0).lastChild.defaultValue, xe.innerHTML = "<option></option>", le.option = !!xe.lastChild; var ke = { thead: [1, "<table>", "</table>"], col: [2, "<table><colgroup>", "</colgroup></table>"], tr: [2, "<table><tbody>", "</tbody></table>"], td: [3, "<table><tbody><tr>", "</tr></tbody></table>"], _default: [0, "", ""] }; function Se(e, t) { var n; return n = "undefined" != typeof e.getElementsByTagName ? e.getElementsByTagName(t || "*") : "undefined" != typeof e.querySelectorAll ? e.querySelectorAll(t || "*") : [], void 0 === t || t && fe(e, t) ? ce.merge([e], n) : n } function Ee(e, t) { for (var n = 0, r = e.length; n < r; n++)_.set(e[n], "globalEval", !t || _.get(t[n], "globalEval")) } ke.tbody = ke.tfoot = ke.colgroup = ke.caption = ke.thead, ke.th = ke.td, le.option || (ke.optgroup = ke.option = [1, "<select multiple='multiple'>", "</select>"]); var je = /<|&#?\w+;/; function Ae(e, t, n, r, i) { for (var o, a, s, u, l, c, f = t.createDocumentFragment(), p = [], d = 0, h = e.length; d < h; d++)if ((o = e[d]) || 0 === o) if ("object" === x(o)) ce.merge(p, o.nodeType ? [o] : o); else if (je.test(o)) { a = a || f.appendChild(t.createElement("div")), s = (Te.exec(o) || ["", ""])[1].toLowerCase(), u = ke[s] || ke._default, a.innerHTML = u[1] + ce.htmlPrefilter(o) + u[2], c = u[0]; while (c--) a = a.lastChild; ce.merge(p, a.childNodes), (a = f.firstChild).textContent = "" } else p.push(t.createTextNode(o)); f.textContent = "", d = 0; while (o = p[d++]) if (r && -1 < ce.inArray(o, r)) i && i.push(o); else if (l = K(o), a = Se(f.appendChild(o), "script"), l && Ee(a), n) { c = 0; while (o = a[c++]) Ce.test(o.type || "") && n.push(o) } return f } var De = /^([^.]*)(?:\.(.+)|)/; function Ne() { return !0 } function qe() { return !1 } function Le(e, t, n, r, i, o) { var a, s; if ("object" == typeof t) { for (s in "string" != typeof n && (r = r || n, n = void 0), t) Le(e, s, n, r, t[s], o); return e } if (null == r && null == i ? (i = n, r = n = void 0) : null == i && ("string" == typeof n ? (i = r, r = void 0) : (i = r, r = n, n = void 0)), !1 === i) i = qe; else if (!i) return e; return 1 === o && (a = i, (i = function (e) { return ce().off(e), a.apply(this, arguments) }).guid = a.guid || (a.guid = ce.guid++)), e.each(function () { ce.event.add(this, t, i, r, n) }) } function He(e, r, t) { t ? (_.set(e, r, !1), ce.event.add(e, r, { namespace: !1, handler: function (e) { var t, n = _.get(this, r); if (1 & e.isTrigger && this[r]) { if (n) (ce.event.special[r] || {}).delegateType && e.stopPropagation(); else if (n = ae.call(arguments), _.set(this, r, n), this[r](), t = _.get(this, r), _.set(this, r, !1), n !== t) return e.stopImmediatePropagation(), e.preventDefault(), t } else n && (_.set(this, r, ce.event.trigger(n[0], n.slice(1), this)), e.stopPropagation(), e.isImmediatePropagationStopped = Ne) } })) : void 0 === _.get(e, r) && ce.event.add(e, r, Ne) } ce.event = { global: {}, add: function (t, e, n, r, i) { var o, a, s, u, l, c, f, p, d, h, g, v = _.get(t); if ($(t)) { n.handler && (n = (o = n).handler, i = o.selector), i && ce.find.matchesSelector(J, i), n.guid || (n.guid = ce.guid++), (u = v.events) || (u = v.events = Object.create(null)), (a = v.handle) || (a = v.handle = function (e) { return "undefined" != typeof ce && ce.event.triggered !== e.type ? ce.event.dispatch.apply(t, arguments) : void 0 }), l = (e = (e || "").match(D) || [""]).length; while (l--) d = g = (s = De.exec(e[l]) || [])[1], h = (s[2] || "").split(".").sort(), d && (f = ce.event.special[d] || {}, d = (i ? f.delegateType : f.bindType) || d, f = ce.event.special[d] || {}, c = ce.extend({ type: d, origType: g, data: r, handler: n, guid: n.guid, selector: i, needsContext: i && ce.expr.match.needsContext.test(i), namespace: h.join(".") }, o), (p = u[d]) || ((p = u[d] = []).delegateCount = 0, f.setup && !1 !== f.setup.call(t, r, h, a) || t.addEventListener && t.addEventListener(d, a)), f.add && (f.add.call(t, c), c.handler.guid || (c.handler.guid = n.guid)), i ? p.splice(p.delegateCount++, 0, c) : p.push(c), ce.event.global[d] = !0) } }, remove: function (e, t, n, r, i) { var o, a, s, u, l, c, f, p, d, h, g, v = _.hasData(e) && _.get(e); if (v && (u = v.events)) { l = (t = (t || "").match(D) || [""]).length; while (l--) if (d = g = (s = De.exec(t[l]) || [])[1], h = (s[2] || "").split(".").sort(), d) { f = ce.event.special[d] || {}, p = u[d = (r ? f.delegateType : f.bindType) || d] || [], s = s[2] && new RegExp("(^|\\.)" + h.join("\\.(?:.*\\.|)") + "(\\.|$)"), a = o = p.length; while (o--) c = p[o], !i && g !== c.origType || n && n.guid !== c.guid || s && !s.test(c.namespace) || r && r !== c.selector && ("**" !== r || !c.selector) || (p.splice(o, 1), c.selector && p.delegateCount--, f.remove && f.remove.call(e, c)); a && !p.length && (f.teardown && !1 !== f.teardown.call(e, h, v.handle) || ce.removeEvent(e, d, v.handle), delete u[d]) } else for (d in u) ce.event.remove(e, d + t[l], n, r, !0); ce.isEmptyObject(u) && _.remove(e, "handle events") } }, dispatch: function (e) { var t, n, r, i, o, a, s = new Array(arguments.length), u = ce.event.fix(e), l = (_.get(this, "events") || Object.create(null))[u.type] || [], c = ce.event.special[u.type] || {}; for (s[0] = u, t = 1; t < arguments.length; t++)s[t] = arguments[t]; if (u.delegateTarget = this, !c.preDispatch || !1 !== c.preDispatch.call(this, u)) { a = ce.event.handlers.call(this, u, l), t = 0; while ((i = a[t++]) && !u.isPropagationStopped()) { u.currentTarget = i.elem, n = 0; while ((o = i.handlers[n++]) && !u.isImmediatePropagationStopped()) u.rnamespace && !1 !== o.namespace && !u.rnamespace.test(o.namespace) || (u.handleObj = o, u.data = o.data, void 0 !== (r = ((ce.event.special[o.origType] || {}).handle || o.handler).apply(i.elem, s)) && !1 === (u.result = r) && (u.preventDefault(), u.stopPropagation())) } return c.postDispatch && c.postDispatch.call(this, u), u.result } }, handlers: function (e, t) { var n, r, i, o, a, s = [], u = t.delegateCount, l = e.target; if (u && l.nodeType && !("click" === e.type && 1 <= e.button)) for (; l !== this; l = l.parentNode || this)if (1 === l.nodeType && ("click" !== e.type || !0 !== l.disabled)) { for (o = [], a = {}, n = 0; n < u; n++)void 0 === a[i = (r = t[n]).selector + " "] && (a[i] = r.needsContext ? -1 < ce(i, this).index(l) : ce.find(i, this, null, [l]).length), a[i] && o.push(r); o.length && s.push({ elem: l, handlers: o }) } return l = this, u < t.length && s.push({ elem: l, handlers: t.slice(u) }), s }, addProp: function (t, e) { Object.defineProperty(ce.Event.prototype, t, { enumerable: !0, configurable: !0, get: v(e) ? function () { if (this.originalEvent) return e(this.originalEvent) } : function () { if (this.originalEvent) return this.originalEvent[t] }, set: function (e) { Object.defineProperty(this, t, { enumerable: !0, configurable: !0, writable: !0, value: e }) } }) }, fix: function (e) { return e[ce.expando] ? e : new ce.Event(e) }, special: { load: { noBubble: !0 }, click: { setup: function (e) { var t = this || e; return we.test(t.type) && t.click && fe(t, "input") && He(t, "click", !0), !1 }, trigger: function (e) { var t = this || e; return we.test(t.type) && t.click && fe(t, "input") && He(t, "click"), !0 }, _default: function (e) { var t = e.target; return we.test(t.type) && t.click && fe(t, "input") && _.get(t, "click") || fe(t, "a") } }, beforeunload: { postDispatch: function (e) { void 0 !== e.result && e.originalEvent && (e.originalEvent.returnValue = e.result) } } } }, ce.removeEvent = function (e, t, n) { e.removeEventListener && e.removeEventListener(t, n) }, ce.Event = function (e, t) { if (!(this instanceof ce.Event)) return new ce.Event(e, t); e && e.type ? (this.originalEvent = e, this.type = e.type, this.isDefaultPrevented = e.defaultPrevented || void 0 === e.defaultPrevented && !1 === e.returnValue ? Ne : qe, this.target = e.target && 3 === e.target.nodeType ? e.target.parentNode : e.target, this.currentTarget = e.currentTarget, this.relatedTarget = e.relatedTarget) : this.type = e, t && ce.extend(this, t), this.timeStamp = e && e.timeStamp || Date.now(), this[ce.expando] = !0 }, ce.Event.prototype = { constructor: ce.Event, isDefaultPrevented: qe, isPropagationStopped: qe, isImmediatePropagationStopped: qe, isSimulated: !1, preventDefault: function () { var e = this.originalEvent; this.isDefaultPrevented = Ne, e && !this.isSimulated && e.preventDefault() }, stopPropagation: function () { var e = this.originalEvent; this.isPropagationStopped = Ne, e && !this.isSimulated && e.stopPropagation() }, stopImmediatePropagation: function () { var e = this.originalEvent; this.isImmediatePropagationStopped = Ne, e && !this.isSimulated && e.stopImmediatePropagation(), this.stopPropagation() } }, ce.each({ altKey: !0, bubbles: !0, cancelable: !0, changedTouches: !0, ctrlKey: !0, detail: !0, eventPhase: !0, metaKey: !0, pageX: !0, pageY: !0, shiftKey: !0, view: !0, "char": !0, code: !0, charCode: !0, key: !0, keyCode: !0, button: !0, buttons: !0, clientX: !0, clientY: !0, offsetX: !0, offsetY: !0, pointerId: !0, pointerType: !0, screenX: !0, screenY: !0, targetTouches: !0, toElement: !0, touches: !0, which: !0 }, ce.event.addProp), ce.each({ focus: "focusin", blur: "focusout" }, function (r, i) { function o(e) { if (C.documentMode) { var t = _.get(this, "handle"), n = ce.event.fix(e); n.type = "focusin" === e.type ? "focus" : "blur", n.isSimulated = !0, t(e), n.target === n.currentTarget && t(n) } else ce.event.simulate(i, e.target, ce.event.fix(e)) } ce.event.special[r] = { setup: function () { var e; if (He(this, r, !0), !C.documentMode) return !1; (e = _.get(this, i)) || this.addEventListener(i, o), _.set(this, i, (e || 0) + 1) }, trigger: function () { return He(this, r), !0 }, teardown: function () { var e; if (!C.documentMode) return !1; (e = _.get(this, i) - 1) ? _.set(this, i, e) : (this.removeEventListener(i, o), _.remove(this, i)) }, _default: function (e) { return _.get(e.target, r) }, delegateType: i }, ce.event.special[i] = { setup: function () { var e = this.ownerDocument || this.document || this, t = C.documentMode ? this : e, n = _.get(t, i); n || (C.documentMode ? this.addEventListener(i, o) : e.addEventListener(r, o, !0)), _.set(t, i, (n || 0) + 1) }, teardown: function () { var e = this.ownerDocument || this.document || this, t = C.documentMode ? this : e, n = _.get(t, i) - 1; n ? _.set(t, i, n) : (C.documentMode ? this.removeEventListener(i, o) : e.removeEventListener(r, o, !0), _.remove(t, i)) } } }), ce.each({ mouseenter: "mouseover", mouseleave: "mouseout", pointerenter: "pointerover", pointerleave: "pointerout" }, function (e, i) { ce.event.special[e] = { delegateType: i, bindType: i, handle: function (e) { var t, n = e.relatedTarget, r = e.handleObj; return n && (n === this || ce.contains(this, n)) || (e.type = r.origType, t = r.handler.apply(this, arguments), e.type = i), t } } }), ce.fn.extend({ on: function (e, t, n, r) { return Le(this, e, t, n, r) }, one: function (e, t, n, r) { return Le(this, e, t, n, r, 1) }, off: function (e, t, n) { var r, i; if (e && e.preventDefault && e.handleObj) return r = e.handleObj, ce(e.delegateTarget).off(r.namespace ? r.origType + "." + r.namespace : r.origType, r.selector, r.handler), this; if ("object" == typeof e) { for (i in e) this.off(i, t, e[i]); return this } return !1 !== t && "function" != typeof t || (n = t, t = void 0), !1 === n && (n = qe), this.each(function () { ce.event.remove(this, e, n, t) }) } }); var Oe = /<script|<style|<link/i, Pe = /checked\s*(?:[^=]|=\s*.checked.)/i, Me = /^\s*<!\[CDATA\[|\]\]>\s*$/g; function Re(e, t) { return fe(e, "table") && fe(11 !== t.nodeType ? t : t.firstChild, "tr") && ce(e).children("tbody")[0] || e } function Ie(e) { return e.type = (null !== e.getAttribute("type")) + "/" + e.type, e } function We(e) { return "true/" === (e.type || "").slice(0, 5) ? e.type = e.type.slice(5) : e.removeAttribute("type"), e } function Fe(e, t) { var n, r, i, o, a, s; if (1 === t.nodeType) { if (_.hasData(e) && (s = _.get(e).events)) for (i in _.remove(t, "handle events"), s) for (n = 0, r = s[i].length; n < r; n++)ce.event.add(t, i, s[i][n]); z.hasData(e) && (o = z.access(e), a = ce.extend({}, o), z.set(t, a)) } } function $e(n, r, i, o) { r = g(r); var e, t, a, s, u, l, c = 0, f = n.length, p = f - 1, d = r[0], h = v(d); if (h || 1 < f && "string" == typeof d && !le.checkClone && Pe.test(d)) return n.each(function (e) { var t = n.eq(e); h && (r[0] = d.call(this, e, t.html())), $e(t, r, i, o) }); if (f && (t = (e = Ae(r, n[0].ownerDocument, !1, n, o)).firstChild, 1 === e.childNodes.length && (e = t), t || o)) { for (s = (a = ce.map(Se(e, "script"), Ie)).length; c < f; c++)u = e, c !== p && (u = ce.clone(u, !0, !0), s && ce.merge(a, Se(u, "script"))), i.call(n[c], u, c); if (s) for (l = a[a.length - 1].ownerDocument, ce.map(a, We), c = 0; c < s; c++)u = a[c], Ce.test(u.type || "") && !_.access(u, "globalEval") && ce.contains(l, u) && (u.src && "module" !== (u.type || "").toLowerCase() ? ce._evalUrl && !u.noModule && ce._evalUrl(u.src, { nonce: u.nonce || u.getAttribute("nonce") }, l) : m(u.textContent.replace(Me, ""), u, l)) } return n } function Be(e, t, n) { for (var r, i = t ? ce.filter(t, e) : e, o = 0; null != (r = i[o]); o++)n || 1 !== r.nodeType || ce.cleanData(Se(r)), r.parentNode && (n && K(r) && Ee(Se(r, "script")), r.parentNode.removeChild(r)); return e } ce.extend({ htmlPrefilter: function (e) { return e }, clone: function (e, t, n) { var r, i, o, a, s, u, l, c = e.cloneNode(!0), f = K(e); if (!(le.noCloneChecked || 1 !== e.nodeType && 11 !== e.nodeType || ce.isXMLDoc(e))) for (a = Se(c), r = 0, i = (o = Se(e)).length; r < i; r++)s = o[r], u = a[r], void 0, "input" === (l = u.nodeName.toLowerCase()) && we.test(s.type) ? u.checked = s.checked : "input" !== l && "textarea" !== l || (u.defaultValue = s.defaultValue); if (t) if (n) for (o = o || Se(e), a = a || Se(c), r = 0, i = o.length; r < i; r++)Fe(o[r], a[r]); else Fe(e, c); return 0 < (a = Se(c, "script")).length && Ee(a, !f && Se(e, "script")), c }, cleanData: function (e) { for (var t, n, r, i = ce.event.special, o = 0; void 0 !== (n = e[o]); o++)if ($(n)) { if (t = n[_.expando]) { if (t.events) for (r in t.events) i[r] ? ce.event.remove(n, r) : ce.removeEvent(n, r, t.handle); n[_.expando] = void 0 } n[z.expando] && (n[z.expando] = void 0) } } }), ce.fn.extend({ detach: function (e) { return Be(this, e, !0) }, remove: function (e) { return Be(this, e) }, text: function (e) { return M(this, function (e) { return void 0 === e ? ce.text(this) : this.empty().each(function () { 1 !== this.nodeType && 11 !== this.nodeType && 9 !== this.nodeType || (this.textContent = e) }) }, null, e, arguments.length) }, append: function () { return $e(this, arguments, function (e) { 1 !== this.nodeType && 11 !== this.nodeType && 9 !== this.nodeType || Re(this, e).appendChild(e) }) }, prepend: function () { return $e(this, arguments, function (e) { if (1 === this.nodeType || 11 === this.nodeType || 9 === this.nodeType) { var t = Re(this, e); t.insertBefore(e, t.firstChild) } }) }, before: function () { return $e(this, arguments, function (e) { this.parentNode && this.parentNode.insertBefore(e, this) }) }, after: function () { return $e(this, arguments, function (e) { this.parentNode && this.parentNode.insertBefore(e, this.nextSibling) }) }, empty: function () { for (var e, t = 0; null != (e = this[t]); t++)1 === e.nodeType && (ce.cleanData(Se(e, !1)), e.textContent = ""); return this }, clone: function (e, t) { return e = null != e && e, t = null == t ? e : t, this.map(function () { return ce.clone(this, e, t) }) }, html: function (e) { return M(this, function (e) { var t = this[0] || {}, n = 0, r = this.length; if (void 0 === e && 1 === t.nodeType) return t.innerHTML; if ("string" == typeof e && !Oe.test(e) && !ke[(Te.exec(e) || ["", ""])[1].toLowerCase()]) { e = ce.htmlPrefilter(e); try { for (; n < r; n++)1 === (t = this[n] || {}).nodeType && (ce.cleanData(Se(t, !1)), t.innerHTML = e); t = 0 } catch (e) { } } t && this.empty().append(e) }, null, e, arguments.length) }, replaceWith: function () { var n = []; return $e(this, arguments, function (e) { var t = this.parentNode; ce.inArray(this, n) < 0 && (ce.cleanData(Se(this)), t && t.replaceChild(e, this)) }, n) } }), ce.each({ appendTo: "append", prependTo: "prepend", insertBefore: "before", insertAfter: "after", replaceAll: "replaceWith" }, function (e, a) { ce.fn[e] = function (e) { for (var t, n = [], r = ce(e), i = r.length - 1, o = 0; o <= i; o++)t = o === i ? this : this.clone(!0), ce(r[o])[a](t), s.apply(n, t.get()); return this.pushStack(n) } }); var _e = new RegExp("^(" + G + ")(?!px)[a-z%]+$", "i"), ze = /^--/, Xe = function (e) { var t = e.ownerDocument.defaultView; return t && t.opener || (t = ie), t.getComputedStyle(e) }, Ue = function (e, t, n) { var r, i, o = {}; for (i in t) o[i] = e.style[i], e.style[i] = t[i]; for (i in r = n.call(e), t) e.style[i] = o[i]; return r }, Ve = new RegExp(Q.join("|"), "i"); function Ge(e, t, n) { var r, i, o, a, s = ze.test(t), u = e.style; return (n = n || Xe(e)) && (a = n.getPropertyValue(t) || n[t], s && a && (a = a.replace(ve, "$1") || void 0), "" !== a || K(e) || (a = ce.style(e, t)), !le.pixelBoxStyles() && _e.test(a) && Ve.test(t) && (r = u.width, i = u.minWidth, o = u.maxWidth, u.minWidth = u.maxWidth = u.width = a, a = n.width, u.width = r, u.minWidth = i, u.maxWidth = o)), void 0 !== a ? a + "" : a } function Ye(e, t) { return { get: function () { if (!e()) return (this.get = t).apply(this, arguments); delete this.get } } } !function () { function e() { if (l) { u.style.cssText = "position:absolute;left:-11111px;width:60px;margin-top:1px;padding:0;border:0", l.style.cssText = "position:relative;display:block;box-sizing:border-box;overflow:scroll;margin:auto;border:1px;padding:1px;width:60%;top:1%", J.appendChild(u).appendChild(l); var e = ie.getComputedStyle(l); n = "1%" !== e.top, s = 12 === t(e.marginLeft), l.style.right = "60%", o = 36 === t(e.right), r = 36 === t(e.width), l.style.position = "absolute", i = 12 === t(l.offsetWidth / 3), J.removeChild(u), l = null } } function t(e) { return Math.round(parseFloat(e)) } var n, r, i, o, a, s, u = C.createElement("div"), l = C.createElement("div"); l.style && (l.style.backgroundClip = "content-box", l.cloneNode(!0).style.backgroundClip = "", le.clearCloneStyle = "content-box" === l.style.backgroundClip, ce.extend(le, { boxSizingReliable: function () { return e(), r }, pixelBoxStyles: function () { return e(), o }, pixelPosition: function () { return e(), n }, reliableMarginLeft: function () { return e(), s }, scrollboxSize: function () { return e(), i }, reliableTrDimensions: function () { var e, t, n, r; return null == a && (e = C.createElement("table"), t = C.createElement("tr"), n = C.createElement("div"), e.style.cssText = "position:absolute;left:-11111px;border-collapse:separate", t.style.cssText = "box-sizing:content-box;border:1px solid", t.style.height = "1px", n.style.height = "9px", n.style.display = "block", J.appendChild(e).appendChild(t).appendChild(n), r = ie.getComputedStyle(t), a = parseInt(r.height, 10) + parseInt(r.borderTopWidth, 10) + parseInt(r.borderBottomWidth, 10) === t.offsetHeight, J.removeChild(e)), a } })) }(); var Qe = ["Webkit", "Moz", "ms"], Je = C.createElement("div").style, Ke = {}; function Ze(e) { var t = ce.cssProps[e] || Ke[e]; return t || (e in Je ? e : Ke[e] = function (e) { var t = e[0].toUpperCase() + e.slice(1), n = Qe.length; while (n--) if ((e = Qe[n] + t) in Je) return e }(e) || e) } var et = /^(none|table(?!-c[ea]).+)/, tt = { position: "absolute", visibility: "hidden", display: "block" }, nt = { letterSpacing: "0", fontWeight: "400" }; function rt(e, t, n) { var r = Y.exec(t); return r ? Math.max(0, r[2] - (n || 0)) + (r[3] || "px") : t } function it(e, t, n, r, i, o) { var a = "width" === t ? 1 : 0, s = 0, u = 0, l = 0; if (n === (r ? "border" : "content")) return 0; for (; a < 4; a += 2)"margin" === n && (l += ce.css(e, n + Q[a], !0, i)), r ? ("content" === n && (u -= ce.css(e, "padding" + Q[a], !0, i)), "margin" !== n && (u -= ce.css(e, "border" + Q[a] + "Width", !0, i))) : (u += ce.css(e, "padding" + Q[a], !0, i), "padding" !== n ? u += ce.css(e, "border" + Q[a] + "Width", !0, i) : s += ce.css(e, "border" + Q[a] + "Width", !0, i)); return !r && 0 <= o && (u += Math.max(0, Math.ceil(e["offset" + t[0].toUpperCase() + t.slice(1)] - o - u - s - .5)) || 0), u + l } function ot(e, t, n) { var r = Xe(e), i = (!le.boxSizingReliable() || n) && "border-box" === ce.css(e, "boxSizing", !1, r), o = i, a = Ge(e, t, r), s = "offset" + t[0].toUpperCase() + t.slice(1); if (_e.test(a)) { if (!n) return a; a = "auto" } return (!le.boxSizingReliable() && i || !le.reliableTrDimensions() && fe(e, "tr") || "auto" === a || !parseFloat(a) && "inline" === ce.css(e, "display", !1, r)) && e.getClientRects().length && (i = "border-box" === ce.css(e, "boxSizing", !1, r), (o = s in e) && (a = e[s])), (a = parseFloat(a) || 0) + it(e, t, n || (i ? "border" : "content"), o, r, a) + "px" } function at(e, t, n, r, i) { return new at.prototype.init(e, t, n, r, i) } ce.extend({ cssHooks: { opacity: { get: function (e, t) { if (t) { var n = Ge(e, "opacity"); return "" === n ? "1" : n } } } }, cssNumber: { animationIterationCount: !0, aspectRatio: !0, borderImageSlice: !0, columnCount: !0, flexGrow: !0, flexShrink: !0, fontWeight: !0, gridArea: !0, gridColumn: !0, gridColumnEnd: !0, gridColumnStart: !0, gridRow: !0, gridRowEnd: !0, gridRowStart: !0, lineHeight: !0, opacity: !0, order: !0, orphans: !0, scale: !0, widows: !0, zIndex: !0, zoom: !0, fillOpacity: !0, floodOpacity: !0, stopOpacity: !0, strokeMiterlimit: !0, strokeOpacity: !0 }, cssProps: {}, style: function (e, t, n, r) { if (e && 3 !== e.nodeType && 8 !== e.nodeType && e.style) { var i, o, a, s = F(t), u = ze.test(t), l = e.style; if (u || (t = Ze(s)), a = ce.cssHooks[t] || ce.cssHooks[s], void 0 === n) return a && "get" in a && void 0 !== (i = a.get(e, !1, r)) ? i : l[t]; "string" === (o = typeof n) && (i = Y.exec(n)) && i[1] && (n = te(e, t, i), o = "number"), null != n && n == n && ("number" !== o || u || (n += i && i[3] || (ce.cssNumber[s] ? "" : "px")), le.clearCloneStyle || "" !== n || 0 !== t.indexOf("background") || (l[t] = "inherit"), a && "set" in a && void 0 === (n = a.set(e, n, r)) || (u ? l.setProperty(t, n) : l[t] = n)) } }, css: function (e, t, n, r) { var i, o, a, s = F(t); return ze.test(t) || (t = Ze(s)), (a = ce.cssHooks[t] || ce.cssHooks[s]) && "get" in a && (i = a.get(e, !0, n)), void 0 === i && (i = Ge(e, t, r)), "normal" === i && t in nt && (i = nt[t]), "" === n || n ? (o = parseFloat(i), !0 === n || isFinite(o) ? o || 0 : i) : i } }), ce.each(["height", "width"], function (e, u) { ce.cssHooks[u] = { get: function (e, t, n) { if (t) return !et.test(ce.css(e, "display")) || e.getClientRects().length && e.getBoundingClientRect().width ? ot(e, u, n) : Ue(e, tt, function () { return ot(e, u, n) }) }, set: function (e, t, n) { var r, i = Xe(e), o = !le.scrollboxSize() && "absolute" === i.position, a = (o || n) && "border-box" === ce.css(e, "boxSizing", !1, i), s = n ? it(e, u, n, a, i) : 0; return a && o && (s -= Math.ceil(e["offset" + u[0].toUpperCase() + u.slice(1)] - parseFloat(i[u]) - it(e, u, "border", !1, i) - .5)), s && (r = Y.exec(t)) && "px" !== (r[3] || "px") && (e.style[u] = t, t = ce.css(e, u)), rt(0, t, s) } } }), ce.cssHooks.marginLeft = Ye(le.reliableMarginLeft, function (e, t) { if (t) return (parseFloat(Ge(e, "marginLeft")) || e.getBoundingClientRect().left - Ue(e, { marginLeft: 0 }, function () { return e.getBoundingClientRect().left })) + "px" }), ce.each({ margin: "", padding: "", border: "Width" }, function (i, o) { ce.cssHooks[i + o] = { expand: function (e) { for (var t = 0, n = {}, r = "string" == typeof e ? e.split(" ") : [e]; t < 4; t++)n[i + Q[t] + o] = r[t] || r[t - 2] || r[0]; return n } }, "margin" !== i && (ce.cssHooks[i + o].set = rt) }), ce.fn.extend({ css: function (e, t) { return M(this, function (e, t, n) { var r, i, o = {}, a = 0; if (Array.isArray(t)) { for (r = Xe(e), i = t.length; a < i; a++)o[t[a]] = ce.css(e, t[a], !1, r); return o } return void 0 !== n ? ce.style(e, t, n) : ce.css(e, t) }, e, t, 1 < arguments.length) } }), ((ce.Tween = at).prototype = { constructor: at, init: function (e, t, n, r, i, o) { this.elem = e, this.prop = n, this.easing = i || ce.easing._default, this.options = t, this.start = this.now = this.cur(), this.end = r, this.unit = o || (ce.cssNumber[n] ? "" : "px") }, cur: function () { var e = at.propHooks[this.prop]; return e && e.get ? e.get(this) : at.propHooks._default.get(this) }, run: function (e) { var t, n = at.propHooks[this.prop]; return this.options.duration ? this.pos = t = ce.easing[this.easing](e, this.options.duration * e, 0, 1, this.options.duration) : this.pos = t = e, this.now = (this.end - this.start) * t + this.start, this.options.step && this.options.step.call(this.elem, this.now, this), n && n.set ? n.set(this) : at.propHooks._default.set(this), this } }).init.prototype = at.prototype, (at.propHooks = { _default: { get: function (e) { var t; return 1 !== e.elem.nodeType || null != e.elem[e.prop] && null == e.elem.style[e.prop] ? e.elem[e.prop] : (t = ce.css(e.elem, e.prop, "")) && "auto" !== t ? t : 0 }, set: function (e) { ce.fx.step[e.prop] ? ce.fx.step[e.prop](e) : 1 !== e.elem.nodeType || !ce.cssHooks[e.prop] && null == e.elem.style[Ze(e.prop)] ? e.elem[e.prop] = e.now : ce.style(e.elem, e.prop, e.now + e.unit) } } }).scrollTop = at.propHooks.scrollLeft = { set: function (e) { e.elem.nodeType && e.elem.parentNode && (e.elem[e.prop] = e.now) } }, ce.easing = { linear: function (e) { return e }, swing: function (e) { return .5 - Math.cos(e * Math.PI) / 2 }, _default: "swing" }, ce.fx = at.prototype.init, ce.fx.step = {}; var st, ut, lt, ct, ft = /^(?:toggle|show|hide)$/, pt = /queueHooks$/; function dt() { ut && (!1 === C.hidden && ie.requestAnimationFrame ? ie.requestAnimationFrame(dt) : ie.setTimeout(dt, ce.fx.interval), ce.fx.tick()) } function ht() { return ie.setTimeout(function () { st = void 0 }), st = Date.now() } function gt(e, t) { var n, r = 0, i = { height: e }; for (t = t ? 1 : 0; r < 4; r += 2 - t)i["margin" + (n = Q[r])] = i["padding" + n] = e; return t && (i.opacity = i.width = e), i } function vt(e, t, n) { for (var r, i = (yt.tweeners[t] || []).concat(yt.tweeners["*"]), o = 0, a = i.length; o < a; o++)if (r = i[o].call(n, t, e)) return r } function yt(o, e, t) { var n, a, r = 0, i = yt.prefilters.length, s = ce.Deferred().always(function () { delete u.elem }), u = function () { if (a) return !1; for (var e = st || ht(), t = Math.max(0, l.startTime + l.duration - e), n = 1 - (t / l.duration || 0), r = 0, i = l.tweens.length; r < i; r++)l.tweens[r].run(n); return s.notifyWith(o, [l, n, t]), n < 1 && i ? t : (i || s.notifyWith(o, [l, 1, 0]), s.resolveWith(o, [l]), !1) }, l = s.promise({ elem: o, props: ce.extend({}, e), opts: ce.extend(!0, { specialEasing: {}, easing: ce.easing._default }, t), originalProperties: e, originalOptions: t, startTime: st || ht(), duration: t.duration, tweens: [], createTween: function (e, t) { var n = ce.Tween(o, l.opts, e, t, l.opts.specialEasing[e] || l.opts.easing); return l.tweens.push(n), n }, stop: function (e) { var t = 0, n = e ? l.tweens.length : 0; if (a) return this; for (a = !0; t < n; t++)l.tweens[t].run(1); return e ? (s.notifyWith(o, [l, 1, 0]), s.resolveWith(o, [l, e])) : s.rejectWith(o, [l, e]), this } }), c = l.props; for (!function (e, t) { var n, r, i, o, a; for (n in e) if (i = t[r = F(n)], o = e[n], Array.isArray(o) && (i = o[1], o = e[n] = o[0]), n !== r && (e[r] = o, delete e[n]), (a = ce.cssHooks[r]) && "expand" in a) for (n in o = a.expand(o), delete e[r], o) n in e || (e[n] = o[n], t[n] = i); else t[r] = i }(c, l.opts.specialEasing); r < i; r++)if (n = yt.prefilters[r].call(l, o, c, l.opts)) return v(n.stop) && (ce._queueHooks(l.elem, l.opts.queue).stop = n.stop.bind(n)), n; return ce.map(c, vt, l), v(l.opts.start) && l.opts.start.call(o, l), l.progress(l.opts.progress).done(l.opts.done, l.opts.complete).fail(l.opts.fail).always(l.opts.always), ce.fx.timer(ce.extend(u, { elem: o, anim: l, queue: l.opts.queue })), l } ce.Animation = ce.extend(yt, { tweeners: { "*": [function (e, t) { var n = this.createTween(e, t); return te(n.elem, e, Y.exec(t), n), n }] }, tweener: function (e, t) { v(e) ? (t = e, e = ["*"]) : e = e.match(D); for (var n, r = 0, i = e.length; r < i; r++)n = e[r], yt.tweeners[n] = yt.tweeners[n] || [], yt.tweeners[n].unshift(t) }, prefilters: [function (e, t, n) { var r, i, o, a, s, u, l, c, f = "width" in t || "height" in t, p = this, d = {}, h = e.style, g = e.nodeType && ee(e), v = _.get(e, "fxshow"); for (r in n.queue || (null == (a = ce._queueHooks(e, "fx")).unqueued && (a.unqueued = 0, s = a.empty.fire, a.empty.fire = function () { a.unqueued || s() }), a.unqueued++, p.always(function () { p.always(function () { a.unqueued--, ce.queue(e, "fx").length || a.empty.fire() }) })), t) if (i = t[r], ft.test(i)) { if (delete t[r], o = o || "toggle" === i, i === (g ? "hide" : "show")) { if ("show" !== i || !v || void 0 === v[r]) continue; g = !0 } d[r] = v && v[r] || ce.style(e, r) } if ((u = !ce.isEmptyObject(t)) || !ce.isEmptyObject(d)) for (r in f && 1 === e.nodeType && (n.overflow = [h.overflow, h.overflowX, h.overflowY], null == (l = v && v.display) && (l = _.get(e, "display")), "none" === (c = ce.css(e, "display")) && (l ? c = l : (re([e], !0), l = e.style.display || l, c = ce.css(e, "display"), re([e]))), ("inline" === c || "inline-block" === c && null != l) && "none" === ce.css(e, "float") && (u || (p.done(function () { h.display = l }), null == l && (c = h.display, l = "none" === c ? "" : c)), h.display = "inline-block")), n.overflow && (h.overflow = "hidden", p.always(function () { h.overflow = n.overflow[0], h.overflowX = n.overflow[1], h.overflowY = n.overflow[2] })), u = !1, d) u || (v ? "hidden" in v && (g = v.hidden) : v = _.access(e, "fxshow", { display: l }), o && (v.hidden = !g), g && re([e], !0), p.done(function () { for (r in g || re([e]), _.remove(e, "fxshow"), d) ce.style(e, r, d[r]) })), u = vt(g ? v[r] : 0, r, p), r in v || (v[r] = u.start, g && (u.end = u.start, u.start = 0)) }], prefilter: function (e, t) { t ? yt.prefilters.unshift(e) : yt.prefilters.push(e) } }), ce.speed = function (e, t, n) { var r = e && "object" == typeof e ? ce.extend({}, e) : { complete: n || !n && t || v(e) && e, duration: e, easing: n && t || t && !v(t) && t }; return ce.fx.off ? r.duration = 0 : "number" != typeof r.duration && (r.duration in ce.fx.speeds ? r.duration = ce.fx.speeds[r.duration] : r.duration = ce.fx.speeds._default), null != r.queue && !0 !== r.queue || (r.queue = "fx"), r.old = r.complete, r.complete = function () { v(r.old) && r.old.call(this), r.queue && ce.dequeue(this, r.queue) }, r }, ce.fn.extend({ fadeTo: function (e, t, n, r) { return this.filter(ee).css("opacity", 0).show().end().animate({ opacity: t }, e, n, r) }, animate: function (t, e, n, r) { var i = ce.isEmptyObject(t), o = ce.speed(e, n, r), a = function () { var e = yt(this, ce.extend({}, t), o); (i || _.get(this, "finish")) && e.stop(!0) }; return a.finish = a, i || !1 === o.queue ? this.each(a) : this.queue(o.queue, a) }, stop: function (i, e, o) { var a = function (e) { var t = e.stop; delete e.stop, t(o) }; return "string" != typeof i && (o = e, e = i, i = void 0), e && this.queue(i || "fx", []), this.each(function () { var e = !0, t = null != i && i + "queueHooks", n = ce.timers, r = _.get(this); if (t) r[t] && r[t].stop && a(r[t]); else for (t in r) r[t] && r[t].stop && pt.test(t) && a(r[t]); for (t = n.length; t--;)n[t].elem !== this || null != i && n[t].queue !== i || (n[t].anim.stop(o), e = !1, n.splice(t, 1)); !e && o || ce.dequeue(this, i) }) }, finish: function (a) { return !1 !== a && (a = a || "fx"), this.each(function () { var e, t = _.get(this), n = t[a + "queue"], r = t[a + "queueHooks"], i = ce.timers, o = n ? n.length : 0; for (t.finish = !0, ce.queue(this, a, []), r && r.stop && r.stop.call(this, !0), e = i.length; e--;)i[e].elem === this && i[e].queue === a && (i[e].anim.stop(!0), i.splice(e, 1)); for (e = 0; e < o; e++)n[e] && n[e].finish && n[e].finish.call(this); delete t.finish }) } }), ce.each(["toggle", "show", "hide"], function (e, r) { var i = ce.fn[r]; ce.fn[r] = function (e, t, n) { return null == e || "boolean" == typeof e ? i.apply(this, arguments) : this.animate(gt(r, !0), e, t, n) } }), ce.each({ slideDown: gt("show"), slideUp: gt("hide"), slideToggle: gt("toggle"), fadeIn: { opacity: "show" }, fadeOut: { opacity: "hide" }, fadeToggle: { opacity: "toggle" } }, function (e, r) { ce.fn[e] = function (e, t, n) { return this.animate(r, e, t, n) } }), ce.timers = [], ce.fx.tick = function () { var e, t = 0, n = ce.timers; for (st = Date.now(); t < n.length; t++)(e = n[t])() || n[t] !== e || n.splice(t--, 1); n.length || ce.fx.stop(), st = void 0 }, ce.fx.timer = function (e) { ce.timers.push(e), ce.fx.start() }, ce.fx.interval = 13, ce.fx.start = function () { ut || (ut = !0, dt()) }, ce.fx.stop = function () { ut = null }, ce.fx.speeds = { slow: 600, fast: 200, _default: 400 }, ce.fn.delay = function (r, e) { return r = ce.fx && ce.fx.speeds[r] || r, e = e || "fx", this.queue(e, function (e, t) { var n = ie.setTimeout(e, r); t.stop = function () { ie.clearTimeout(n) } }) }, lt = C.createElement("input"), ct = C.createElement("select").appendChild(C.createElement("option")), lt.type = "checkbox", le.checkOn = "" !== lt.value, le.optSelected = ct.selected, (lt = C.createElement("input")).value = "t", lt.type = "radio", le.radioValue = "t" === lt.value; var mt, xt = ce.expr.attrHandle; ce.fn.extend({ attr: function (e, t) { return M(this, ce.attr, e, t, 1 < arguments.length) }, removeAttr: function (e) { return this.each(function () { ce.removeAttr(this, e) }) } }), ce.extend({ attr: function (e, t, n) { var r, i, o = e.nodeType; if (3 !== o && 8 !== o && 2 !== o) return "undefined" == typeof e.getAttribute ? ce.prop(e, t, n) : (1 === o && ce.isXMLDoc(e) || (i = ce.attrHooks[t.toLowerCase()] || (ce.expr.match.bool.test(t) ? mt : void 0)), void 0 !== n ? null === n ? void ce.removeAttr(e, t) : i && "set" in i && void 0 !== (r = i.set(e, n, t)) ? r : (e.setAttribute(t, n + ""), n) : i && "get" in i && null !== (r = i.get(e, t)) ? r : null == (r = ce.find.attr(e, t)) ? void 0 : r) }, attrHooks: { type: { set: function (e, t) { if (!le.radioValue && "radio" === t && fe(e, "input")) { var n = e.value; return e.setAttribute("type", t), n && (e.value = n), t } } } }, removeAttr: function (e, t) { var n, r = 0, i = t && t.match(D); if (i && 1 === e.nodeType) while (n = i[r++]) e.removeAttribute(n) } }), mt = { set: function (e, t, n) { return !1 === t ? ce.removeAttr(e, n) : e.setAttribute(n, n), n } }, ce.each(ce.expr.match.bool.source.match(/\w+/g), function (e, t) { var a = xt[t] || ce.find.attr; xt[t] = function (e, t, n) { var r, i, o = t.toLowerCase(); return n || (i = xt[o], xt[o] = r, r = null != a(e, t, n) ? o : null, xt[o] = i), r } }); var bt = /^(?:input|select|textarea|button)$/i, wt = /^(?:a|area)$/i; function Tt(e) { return (e.match(D) || []).join(" ") } function Ct(e) { return e.getAttribute && e.getAttribute("class") || "" } function kt(e) { return Array.isArray(e) ? e : "string" == typeof e && e.match(D) || [] } ce.fn.extend({ prop: function (e, t) { return M(this, ce.prop, e, t, 1 < arguments.length) }, removeProp: function (e) { return this.each(function () { delete this[ce.propFix[e] || e] }) } }), ce.extend({ prop: function (e, t, n) { var r, i, o = e.nodeType; if (3 !== o && 8 !== o && 2 !== o) return 1 === o && ce.isXMLDoc(e) || (t = ce.propFix[t] || t, i = ce.propHooks[t]), void 0 !== n ? i && "set" in i && void 0 !== (r = i.set(e, n, t)) ? r : e[t] = n : i && "get" in i && null !== (r = i.get(e, t)) ? r : e[t] }, propHooks: { tabIndex: { get: function (e) { var t = ce.find.attr(e, "tabindex"); return t ? parseInt(t, 10) : bt.test(e.nodeName) || wt.test(e.nodeName) && e.href ? 0 : -1 } } }, propFix: { "for": "htmlFor", "class": "className" } }), le.optSelected || (ce.propHooks.selected = { get: function (e) { var t = e.parentNode; return t && t.parentNode && t.parentNode.selectedIndex, null }, set: function (e) { var t = e.parentNode; t && (t.selectedIndex, t.parentNode && t.parentNode.selectedIndex) } }), ce.each(["tabIndex", "readOnly", "maxLength", "cellSpacing", "cellPadding", "rowSpan", "colSpan", "useMap", "frameBorder", "contentEditable"], function () { ce.propFix[this.toLowerCase()] = this }), ce.fn.extend({ addClass: function (t) { var e, n, r, i, o, a; return v(t) ? this.each(function (e) { ce(this).addClass(t.call(this, e, Ct(this))) }) : (e = kt(t)).length ? this.each(function () { if (r = Ct(this), n = 1 === this.nodeType && " " + Tt(r) + " ") { for (o = 0; o < e.length; o++)i = e[o], n.indexOf(" " + i + " ") < 0 && (n += i + " "); a = Tt(n), r !== a && this.setAttribute("class", a) } }) : this }, removeClass: function (t) { var e, n, r, i, o, a; return v(t) ? this.each(function (e) { ce(this).removeClass(t.call(this, e, Ct(this))) }) : arguments.length ? (e = kt(t)).length ? this.each(function () { if (r = Ct(this), n = 1 === this.nodeType && " " + Tt(r) + " ") { for (o = 0; o < e.length; o++) { i = e[o]; while (-1 < n.indexOf(" " + i + " ")) n = n.replace(" " + i + " ", " ") } a = Tt(n), r !== a && this.setAttribute("class", a) } }) : this : this.attr("class", "") }, toggleClass: function (t, n) { var e, r, i, o, a = typeof t, s = "string" === a || Array.isArray(t); return v(t) ? this.each(function (e) { ce(this).toggleClass(t.call(this, e, Ct(this), n), n) }) : "boolean" == typeof n && s ? n ? this.addClass(t) : this.removeClass(t) : (e = kt(t), this.each(function () { if (s) for (o = ce(this), i = 0; i < e.length; i++)r = e[i], o.hasClass(r) ? o.removeClass(r) : o.addClass(r); else void 0 !== t && "boolean" !== a || ((r = Ct(this)) && _.set(this, "__className__", r), this.setAttribute && this.setAttribute("class", r || !1 === t ? "" : _.get(this, "__className__") || "")) })) }, hasClass: function (e) { var t, n, r = 0; t = " " + e + " "; while (n = this[r++]) if (1 === n.nodeType && -1 < (" " + Tt(Ct(n)) + " ").indexOf(t)) return !0; return !1 } }); var St = /\r/g; ce.fn.extend({ val: function (n) { var r, e, i, t = this[0]; return arguments.length ? (i = v(n), this.each(function (e) { var t; 1 === this.nodeType && (null == (t = i ? n.call(this, e, ce(this).val()) : n) ? t = "" : "number" == typeof t ? t += "" : Array.isArray(t) && (t = ce.map(t, function (e) { return null == e ? "" : e + "" })), (r = ce.valHooks[this.type] || ce.valHooks[this.nodeName.toLowerCase()]) && "set" in r && void 0 !== r.set(this, t, "value") || (this.value = t)) })) : t ? (r = ce.valHooks[t.type] || ce.valHooks[t.nodeName.toLowerCase()]) && "get" in r && void 0 !== (e = r.get(t, "value")) ? e : "string" == typeof (e = t.value) ? e.replace(St, "") : null == e ? "" : e : void 0 } }), ce.extend({ valHooks: { option: { get: function (e) { var t = ce.find.attr(e, "value"); return null != t ? t : Tt(ce.text(e)) } }, select: { get: function (e) { var t, n, r, i = e.options, o = e.selectedIndex, a = "select-one" === e.type, s = a ? null : [], u = a ? o + 1 : i.length; for (r = o < 0 ? u : a ? o : 0; r < u; r++)if (((n = i[r]).selected || r === o) && !n.disabled && (!n.parentNode.disabled || !fe(n.parentNode, "optgroup"))) { if (t = ce(n).val(), a) return t; s.push(t) } return s }, set: function (e, t) { var n, r, i = e.options, o = ce.makeArray(t), a = i.length; while (a--) ((r = i[a]).selected = -1 < ce.inArray(ce.valHooks.option.get(r), o)) && (n = !0); return n || (e.selectedIndex = -1), o } } } }), ce.each(["radio", "checkbox"], function () { ce.valHooks[this] = { set: function (e, t) { if (Array.isArray(t)) return e.checked = -1 < ce.inArray(ce(e).val(), t) } }, le.checkOn || (ce.valHooks[this].get = function (e) { return null === e.getAttribute("value") ? "on" : e.value }) }); var Et = ie.location, jt = { guid: Date.now() }, At = /\?/; ce.parseXML = function (e) { var t, n; if (!e || "string" != typeof e) return null; try { t = (new ie.DOMParser).parseFromString(e, "text/xml") } catch (e) { } return n = t && t.getElementsByTagName("parsererror")[0], t && !n || ce.error("Invalid XML: " + (n ? ce.map(n.childNodes, function (e) { return e.textContent }).join("\n") : e)), t }; var Dt = /^(?:focusinfocus|focusoutblur)$/, Nt = function (e) { e.stopPropagation() }; ce.extend(ce.event, { trigger: function (e, t, n, r) { var i, o, a, s, u, l, c, f, p = [n || C], d = ue.call(e, "type") ? e.type : e, h = ue.call(e, "namespace") ? e.namespace.split(".") : []; if (o = f = a = n = n || C, 3 !== n.nodeType && 8 !== n.nodeType && !Dt.test(d + ce.event.triggered) && (-1 < d.indexOf(".") && (d = (h = d.split(".")).shift(), h.sort()), u = d.indexOf(":") < 0 && "on" + d, (e = e[ce.expando] ? e : new ce.Event(d, "object" == typeof e && e)).isTrigger = r ? 2 : 3, e.namespace = h.join("."), e.rnamespace = e.namespace ? new RegExp("(^|\\.)" + h.join("\\.(?:.*\\.|)") + "(\\.|$)") : null, e.result = void 0, e.target || (e.target = n), t = null == t ? [e] : ce.makeArray(t, [e]), c = ce.event.special[d] || {}, r || !c.trigger || !1 !== c.trigger.apply(n, t))) { if (!r && !c.noBubble && !y(n)) { for (s = c.delegateType || d, Dt.test(s + d) || (o = o.parentNode); o; o = o.parentNode)p.push(o), a = o; a === (n.ownerDocument || C) && p.push(a.defaultView || a.parentWindow || ie) } i = 0; while ((o = p[i++]) && !e.isPropagationStopped()) f = o, e.type = 1 < i ? s : c.bindType || d, (l = (_.get(o, "events") || Object.create(null))[e.type] && _.get(o, "handle")) && l.apply(o, t), (l = u && o[u]) && l.apply && $(o) && (e.result = l.apply(o, t), !1 === e.result && e.preventDefault()); return e.type = d, r || e.isDefaultPrevented() || c._default && !1 !== c._default.apply(p.pop(), t) || !$(n) || u && v(n[d]) && !y(n) && ((a = n[u]) && (n[u] = null), ce.event.triggered = d, e.isPropagationStopped() && f.addEventListener(d, Nt), n[d](), e.isPropagationStopped() && f.removeEventListener(d, Nt), ce.event.triggered = void 0, a && (n[u] = a)), e.result } }, simulate: function (e, t, n) { var r = ce.extend(new ce.Event, n, { type: e, isSimulated: !0 }); ce.event.trigger(r, null, t) } }), ce.fn.extend({ trigger: function (e, t) { return this.each(function () { ce.event.trigger(e, t, this) }) }, triggerHandler: function (e, t) { var n = this[0]; if (n) return ce.event.trigger(e, t, n, !0) } }); var qt = /\[\]$/, Lt = /\r?\n/g, Ht = /^(?:submit|button|image|reset|file)$/i, Ot = /^(?:input|select|textarea|keygen)/i; function Pt(n, e, r, i) { var t; if (Array.isArray(e)) ce.each(e, function (e, t) { r || qt.test(n) ? i(n, t) : Pt(n + "[" + ("object" == typeof t && null != t ? e : "") + "]", t, r, i) }); else if (r || "object" !== x(e)) i(n, e); else for (t in e) Pt(n + "[" + t + "]", e[t], r, i) } ce.param = function (e, t) { var n, r = [], i = function (e, t) { var n = v(t) ? t() : t; r[r.length] = encodeURIComponent(e) + "=" + encodeURIComponent(null == n ? "" : n) }; if (null == e) return ""; if (Array.isArray(e) || e.jquery && !ce.isPlainObject(e)) ce.each(e, function () { i(this.name, this.value) }); else for (n in e) Pt(n, e[n], t, i); return r.join("&") }, ce.fn.extend({ serialize: function () { return ce.param(this.serializeArray()) }, serializeArray: function () { return this.map(function () { var e = ce.prop(this, "elements"); return e ? ce.makeArray(e) : this }).filter(function () { var e = this.type; return this.name && !ce(this).is(":disabled") && Ot.test(this.nodeName) && !Ht.test(e) && (this.checked || !we.test(e)) }).map(function (e, t) { var n = ce(this).val(); return null == n ? null : Array.isArray(n) ? ce.map(n, function (e) { return { name: t.name, value: e.replace(Lt, "\r\n") } }) : { name: t.name, value: n.replace(Lt, "\r\n") } }).get() } }); var Mt = /%20/g, Rt = /#.*$/, It = /([?&])_=[^&]*/, Wt = /^(.*?):[ \t]*([^\r\n]*)$/gm, Ft = /^(?:GET|HEAD)$/, $t = /^\/\//, Bt = {}, _t = {}, zt = "*/".concat("*"), Xt = C.createElement("a"); function Ut(o) { return function (e, t) { "string" != typeof e && (t = e, e = "*"); var n, r = 0, i = e.toLowerCase().match(D) || []; if (v(t)) while (n = i[r++]) "+" === n[0] ? (n = n.slice(1) || "*", (o[n] = o[n] || []).unshift(t)) : (o[n] = o[n] || []).push(t) } } function Vt(t, i, o, a) { var s = {}, u = t === _t; function l(e) { var r; return s[e] = !0, ce.each(t[e] || [], function (e, t) { var n = t(i, o, a); return "string" != typeof n || u || s[n] ? u ? !(r = n) : void 0 : (i.dataTypes.unshift(n), l(n), !1) }), r } return l(i.dataTypes[0]) || !s["*"] && l("*") } function Gt(e, t) { var n, r, i = ce.ajaxSettings.flatOptions || {}; for (n in t) void 0 !== t[n] && ((i[n] ? e : r || (r = {}))[n] = t[n]); return r && ce.extend(!0, e, r), e } Xt.href = Et.href, ce.extend({ active: 0, lastModified: {}, etag: {}, ajaxSettings: { url: Et.href, type: "GET", isLocal: /^(?:about|app|app-storage|.+-extension|file|res|widget):$/.test(Et.protocol), global: !0, processData: !0, async: !0, contentType: "application/x-www-form-urlencoded; charset=UTF-8", accepts: { "*": zt, text: "text/plain", html: "text/html", xml: "application/xml, text/xml", json: "application/json, text/javascript" }, contents: { xml: /\bxml\b/, html: /\bhtml/, json: /\bjson\b/ }, responseFields: { xml: "responseXML", text: "responseText", json: "responseJSON" }, converters: { "* text": String, "text html": !0, "text json": JSON.parse, "text xml": ce.parseXML }, flatOptions: { url: !0, context: !0 } }, ajaxSetup: function (e, t) { return t ? Gt(Gt(e, ce.ajaxSettings), t) : Gt(ce.ajaxSettings, e) }, ajaxPrefilter: Ut(Bt), ajaxTransport: Ut(_t), ajax: function (e, t) { "object" == typeof e && (t = e, e = void 0), t = t || {}; var c, f, p, n, d, r, h, g, i, o, v = ce.ajaxSetup({}, t), y = v.context || v, m = v.context && (y.nodeType || y.jquery) ? ce(y) : ce.event, x = ce.Deferred(), b = ce.Callbacks("once memory"), w = v.statusCode || {}, a = {}, s = {}, u = "canceled", T = { readyState: 0, getResponseHeader: function (e) { var t; if (h) { if (!n) { n = {}; while (t = Wt.exec(p)) n[t[1].toLowerCase() + " "] = (n[t[1].toLowerCase() + " "] || []).concat(t[2]) } t = n[e.toLowerCase() + " "] } return null == t ? null : t.join(", ") }, getAllResponseHeaders: function () { return h ? p : null }, setRequestHeader: function (e, t) { return null == h && (e = s[e.toLowerCase()] = s[e.toLowerCase()] || e, a[e] = t), this }, overrideMimeType: function (e) { return null == h && (v.mimeType = e), this }, statusCode: function (e) { var t; if (e) if (h) T.always(e[T.status]); else for (t in e) w[t] = [w[t], e[t]]; return this }, abort: function (e) { var t = e || u; return c && c.abort(t), l(0, t), this } }; if (x.promise(T), v.url = ((e || v.url || Et.href) + "").replace($t, Et.protocol + "//"), v.type = t.method || t.type || v.method || v.type, v.dataTypes = (v.dataType || "*").toLowerCase().match(D) || [""], null == v.crossDomain) { r = C.createElement("a"); try { r.href = v.url, r.href = r.href, v.crossDomain = Xt.protocol + "//" + Xt.host != r.protocol + "//" + r.host } catch (e) { v.crossDomain = !0 } } if (v.data && v.processData && "string" != typeof v.data && (v.data = ce.param(v.data, v.traditional)), Vt(Bt, v, t, T), h) return T; for (i in (g = ce.event && v.global) && 0 == ce.active++ && ce.event.trigger("ajaxStart"), v.type = v.type.toUpperCase(), v.hasContent = !Ft.test(v.type), f = v.url.replace(Rt, ""), v.hasContent ? v.data && v.processData && 0 === (v.contentType || "").indexOf("application/x-www-form-urlencoded") && (v.data = v.data.replace(Mt, "+")) : (o = v.url.slice(f.length), v.data && (v.processData || "string" == typeof v.data) && (f += (At.test(f) ? "&" : "?") + v.data, delete v.data), !1 === v.cache && (f = f.replace(It, "$1"), o = (At.test(f) ? "&" : "?") + "_=" + jt.guid++ + o), v.url = f + o), v.ifModified && (ce.lastModified[f] && T.setRequestHeader("If-Modified-Since", ce.lastModified[f]), ce.etag[f] && T.setRequestHeader("If-None-Match", ce.etag[f])), (v.data && v.hasContent && !1 !== v.contentType || t.contentType) && T.setRequestHeader("Content-Type", v.contentType), T.setRequestHeader("Accept", v.dataTypes[0] && v.accepts[v.dataTypes[0]] ? v.accepts[v.dataTypes[0]] + ("*" !== v.dataTypes[0] ? ", " + zt + "; q=0.01" : "") : v.accepts["*"]), v.headers) T.setRequestHeader(i, v.headers[i]); if (v.beforeSend && (!1 === v.beforeSend.call(y, T, v) || h)) return T.abort(); if (u = "abort", b.add(v.complete), T.done(v.success), T.fail(v.error), c = Vt(_t, v, t, T)) { if (T.readyState = 1, g && m.trigger("ajaxSend", [T, v]), h) return T; v.async && 0 < v.timeout && (d = ie.setTimeout(function () { T.abort("timeout") }, v.timeout)); try { h = !1, c.send(a, l) } catch (e) { if (h) throw e; l(-1, e) } } else l(-1, "No Transport"); function l(e, t, n, r) { var i, o, a, s, u, l = t; h || (h = !0, d && ie.clearTimeout(d), c = void 0, p = r || "", T.readyState = 0 < e ? 4 : 0, i = 200 <= e && e < 300 || 304 === e, n && (s = function (e, t, n) { var r, i, o, a, s = e.contents, u = e.dataTypes; while ("*" === u[0]) u.shift(), void 0 === r && (r = e.mimeType || t.getResponseHeader("Content-Type")); if (r) for (i in s) if (s[i] && s[i].test(r)) { u.unshift(i); break } if (u[0] in n) o = u[0]; else { for (i in n) { if (!u[0] || e.converters[i + " " + u[0]]) { o = i; break } a || (a = i) } o = o || a } if (o) return o !== u[0] && u.unshift(o), n[o] }(v, T, n)), !i && -1 < ce.inArray("script", v.dataTypes) && ce.inArray("json", v.dataTypes) < 0 && (v.converters["text script"] = function () { }), s = function (e, t, n, r) { var i, o, a, s, u, l = {}, c = e.dataTypes.slice(); if (c[1]) for (a in e.converters) l[a.toLowerCase()] = e.converters[a]; o = c.shift(); while (o) if (e.responseFields[o] && (n[e.responseFields[o]] = t), !u && r && e.dataFilter && (t = e.dataFilter(t, e.dataType)), u = o, o = c.shift()) if ("*" === o) o = u; else if ("*" !== u && u !== o) { if (!(a = l[u + " " + o] || l["* " + o])) for (i in l) if ((s = i.split(" "))[1] === o && (a = l[u + " " + s[0]] || l["* " + s[0]])) { !0 === a ? a = l[i] : !0 !== l[i] && (o = s[0], c.unshift(s[1])); break } if (!0 !== a) if (a && e["throws"]) t = a(t); else try { t = a(t) } catch (e) { return { state: "parsererror", error: a ? e : "No conversion from " + u + " to " + o } } } return { state: "success", data: t } }(v, s, T, i), i ? (v.ifModified && ((u = T.getResponseHeader("Last-Modified")) && (ce.lastModified[f] = u), (u = T.getResponseHeader("etag")) && (ce.etag[f] = u)), 204 === e || "HEAD" === v.type ? l = "nocontent" : 304 === e ? l = "notmodified" : (l = s.state, o = s.data, i = !(a = s.error))) : (a = l, !e && l || (l = "error", e < 0 && (e = 0))), T.status = e, T.statusText = (t || l) + "", i ? x.resolveWith(y, [o, l, T]) : x.rejectWith(y, [T, l, a]), T.statusCode(w), w = void 0, g && m.trigger(i ? "ajaxSuccess" : "ajaxError", [T, v, i ? o : a]), b.fireWith(y, [T, l]), g && (m.trigger("ajaxComplete", [T, v]), --ce.active || ce.event.trigger("ajaxStop"))) } return T }, getJSON: function (e, t, n) { return ce.get(e, t, n, "json") }, getScript: function (e, t) { return ce.get(e, void 0, t, "script") } }), ce.each(["get", "post"], function (e, i) { ce[i] = function (e, t, n, r) { return v(t) && (r = r || n, n = t, t = void 0), ce.ajax(ce.extend({ url: e, type: i, dataType: r, data: t, success: n }, ce.isPlainObject(e) && e)) } }), ce.ajaxPrefilter(function (e) { var t; for (t in e.headers) "content-type" === t.toLowerCase() && (e.contentType = e.headers[t] || "") }), ce._evalUrl = function (e, t, n) { return ce.ajax({ url: e, type: "GET", dataType: "script", cache: !0, async: !1, global: !1, converters: { "text script": function () { } }, dataFilter: function (e) { ce.globalEval(e, t, n) } }) }, ce.fn.extend({ wrapAll: function (e) { var t; return this[0] && (v(e) && (e = e.call(this[0])), t = ce(e, this[0].ownerDocument).eq(0).clone(!0), this[0].parentNode && t.insertBefore(this[0]), t.map(function () { var e = this; while (e.firstElementChild) e = e.firstElementChild; return e }).append(this)), this }, wrapInner: function (n) { return v(n) ? this.each(function (e) { ce(this).wrapInner(n.call(this, e)) }) : this.each(function () { var e = ce(this), t = e.contents(); t.length ? t.wrapAll(n) : e.append(n) }) }, wrap: function (t) { var n = v(t); return this.each(function (e) { ce(this).wrapAll(n ? t.call(this, e) : t) }) }, unwrap: function (e) { return this.parent(e).not("body").each(function () { ce(this).replaceWith(this.childNodes) }), this } }), ce.expr.pseudos.hidden = function (e) { return !ce.expr.pseudos.visible(e) }, ce.expr.pseudos.visible = function (e) { return !!(e.offsetWidth || e.offsetHeight || e.getClientRects().length) }, ce.ajaxSettings.xhr = function () { try { return new ie.XMLHttpRequest } catch (e) { } }; var Yt = { 0: 200, 1223: 204 }, Qt = ce.ajaxSettings.xhr(); le.cors = !!Qt && "withCredentials" in Qt, le.ajax = Qt = !!Qt, ce.ajaxTransport(function (i) { var o, a; if (le.cors || Qt && !i.crossDomain) return { send: function (e, t) { var n, r = i.xhr(); if (r.open(i.type, i.url, i.async, i.username, i.password), i.xhrFields) for (n in i.xhrFields) r[n] = i.xhrFields[n]; for (n in i.mimeType && r.overrideMimeType && r.overrideMimeType(i.mimeType), i.crossDomain || e["X-Requested-With"] || (e["X-Requested-With"] = "XMLHttpRequest"), e) r.setRequestHeader(n, e[n]); o = function (e) { return function () { o && (o = a = r.onload = r.onerror = r.onabort = r.ontimeout = r.onreadystatechange = null, "abort" === e ? r.abort() : "error" === e ? "number" != typeof r.status ? t(0, "error") : t(r.status, r.statusText) : t(Yt[r.status] || r.status, r.statusText, "text" !== (r.responseType || "text") || "string" != typeof r.responseText ? { binary: r.response } : { text: r.responseText }, r.getAllResponseHeaders())) } }, r.onload = o(), a = r.onerror = r.ontimeout = o("error"), void 0 !== r.onabort ? r.onabort = a : r.onreadystatechange = function () { 4 === r.readyState && ie.setTimeout(function () { o && a() }) }, o = o("abort"); try { r.send(i.hasContent && i.data || null) } catch (e) { if (o) throw e } }, abort: function () { o && o() } } }), ce.ajaxPrefilter(function (e) { e.crossDomain && (e.contents.script = !1) }), ce.ajaxSetup({ accepts: { script: "text/javascript, application/javascript, application/ecmascript, application/x-ecmascript" }, contents: { script: /\b(?:java|ecma)script\b/ }, converters: { "text script": function (e) { return ce.globalEval(e), e } } }), ce.ajaxPrefilter("script", function (e) { void 0 === e.cache && (e.cache = !1), e.crossDomain && (e.type = "GET") }), ce.ajaxTransport("script", function (n) { var r, i; if (n.crossDomain || n.scriptAttrs) return { send: function (e, t) { r = ce("<script>").attr(n.scriptAttrs || {}).prop({ charset: n.scriptCharset, src: n.url }).on("load error", i = function (e) { r.remove(), i = null, e && t("error" === e.type ? 404 : 200, e.type) }), C.head.appendChild(r[0]) }, abort: function () { i && i() } } }); var Jt, Kt = [], Zt = /(=)\?(?=&|$)|\?\?/; ce.ajaxSetup({ jsonp: "callback", jsonpCallback: function () { var e = Kt.pop() || ce.expando + "_" + jt.guid++; return this[e] = !0, e } }), ce.ajaxPrefilter("json jsonp", function (e, t, n) { var r, i, o, a = !1 !== e.jsonp && (Zt.test(e.url) ? "url" : "string" == typeof e.data && 0 === (e.contentType || "").indexOf("application/x-www-form-urlencoded") && Zt.test(e.data) && "data"); if (a || "jsonp" === e.dataTypes[0]) return r = e.jsonpCallback = v(e.jsonpCallback) ? e.jsonpCallback() : e.jsonpCallback, a ? e[a] = e[a].replace(Zt, "$1" + r) : !1 !== e.jsonp && (e.url += (At.test(e.url) ? "&" : "?") + e.jsonp + "=" + r), e.converters["script json"] = function () { return o || ce.error(r + " was not called"), o[0] }, e.dataTypes[0] = "json", i = ie[r], ie[r] = function () { o = arguments }, n.always(function () { void 0 === i ? ce(ie).removeProp(r) : ie[r] = i, e[r] && (e.jsonpCallback = t.jsonpCallback, Kt.push(r)), o && v(i) && i(o[0]), o = i = void 0 }), "script" }), le.createHTMLDocument = ((Jt = C.implementation.createHTMLDocument("").body).innerHTML = "<form></form><form></form>", 2 === Jt.childNodes.length), ce.parseHTML = function (e, t, n) { return "string" != typeof e ? [] : ("boolean" == typeof t && (n = t, t = !1), t || (le.createHTMLDocument ? ((r = (t = C.implementation.createHTMLDocument("")).createElement("base")).href = C.location.href, t.head.appendChild(r)) : t = C), o = !n && [], (i = w.exec(e)) ? [t.createElement(i[1])] : (i = Ae([e], t, o), o && o.length && ce(o).remove(), ce.merge([], i.childNodes))); var r, i, o }, ce.fn.load = function (e, t, n) { var r, i, o, a = this, s = e.indexOf(" "); return -1 < s && (r = Tt(e.slice(s)), e = e.slice(0, s)), v(t) ? (n = t, t = void 0) : t && "object" == typeof t && (i = "POST"), 0 < a.length && ce.ajax({ url: e, type: i || "GET", dataType: "html", data: t }).done(function (e) { o = arguments, a.html(r ? ce("<div>").append(ce.parseHTML(e)).find(r) : e) }).always(n && function (e, t) { a.each(function () { n.apply(this, o || [e.responseText, t, e]) }) }), this }, ce.expr.pseudos.animated = function (t) { return ce.grep(ce.timers, function (e) { return t === e.elem }).length }, ce.offset = { setOffset: function (e, t, n) { var r, i, o, a, s, u, l = ce.css(e, "position"), c = ce(e), f = {}; "static" === l && (e.style.position = "relative"), s = c.offset(), o = ce.css(e, "top"), u = ce.css(e, "left"), ("absolute" === l || "fixed" === l) && -1 < (o + u).indexOf("auto") ? (a = (r = c.position()).top, i = r.left) : (a = parseFloat(o) || 0, i = parseFloat(u) || 0), v(t) && (t = t.call(e, n, ce.extend({}, s))), null != t.top && (f.top = t.top - s.top + a), null != t.left && (f.left = t.left - s.left + i), "using" in t ? t.using.call(e, f) : c.css(f) } }, ce.fn.extend({ offset: function (t) { if (arguments.length) return void 0 === t ? this : this.each(function (e) { ce.offset.setOffset(this, t, e) }); var e, n, r = this[0]; return r ? r.getClientRects().length ? (e = r.getBoundingClientRect(), n = r.ownerDocument.defaultView, { top: e.top + n.pageYOffset, left: e.left + n.pageXOffset }) : { top: 0, left: 0 } : void 0 }, position: function () { if (this[0]) { var e, t, n, r = this[0], i = { top: 0, left: 0 }; if ("fixed" === ce.css(r, "position")) t = r.getBoundingClientRect(); else { t = this.offset(), n = r.ownerDocument, e = r.offsetParent || n.documentElement; while (e && (e === n.body || e === n.documentElement) && "static" === ce.css(e, "position")) e = e.parentNode; e && e !== r && 1 === e.nodeType && ((i = ce(e).offset()).top += ce.css(e, "borderTopWidth", !0), i.left += ce.css(e, "borderLeftWidth", !0)) } return { top: t.top - i.top - ce.css(r, "marginTop", !0), left: t.left - i.left - ce.css(r, "marginLeft", !0) } } }, offsetParent: function () { return this.map(function () { var e = this.offsetParent; while (e && "static" === ce.css(e, "position")) e = e.offsetParent; return e || J }) } }), ce.each({ scrollLeft: "pageXOffset", scrollTop: "pageYOffset" }, function (t, i) { var o = "pageYOffset" === i; ce.fn[t] = function (e) { return M(this, function (e, t, n) { var r; if (y(e) ? r = e : 9 === e.nodeType && (r = e.defaultView), void 0 === n) return r ? r[i] : e[t]; r ? r.scrollTo(o ? r.pageXOffset : n, o ? n : r.pageYOffset) : e[t] = n }, t, e, arguments.length) } }), ce.each(["top", "left"], function (e, n) { ce.cssHooks[n] = Ye(le.pixelPosition, function (e, t) { if (t) return t = Ge(e, n), _e.test(t) ? ce(e).position()[n] + "px" : t }) }), ce.each({ Height: "height", Width: "width" }, function (a, s) { ce.each({ padding: "inner" + a, content: s, "": "outer" + a }, function (r, o) { ce.fn[o] = function (e, t) { var n = arguments.length && (r || "boolean" != typeof e), i = r || (!0 === e || !0 === t ? "margin" : "border"); return M(this, function (e, t, n) { var r; return y(e) ? 0 === o.indexOf("outer") ? e["inner" + a] : e.document.documentElement["client" + a] : 9 === e.nodeType ? (r = e.documentElement, Math.max(e.body["scroll" + a], r["scroll" + a], e.body["offset" + a], r["offset" + a], r["client" + a])) : void 0 === n ? ce.css(e, t, i) : ce.style(e, t, n, i) }, s, n ? e : void 0, n) } }) }), ce.each(["ajaxStart", "ajaxStop", "ajaxComplete", "ajaxError", "ajaxSuccess", "ajaxSend"], function (e, t) { ce.fn[t] = function (e) { return this.on(t, e) } }), ce.fn.extend({ bind: function (e, t, n) { return this.on(e, null, t, n) }, unbind: function (e, t) { return this.off(e, null, t) }, delegate: function (e, t, n, r) { return this.on(t, e, n, r) }, undelegate: function (e, t, n) { return 1 === arguments.length ? this.off(e, "**") : this.off(t, e || "**", n) }, hover: function (e, t) { return this.on("mouseenter", e).on("mouseleave", t || e) } }), ce.each("blur focus focusin focusout resize scroll click dblclick mousedown mouseup mousemove mouseover mouseout mouseenter mouseleave change select submit keydown keypress keyup contextmenu".split(" "), function (e, n) { ce.fn[n] = function (e, t) { return 0 < arguments.length ? this.on(n, null, e, t) : this.trigger(n) } }); var en = /^[\s\uFEFF\xA0]+|([^\s\uFEFF\xA0])[\s\uFEFF\xA0]+$/g; ce.proxy = function (e, t) { var n, r, i; if ("string" == typeof t && (n = e[t], t = e, e = n), v(e)) return r = ae.call(arguments, 2), (i = function () { return e.apply(t || this, r.concat(ae.call(arguments))) }).guid = e.guid = e.guid || ce.guid++, i }, ce.holdReady = function (e) { e ? ce.readyWait++ : ce.ready(!0) }, ce.isArray = Array.isArray, ce.parseJSON = JSON.parse, ce.nodeName = fe, ce.isFunction = v, ce.isWindow = y, ce.camelCase = F, ce.type = x, ce.now = Date.now, ce.isNumeric = function (e) { var t = ce.type(e); return ("number" === t || "string" === t) && !isNaN(e - parseFloat(e)) }, ce.trim = function (e) { return null == e ? "" : (e + "").replace(en, "$1") }, "function" == typeof define && define.amd && define("jquery", [], function () { return ce }); var tn = ie.jQuery, nn = ie.$; return ce.noConflict = function (e) { return ie.$ === ce && (ie.$ = nn), e && ie.jQuery === ce && (ie.jQuery = tn), ce }, "undefined" == typeof e && (ie.jQuery = ie.$ = ce), ce });
/**
* Bootstrap.js by @fat & @mdo
* plugins: bootstrap-transition.js, bootstrap-modal.js, bootstrap-dropdown.js, bootstrap-scrollspy.js, bootstrap-tab.js, bootstrap-tooltip.js, bootstrap-popover.js, bootstrap-affix.js, bootstrap-alert.js, bootstrap-button.js, bootstrap-collapse.js, bootstrap-carousel.js, bootstrap-typeahead.js
* Copyright 2012 Twitter, Inc.
* http://www.apache.org/licenses/LICENSE-2.0.txt
*/
!function(a){a(function(){a.support.transition=function(){var a=function(){var a=document.createElement("bootstrap"),b={WebkitTransition:"webkitTransitionEnd",MozTransition:"transitionend",OTransition:"oTransitionEnd otransitionend",transition:"transitionend"},c;for(c in b)if(a.style[c]!==undefined)return b[c]}();return a&&{end:a}}()})}(window.jQuery),!function(a){var b=function(b,c){this.options=c,this.$element=a(b).delegate('[data-dismiss="modal"]',"click.dismiss.modal",a.proxy(this.hide,this)),this.options.remote&&this.$element.find(".modal-body").load(this.options.remote)};b.prototype={constructor:b,toggle:function(){return this[this.isShown?"hide":"show"]()},show:function(){var b=this,c=a.Event("show");this.$element.trigger(c);if(this.isShown||c.isDefaultPrevented())return;this.isShown=!0,this.escape(),this.backdrop(function(){var c=a.support.transition&&b.$element.hasClass("fade");b.$element.parent().length||b.$element.appendTo(document.body),b.$element.show(),c&&b.$element[0].offsetWidth,b.$element.addClass("in").attr("aria-hidden",!1),b.enforceFocus(),c?b.$element.one(a.support.transition.end,function(){b.$element.focus().trigger("shown")}):b.$element.focus().trigger("shown")})},hide:function(b){b&&b.preventDefault();var c=this;b=a.Event("hide"),this.$element.trigger(b);if(!this.isShown||b.isDefaultPrevented())return;this.isShown=!1,this.escape(),a(document).off("focusin.modal"),this.$element.removeClass("in").attr("aria-hidden",!0),a.support.transition&&this.$element.hasClass("fade")?this.hideWithTransition():this.hideModal()},enforceFocus:function(){var b=this;a(document).on("focusin.modal",function(a){b.$element[0]!==a.target&&!b.$element.has(a.target).length&&b.$element.focus()})},escape:function(){var a=this;this.isShown&&this.options.keyboard?this.$element.on("keyup.dismiss.modal",function(b){b.which==27&&a.hide()}):this.isShown||this.$element.off("keyup.dismiss.modal")},hideWithTransition:function(){var b=this,c=setTimeout(function(){b.$element.off(a.support.transition.end),b.hideModal()},500);this.$element.one(a.support.transition.end,function(){clearTimeout(c),b.hideModal()})},hideModal:function(){var a=this;this.$element.hide(),this.backdrop(function(){a.removeBackdrop(),a.$element.trigger("hidden")})},removeBackdrop:function(){this.$backdrop&&this.$backdrop.remove(),this.$backdrop=null},backdrop:function(b){var c=this,d=this.$element.hasClass("fade")?"fade":"";if(this.isShown&&this.options.backdrop){var e=a.support.transition&&d;this.$backdrop=a('<div class="modal-backdrop '+d+'" />').appendTo(document.body),this.$backdrop.click(this.options.backdrop=="static"?a.proxy(this.$element[0].focus,this.$element[0]):a.proxy(this.hide,this)),e&&this.$backdrop[0].offsetWidth,this.$backdrop.addClass("in");if(!b)return;e?this.$backdrop.one(a.support.transition.end,b):b()}else!this.isShown&&this.$backdrop?(this.$backdrop.removeClass("in"),a.support.transition&&this.$element.hasClass("fade")?this.$backdrop.one(a.support.transition.end,b):b()):b&&b()}};var c=a.fn.modal;a.fn.modal=function(c){return this.each(function(){var d=a(this),e=d.data("modal"),f=a.extend({},a.fn.modal.defaults,d.data(),typeof c=="object"&&c);e||d.data("modal",e=new b(this,f)),typeof c=="string"?e[c]():f.show&&e.show()})},a.fn.modal.defaults={backdrop:!0,keyboard:!0,show:!0},a.fn.modal.Constructor=b,a.fn.modal.noConflict=function(){return a.fn.modal=c,this},a(document).on("click.modal.data-api",'[data-toggle="modal"]',function(b){var c=a(this),d=c.attr("href"),e=a(c.attr("data-target")||d&&d.replace(/.*(?=#[^\s]+$)/,"")),f=e.data("modal")?"toggle":a.extend({remote:!/#/.test(d)&&d},e.data(),c.data());b.preventDefault(),e.modal(f).one("hide",function(){c.focus()})})}(window.jQuery),!function(a){function d(){a(".dropdown-backdrop").remove(),a(b).each(function(){e(a(this)).removeClass("open")})}function e(b){var c=b.attr("data-target"),d;c||(c=b.attr("href"),c=c&&/#/.test(c)&&c.replace(/.*(?=#[^\s]*$)/,"")),d=c&&a(c);if(!d||!d.length)d=b.parent();return d}var b="[data-toggle=dropdown]",c=function(b){var c=a(b).on("click.dropdown.data-api",this.toggle);a("html").on("click.dropdown.data-api",function(){c.parent().removeClass("open")})};c.prototype={constructor:c,toggle:function(b){var c=a(this),f,g;if(c.is(".disabled, :disabled"))return;return f=e(c),g=f.hasClass("open"),d(),g||("ontouchstart"in document.documentElement&&a('<div class="dropdown-backdrop"/>').insertBefore(a(this)).on("click",d),f.toggleClass("open")),c.focus(),!1},keydown:function(c){var d,f,g,h,i,j;if(!/(38|40|27)/.test(c.keyCode))return;d=a(this),c.preventDefault(),c.stopPropagation();if(d.is(".disabled, :disabled"))return;h=e(d),i=h.hasClass("open");if(!i||i&&c.keyCode==27)return c.which==27&&h.find(b).focus(),d.click();f=a("[role=menu] li:not(.divider):visible a",h);if(!f.length)return;j=f.index(f.filter(":focus")),c.keyCode==38&&j>0&&j--,c.keyCode==40&&j<f.length-1&&j++,~j||(j=0),f.eq(j).focus()}};var f=a.fn.dropdown;a.fn.dropdown=function(b){return this.each(function(){var d=a(this),e=d.data("dropdown");e||d.data("dropdown",e=new c(this)),typeof b=="string"&&e[b].call(d)})},a.fn.dropdown.Constructor=c,a.fn.dropdown.noConflict=function(){return a.fn.dropdown=f,this},a(document).on("click.dropdown.data-api",d).on("click.dropdown.data-api",".dropdown form",function(a){a.stopPropagation()}).on("click.dropdown.data-api",b,c.prototype.toggle).on("keydown.dropdown.data-api",b+", [role=menu]",c.prototype.keydown)}(window.jQuery),!function(a){function b(b,c){var d=a.proxy(this.process,this),e=a(b).is("body")?a(window):a(b),f;this.options=a.extend({},a.fn.scrollspy.defaults,c),this.$scrollElement=e.on("scroll.scroll-spy.data-api",d),this.selector=(this.options.target||(f=a(b).attr("href"))&&f.replace(/.*(?=#[^\s]+$)/,"")||"")+" .nav li > a",this.$body=a("body"),this.refresh(),this.process()}b.prototype={constructor:b,refresh:function(){var b=this,c;this.offsets=a([]),this.targets=a([]),c=this.$body.find(this.selector).map(function(){var c=a(this),d=c.data("target")||c.attr("href"),e=/^#\w/.test(d)&&a(d);return e&&e.length&&[[e.position().top+(!a.isWindow(b.$scrollElement.get(0))&&b.$scrollElement.scrollTop()),d]]||null}).sort(function(a,b){return a[0]-b[0]}).each(function(){b.offsets.push(this[0]),b.targets.push(this[1])})},process:function(){var a=this.$scrollElement.scrollTop()+this.options.offset,b=this.$scrollElement[0].scrollHeight||this.$body[0].scrollHeight,c=b-this.$scrollElement.height(),d=this.offsets,e=this.targets,f=this.activeTarget,g;if(a>=c)return f!=(g=e.last()[0])&&this.activate(g);for(g=d.length;g--;)f!=e[g]&&a>=d[g]&&(!d[g+1]||a<=d[g+1])&&this.activate(e[g])},activate:function(b){var c,d;this.activeTarget=b,a(this.selector).parent(".active").removeClass("active"),d=this.selector+'[data-target="'+b+'"],'+this.selector+'[href="'+b+'"]',c=a(d).parent("li").addClass("active"),c.parent(".dropdown-menu").length&&(c=c.closest("li.dropdown").addClass("active")),c.trigger("activate")}};var c=a.fn.scrollspy;a.fn.scrollspy=function(c){return this.each(function(){var d=a(this),e=d.data("scrollspy"),f=typeof c=="object"&&c;e||d.data("scrollspy",e=new b(this,f)),typeof c=="string"&&e[c]()})},a.fn.scrollspy.Constructor=b,a.fn.scrollspy.defaults={offset:10},a.fn.scrollspy.noConflict=function(){return a.fn.scrollspy=c,this},a(window).on("load",function(){a('[data-spy="scroll"]').each(function(){var b=a(this);b.scrollspy(b.data())})})}(window.jQuery),!function(a){var b=function(b){this.element=a(b)};b.prototype={constructor:b,show:function(){var b=this.element,c=b.closest("ul:not(.dropdown-menu)"),d=b.attr("data-target"),e,f,g;d||(d=b.attr("href"),d=d&&d.replace(/.*(?=#[^\s]*$)/,""));if(b.parent("li").hasClass("active"))return;e=c.find(".active:last a")[0],g=a.Event("show",{relatedTarget:e}),b.trigger(g);if(g.isDefaultPrevented())return;f=a(d),this.activate(b.parent("li"),c),this.activate(f,f.parent(),function(){b.trigger({type:"shown",relatedTarget:e})})},activate:function(b,c,d){function g(){e.removeClass("active").find("> .dropdown-menu > .active").removeClass("active"),b.addClass("active"),f?(b[0].offsetWidth,b.addClass("in")):b.removeClass("fade"),b.parent(".dropdown-menu")&&b.closest("li.dropdown").addClass("active"),d&&d()}var e=c.find("> .active"),f=d&&a.support.transition&&e.hasClass("fade");f?e.one(a.support.transition.end,g):g(),e.removeClass("in")}};var c=a.fn.tab;a.fn.tab=function(c){return this.each(function(){var d=a(this),e=d.data("tab");e||d.data("tab",e=new b(this)),typeof c=="string"&&e[c]()})},a.fn.tab.Constructor=b,a.fn.tab.noConflict=function(){return a.fn.tab=c,this},a(document).on("click.tab.data-api",'[data-toggle="tab"], [data-toggle="pill"]',function(b){b.preventDefault(),a(this).tab("show")})}(window.jQuery),!function(a){var b=function(a,b){this.init("tooltip",a,b)};b.prototype={constructor:b,init:function(b,c,d){var e,f,g,h,i;this.type=b,this.$element=a(c),this.options=this.getOptions(d),this.enabled=!0,g=this.options.trigger.split(" ");for(i=g.length;i--;)h=g[i],h=="click"?this.$element.on("click."+this.type,this.options.selector,a.proxy(this.toggle,this)):h!="manual"&&(e=h=="hover"?"mouseenter":"focus",f=h=="hover"?"mouseleave":"blur",this.$element.on(e+"."+this.type,this.options.selector,a.proxy(this.enter,this)),this.$element.on(f+"."+this.type,this.options.selector,a.proxy(this.leave,this)));this.options.selector?this._options=a.extend({},this.options,{trigger:"manual",selector:""}):this.fixTitle()},getOptions:function(b){return b=a.extend({},a.fn[this.type].defaults,this.$element.data(),b),b.delay&&typeof b.delay=="number"&&(b.delay={show:b.delay,hide:b.delay}),b},enter:function(b){var c=a.fn[this.type].defaults,d={},e;this._options&&a.each(this._options,function(a,b){c[a]!=b&&(d[a]=b)},this),e=a(b.currentTarget)[this.type](d).data(this.type);if(!e.options.delay||!e.options.delay.show)return e.show();clearTimeout(this.timeout),e.hoverState="in",this.timeout=setTimeout(function(){e.hoverState=="in"&&e.show()},e.options.delay.show)},leave:function(b){var c=a(b.currentTarget)[this.type](this._options).data(this.type);this.timeout&&clearTimeout(this.timeout);if(!c.options.delay||!c.options.delay.hide)return c.hide();c.hoverState="out",this.timeout=setTimeout(function(){c.hoverState=="out"&&c.hide()},c.options.delay.hide)},show:function(){var b,c,d,e,f,g,h=a.Event("show");if(this.hasContent()&&this.enabled){this.$element.trigger(h);if(h.isDefaultPrevented())return;b=this.tip(),this.setContent(),this.options.animation&&b.addClass("fade"),f=typeof this.options.placement=="function"?this.options.placement.call(this,b[0],this.$element[0]):this.options.placement,b.detach().css({top:0,left:0,display:"block"}),this.options.container?b.appendTo(this.options.container):b.insertAfter(this.$element),c=this.getPosition(),d=b[0].offsetWidth,e=b[0].offsetHeight;switch(f){case"bottom":g={top:c.top+c.height,left:c.left+c.width/2-d/2};break;case"top":g={top:c.top-e,left:c.left+c.width/2-d/2};break;case"left":g={top:c.top+c.height/2-e/2,left:c.left-d};break;case"right":g={top:c.top+c.height/2-e/2,left:c.left+c.width}}this.applyPlacement(g,f),this.$element.trigger("shown")}},applyPlacement:function(a,b){var c=this.tip(),d=c[0].offsetWidth,e=c[0].offsetHeight,f,g,h,i;c.offset(a).addClass(b).addClass("in"),f=c[0].offsetWidth,g=c[0].offsetHeight,b=="top"&&g!=e&&(a.top=a.top+e-g,i=!0),b=="bottom"||b=="top"?(h=0,a.left<0&&(h=a.left*-2,a.left=0,c.offset(a),f=c[0].offsetWidth,g=c[0].offsetHeight),this.replaceArrow(h-d+f,f,"left")):this.replaceArrow(g-e,g,"top"),i&&c.offset(a)},replaceArrow:function(a,b,c){this.arrow().css(c,a?50*(1-a/b)+"%":"")},setContent:function(){var a=this.tip(),b=this.getTitle();a.find(".tooltip-inner")[this.options.html?"html":"text"](b),a.removeClass("fade in top bottom left right")},hide:function(){function e(){var b=setTimeout(function(){c.off(a.support.transition.end).detach()},500);c.one(a.support.transition.end,function(){clearTimeout(b),c.detach()})}var b=this,c=this.tip(),d=a.Event("hide");this.$element.trigger(d);if(d.isDefaultPrevented())return;return c.removeClass("in"),a.support.transition&&this.$tip.hasClass("fade")?e():c.detach(),this.$element.trigger("hidden"),this},fixTitle:function(){var a=this.$element;(a.attr("title")||typeof a.attr("data-original-title")!="string")&&a.attr("data-original-title",a.attr("title")||"").attr("title","")},hasContent:function(){return this.getTitle()},getPosition:function(){var b=this.$element[0];return a.extend({},typeof b.getBoundingClientRect=="function"?b.getBoundingClientRect():{width:b.offsetWidth,height:b.offsetHeight},this.$element.offset())},getTitle:function(){var a,b=this.$element,c=this.options;return a=b.attr("data-original-title")||(typeof c.title=="function"?c.title.call(b[0]):c.title),a},tip:function(){return this.$tip=this.$tip||a(this.options.template)},arrow:function(){return this.$arrow=this.$arrow||this.tip().find(".tooltip-arrow")},validate:function(){this.$element[0].parentNode||(this.hide(),this.$element=null,this.options=null)},enable:function(){this.enabled=!0},disable:function(){this.enabled=!1},toggleEnabled:function(){this.enabled=!this.enabled},toggle:function(b){var c=b?a(b.currentTarget)[this.type](this._options).data(this.type):this;c.tip().hasClass("in")?c.hide():c.show()},destroy:function(){this.hide().$element.off("."+this.type).removeData(this.type)}};var c=a.fn.tooltip;a.fn.tooltip=function(c){return this.each(function(){var d=a(this),e=d.data("tooltip"),f=typeof c=="object"&&c;e||d.data("tooltip",e=new b(this,f)),typeof c=="string"&&e[c]()})},a.fn.tooltip.Constructor=b,a.fn.tooltip.defaults={animation:!0,placement:"top",selector:!1,template:'<div class="tooltip"><div class="tooltip-arrow"></div><div class="tooltip-inner"></div></div>',trigger:"hover focus",title:"",delay:0,html:!1,container:!1},a.fn.tooltip.noConflict=function(){return a.fn.tooltip=c,this}}(window.jQuery),!function(a){var b=function(a,b){this.init("popover",a,b)};b.prototype=a.extend({},a.fn.tooltip.Constructor.prototype,{constructor:b,setContent:function(){var a=this.tip(),b=this.getTitle(),c=this.getContent();a.find(".popover-title")[this.options.html?"html":"text"](b),a.find(".popover-content")[this.options.html?"html":"text"](c),a.removeClass("fade top bottom left right in")},hasContent:function(){return this.getTitle()||this.getContent()},getContent:function(){var a,b=this.$element,c=this.options;return a=(typeof c.content=="function"?c.content.call(b[0]):c.content)||b.attr("data-content"),a},tip:function(){return this.$tip||(this.$tip=a(this.options.template)),this.$tip},destroy:function(){this.hide().$element.off("."+this.type).removeData(this.type)}});var c=a.fn.popover;a.fn.popover=function(c){return this.each(function(){var d=a(this),e=d.data("popover"),f=typeof c=="object"&&c;e||d.data("popover",e=new b(this,f)),typeof c=="string"&&e[c]()})},a.fn.popover.Constructor=b,a.fn.popover.defaults=a.extend({},a.fn.tooltip.defaults,{placement:"right",trigger:"click",content:"",template:'<div class="popover"><div class="arrow"></div><h3 class="popover-title"></h3><div class="popover-content"></div></div>'}),a.fn.popover.noConflict=function(){return a.fn.popover=c,this}}(window.jQuery),!function(a){var b=function(b,c){this.options=a.extend({},a.fn.affix.defaults,c),this.$window=a(window).on("scroll.affix.data-api",a.proxy(this.checkPosition,this)).on("click.affix.data-api",a.proxy(function(){setTimeout(a.proxy(this.checkPosition,this),1)},this)),this.$element=a(b),this.checkPosition()};b.prototype.checkPosition=function(){if(!this.$element.is(":visible"))return;var b=a(document).height(),c=this.$window.scrollTop(),d=this.$element.offset(),e=this.options.offset,f=e.bottom,g=e.top,h="affix affix-top affix-bottom",i;typeof e!="object"&&(f=g=e),typeof g=="function"&&(g=e.top()),typeof f=="function"&&(f=e.bottom()),i=this.unpin!=null&&c+this.unpin<=d.top?!1:f!=null&&d.top+this.$element.height()>=b-f?"bottom":g!=null&&c<=g?"top":!1;if(this.affixed===i)return;this.affixed=i,this.unpin=i=="bottom"?d.top-c:null,this.$element.removeClass(h).addClass("affix"+(i?"-"+i:""))};var c=a.fn.affix;a.fn.affix=function(c){return this.each(function(){var d=a(this),e=d.data("affix"),f=typeof c=="object"&&c;e||d.data("affix",e=new b(this,f)),typeof c=="string"&&e[c]()})},a.fn.affix.Constructor=b,a.fn.affix.defaults={offset:0},a.fn.affix.noConflict=function(){return a.fn.affix=c,this},a(window).on("load",function(){a('[data-spy="affix"]').each(function(){var b=a(this),c=b.data();c.offset=c.offset||{},c.offsetBottom&&(c.offset.bottom=c.offsetBottom),c.offsetTop&&(c.offset.top=c.offsetTop),b.affix(c)})})}(window.jQuery),!function(a){var b='[data-dismiss="alert"]',c=function(c){a(c).on("click",b,this.close)};c.prototype.close=function(b){function f(){e.trigger("closed").remove()}var c=a(this),d=c.attr("data-target"),e;d||(d=c.attr("href"),d=d&&d.replace(/.*(?=#[^\s]*$)/,"")),e=a(d),b&&b.preventDefault(),e.length||(e=c.hasClass("alert")?c:c.parent()),e.trigger(b=a.Event("close"));if(b.isDefaultPrevented())return;e.removeClass("in"),a.support.transition&&e.hasClass("fade")?e.on(a.support.transition.end,f):f()};var d=a.fn.alert;a.fn.alert=function(b){return this.each(function(){var d=a(this),e=d.data("alert");e||d.data("alert",e=new c(this)),typeof b=="string"&&e[b].call(d)})},a.fn.alert.Constructor=c,a.fn.alert.noConflict=function(){return a.fn.alert=d,this},a(document).on("click.alert.data-api",b,c.prototype.close)}(window.jQuery),!function(a){var b=function(b,c){this.$element=a(b),this.options=a.extend({},a.fn.button.defaults,c)};b.prototype.setState=function(a){var b="disabled",c=this.$element,d=c.data(),e=c.is("input")?"val":"html";a+="Text",d.resetText||c.data("resetText",c[e]()),c[e](d[a]||this.options[a]),setTimeout(function(){a=="loadingText"?c.addClass(b).attr(b,b):c.removeClass(b).removeAttr(b)},0)},b.prototype.toggle=function(){var a=this.$element.closest('[data-toggle="buttons-radio"]');a&&a.find(".active").removeClass("active"),this.$element.toggleClass("active")};var c=a.fn.button;a.fn.button=function(c){return this.each(function(){var d=a(this),e=d.data("button"),f=typeof c=="object"&&c;e||d.data("button",e=new b(this,f)),c=="toggle"?e.toggle():c&&e.setState(c)})},a.fn.button.defaults={loadingText:"loading..."},a.fn.button.Constructor=b,a.fn.button.noConflict=function(){return a.fn.button=c,this},a(document).on("click.button.data-api","[data-toggle^=button]",function(b){var c=a(b.target);c.hasClass("btn")||(c=c.closest(".btn")),c.button("toggle")})}(window.jQuery),!function(a){var b=function(b,c){this.$element=a(b),this.options=a.extend({},a.fn.collapse.defaults,c),this.options.parent&&(this.$parent=a(this.options.parent)),this.options.toggle&&this.toggle()};b.prototype={constructor:b,dimension:function(){var a=this.$element.hasClass("width");return a?"width":"height"},show:function(){var b,c,d,e;if(this.transitioning||this.$element.hasClass("in"))return;b=this.dimension(),c=a.camelCase(["scroll",b].join("-")),d=this.$parent&&this.$parent.find("> .accordion-group > .in");if(d&&d.length){e=d.data("collapse");if(e&&e.transitioning)return;d.collapse("hide"),e||d.data("collapse",null)}this.$element[b](0),this.transition("addClass",a.Event("show"),"shown"),a.support.transition&&this.$element[b](this.$element[0][c])},hide:function(){var b;if(this.transitioning||!this.$element.hasClass("in"))return;b=this.dimension(),this.reset(this.$element[b]()),this.transition("removeClass",a.Event("hide"),"hidden"),this.$element[b](0)},reset:function(a){var b=this.dimension();return this.$element.removeClass("collapse")[b](a||"auto")[0].offsetWidth,this.$element[a!==null?"addClass":"removeClass"]("collapse"),this},transition:function(b,c,d){var e=this,f=function(){c.type=="show"&&e.reset(),e.transitioning=0,e.$element.trigger(d)};this.$element.trigger(c);if(c.isDefaultPrevented())return;this.transitioning=1,this.$element[b]("in"),a.support.transition&&this.$element.hasClass("collapse")?this.$element.one(a.support.transition.end,f):f()},toggle:function(){this[this.$element.hasClass("in")?"hide":"show"]()}};var c=a.fn.collapse;a.fn.collapse=function(c){return this.each(function(){var d=a(this),e=d.data("collapse"),f=a.extend({},a.fn.collapse.defaults,d.data(),typeof c=="object"&&c);e||d.data("collapse",e=new b(this,f)),typeof c=="string"&&e[c]()})},a.fn.collapse.defaults={toggle:!0},a.fn.collapse.Constructor=b,a.fn.collapse.noConflict=function(){return a.fn.collapse=c,this},a(document).on("click.collapse.data-api","[data-toggle=collapse]",function(b){var c=a(this),d,e=c.attr("data-target")||b.preventDefault()||(d=c.attr("href"))&&d.replace(/.*(?=#[^\s]+$)/,""),f=a(e).data("collapse")?"toggle":c.data();c[a(e).hasClass("in")?"addClass":"removeClass"]("collapsed"),a(e).collapse(f)})}(window.jQuery),!function(a){var b=function(b,c){this.$element=a(b),this.$indicators=this.$element.find(".carousel-indicators"),this.options=c,this.options.pause=="hover"&&this.$element.on("mouseenter",a.proxy(this.pause,this)).on("mouseleave",a.proxy(this.cycle,this))};b.prototype={cycle:function(b){return b||(this.paused=!1),this.interval&&clearInterval(this.interval),this.options.interval&&!this.paused&&(this.interval=setInterval(a.proxy(this.next,this),this.options.interval)),this},getActiveIndex:function(){return this.$active=this.$element.find(".item.active"),this.$items=this.$active.parent().children(),this.$items.index(this.$active)},to:function(b){var c=this.getActiveIndex(),d=this;if(b>this.$items.length-1||b<0)return;return this.sliding?this.$element.one("slid",function(){d.to(b)}):c==b?this.pause().cycle():this.slide(b>c?"next":"prev",a(this.$items[b]))},pause:function(b){return b||(this.paused=!0),this.$element.find(".next, .prev").length&&a.support.transition.end&&(this.$element.trigger(a.support.transition.end),this.cycle(!0)),clearInterval(this.interval),this.interval=null,this},next:function(){if(this.sliding)return;return this.slide("next")},prev:function(){if(this.sliding)return;return this.slide("prev")},slide:function(b,c){var d=this.$element.find(".item.active"),e=c||d[b](),f=this.interval,g=b=="next"?"left":"right",h=b=="next"?"first":"last",i=this,j;this.sliding=!0,f&&this.pause(),e=e.length?e:this.$element.find(".item")[h](),j=a.Event("slide",{relatedTarget:e[0],direction:g});if(e.hasClass("active"))return;this.$indicators.length&&(this.$indicators.find(".active").removeClass("active"),this.$element.one("slid",function(){var b=a(i.$indicators.children()[i.getActiveIndex()]);b&&b.addClass("active")}));if(a.support.transition&&this.$element.hasClass("slide")){this.$element.trigger(j);if(j.isDefaultPrevented())return;e.addClass(b),e[0].offsetWidth,d.addClass(g),e.addClass(g),this.$element.one(a.support.transition.end,function(){e.removeClass([b,g].join(" ")).addClass("active"),d.removeClass(["active",g].join(" ")),i.sliding=!1,setTimeout(function(){i.$element.trigger("slid")},0)})}else{this.$element.trigger(j);if(j.isDefaultPrevented())return;d.removeClass("active"),e.addClass("active"),this.sliding=!1,this.$element.trigger("slid")}return f&&this.cycle(),this}};var c=a.fn.carousel;a.fn.carousel=function(c){return this.each(function(){var d=a(this),e=d.data("carousel"),f=a.extend({},a.fn.carousel.defaults,typeof c=="object"&&c),g=typeof c=="string"?c:f.slide;e||d.data("carousel",e=new b(this,f)),typeof c=="number"?e.to(c):g?e[g]():f.interval&&e.pause().cycle()})},a.fn.carousel.defaults={interval:5e3,pause:"hover"},a.fn.carousel.Constructor=b,a.fn.carousel.noConflict=function(){return a.fn.carousel=c,this},a(document).on("click.carousel.data-api","[data-slide], [data-slide-to]",function(b){var c=a(this),d,e=a(c.attr("data-target")||(d=c.attr("href"))&&d.replace(/.*(?=#[^\s]+$)/,"")),f=a.extend({},e.data(),c.data()),g;e.carousel(f),(g=c.attr("data-slide-to"))&&e.data("carousel").pause().to(g).cycle(),b.preventDefault()})}(window.jQuery),!function(a){var b=function(b,c){this.$element=a(b),this.options=a.extend({},a.fn.typeahead.defaults,c),this.matcher=this.options.matcher||this.matcher,this.sorter=this.options.sorter||this.sorter,this.highlighter=this.options.highlighter||this.highlighter,this.updater=this.options.updater||this.updater,this.source=this.options.source,this.$menu=a(this.options.menu),this.shown=!1,this.listen()};b.prototype={constructor:b,select:function(){var a=this.$menu.find(".active").attr("data-value");return this.$element.val(this.updater(a)).change(),this.hide()},updater:function(a){return a},show:function(){var b=a.extend({},this.$element.position(),{height:this.$element[0].offsetHeight});return this.$menu.insertAfter(this.$element).css({top:b.top+b.height,left:b.left}).show(),this.shown=!0,this},hide:function(){return this.$menu.hide(),this.shown=!1,this},lookup:function(b){var c;return this.query=this.$element.val(),!this.query||this.query.length<this.options.minLength?this.shown?this.hide():this:(c=a.isFunction(this.source)?this.source(this.query,a.proxy(this.process,this)):this.source,c?this.process(c):this)},process:function(b){var c=this;return b=a.grep(b,function(a){return c.matcher(a)}),b=this.sorter(b),b.length?this.render(b.slice(0,this.options.items)).show():this.shown?this.hide():this},matcher:function(a){return~a.toLowerCase().indexOf(this.query.toLowerCase())},sorter:function(a){var b=[],c=[],d=[],e;while(e=a.shift())e.toLowerCase().indexOf(this.query.toLowerCase())?~e.indexOf(this.query)?c.push(e):d.push(e):b.push(e);return b.concat(c,d)},highlighter:function(a){var b=this.query.replace(/[\-\[\]{}()*+?.,\\\^$|#\s]/g,"\\$&");return a.replace(new RegExp("("+b+")","ig"),function(a,b){return"<strong>"+b+"</strong>"})},render:function(b){var c=this;return b=a(b).map(function(b,d){return b=a(c.options.item).attr("data-value",d),b.find("a").html(c.highlighter(d)),b[0]}),b.first().addClass("active"),this.$menu.html(b),this},next:function(b){var c=this.$menu.find(".active").removeClass("active"),d=c.next();d.length||(d=a(this.$menu.find("li")[0])),d.addClass("active")},prev:function(a){var b=this.$menu.find(".active").removeClass("active"),c=b.prev();c.length||(c=this.$menu.find("li").last()),c.addClass("active")},listen:function(){this.$element.on("focus",a.proxy(this.focus,this)).on("blur",a.proxy(this.blur,this)).on("keypress",a.proxy(this.keypress,this)).on("keyup",a.proxy(this.keyup,this)),this.eventSupported("keydown")&&this.$element.on("keydown",a.proxy(this.keydown,this)),this.$menu.on("click",a.proxy(this.click,this)).on("mouseenter","li",a.proxy(this.mouseenter,this)).on("mouseleave","li",a.proxy(this.mouseleave,this))},eventSupported:function(a){var b=a in this.$element;return b||(this.$element.setAttribute(a,"return;"),b=typeof this.$element[a]=="function"),b},move:function(a){if(!this.shown)return;switch(a.keyCode){case 9:case 13:case 27:a.preventDefault();break;case 38:a.preventDefault(),this.prev();break;case 40:a.preventDefault(),this.next()}a.stopPropagation()},keydown:function(b){this.suppressKeyPressRepeat=~a.inArray(b.keyCode,[40,38,9,13,27]),this.move(b)},keypress:function(a){if(this.suppressKeyPressRepeat)return;this.move(a)},keyup:function(a){switch(a.keyCode){case 40:case 38:case 16:case 17:case 18:break;case 9:case 13:if(!this.shown)return;this.select();break;case 27:if(!this.shown)return;this.hide();break;default:this.lookup()}a.stopPropagation(),a.preventDefault()},focus:function(a){this.focused=!0},blur:function(a){this.focused=!1,!this.mousedover&&this.shown&&this.hide()},click:function(a){a.stopPropagation(),a.preventDefault(),this.select(),this.$element.focus()},mouseenter:function(b){this.mousedover=!0,this.$menu.find(".active").removeClass("active"),a(b.currentTarget).addClass("active")},mouseleave:function(a){this.mousedover=!1,!this.focused&&this.shown&&this.hide()}};var c=a.fn.typeahead;a.fn.typeahead=function(c){return this.each(function(){var d=a(this),e=d.data("typeahead"),f=typeof c=="object"&&c;e||d.data("typeahead",e=new b(this,f)),typeof c=="string"&&e[c]()})},a.fn.typeahead.defaults={source:[],items:8,menu:'<ul class="typeahead dropdown-menu"></ul>',item:'<li><a href="#"></a></li>',minLength:1},a.fn.typeahead.Constructor=b,a.fn.typeahead.noConflict=function(){return a.fn.typeahead=c,this},a(document).on("focus.typeahead.data-api",'[data-provide="typeahead"]',function(b){var c=a(this);if(c.data("typeahead"))return;c.typeahead(c.data())})}(window.jQuery)
!function($){var $window=$(window);function UTCDate(){return new Date(Date.UTC.apply(Date,arguments))}function UTCToday(){var today=new Date;return UTCDate(today.getUTCFullYear(),today.getUTCMonth(),today.getUTCDate())}var Datepicker=function(element,options){var that=this;this._process_options(options);this.element=$(element);this.isInline=false;this.isInput=this.element.is("input");this.component=this.element.is(".date")?this.element.find(".add-on, .btn"):false;this.hasInput=this.component&&this.element.find("input").length;if(this.component&&this.component.length===0)this.component=false;this.picker=$(DPGlobal.template);this._buildEvents();this._attachEvents();if(this.isInline){this.picker.addClass("datepicker-inline").appendTo(this.element)}else{this.picker.addClass("datepicker-dropdown dropdown-menu")}if(this.o.rtl){this.picker.addClass("datepicker-rtl");this.picker.find(".prev i, .next i").toggleClass("icon-arrow-left icon-arrow-right")}this.viewMode=this.o.startView;if(this.o.calendarWeeks)this.picker.find("tfoot th.today").attr("colspan",function(i,val){return parseInt(val)+1});this._allow_update=false;this.setStartDate(this._o.startDate);this.setEndDate(this._o.endDate);this.setDaysOfWeekDisabled(this.o.daysOfWeekDisabled);this.fillDow();this.fillMonths();this._allow_update=true;this.update();this.showMode();if(this.isInline){this.show()}};Datepicker.prototype={constructor:Datepicker,_process_options:function(opts){this._o=$.extend({},this._o,opts);var o=this.o=$.extend({},this._o);var lang=o.language;if(!dates[lang]){lang=lang.split("-")[0];if(!dates[lang])lang=defaults.language}o.language=lang;switch(o.startView){case 2:case"decade":o.startView=2;break;case 1:case"year":o.startView=1;break;default:o.startView=0}switch(o.minViewMode){case 1:case"months":o.minViewMode=1;break;case 2:case"years":o.minViewMode=2;break;default:o.minViewMode=0}o.startView=Math.max(o.startView,o.minViewMode);o.weekStart%=7;o.weekEnd=(o.weekStart+6)%7;var format=DPGlobal.parseFormat(o.format);if(o.startDate!==-Infinity){if(!!o.startDate){if(o.startDate instanceof Date)o.startDate=this._local_to_utc(this._zero_time(o.startDate));else o.startDate=DPGlobal.parseDate(o.startDate,format,o.language)}else{o.startDate=-Infinity}}if(o.endDate!==Infinity){if(!!o.endDate){if(o.endDate instanceof Date)o.endDate=this._local_to_utc(this._zero_time(o.endDate));else o.endDate=DPGlobal.parseDate(o.endDate,format,o.language)}else{o.endDate=Infinity}}o.daysOfWeekDisabled=o.daysOfWeekDisabled||[];if(!$.isArray(o.daysOfWeekDisabled))o.daysOfWeekDisabled=o.daysOfWeekDisabled.split(/[,\s]*/);o.daysOfWeekDisabled=$.map(o.daysOfWeekDisabled,function(d){return parseInt(d,10)});var plc=String(o.orientation).toLowerCase().split(/\s+/g),_plc=o.orientation.toLowerCase();plc=$.grep(plc,function(word){return/^auto|left|right|top|bottom$/.test(word)});o.orientation={x:"auto",y:"auto"};if(!_plc||_plc==="auto");else if(plc.length===1){switch(plc[0]){case"top":case"bottom":o.orientation.y=plc[0];break;case"left":case"right":o.orientation.x=plc[0];break}}else{_plc=$.grep(plc,function(word){return/^left|right$/.test(word)});o.orientation.x=_plc[0]||"auto";_plc=$.grep(plc,function(word){return/^top|bottom$/.test(word)});o.orientation.y=_plc[0]||"auto"}},_events:[],_secondaryEvents:[],_applyEvents:function(evs){for(var i=0,el,ev;i<evs.length;i++){el=evs[i][0];ev=evs[i][1];el.on(ev)}},_unapplyEvents:function(evs){for(var i=0,el,ev;i<evs.length;i++){el=evs[i][0];ev=evs[i][1];el.off(ev)}},_buildEvents:function(){if(this.isInput){this._events=[[this.element,{focus:$.proxy(this.show,this),keyup:$.proxy(this.update,this),keydown:$.proxy(this.keydown,this)}]]}else if(this.component&&this.hasInput){this._events=[[this.element.find("input"),{focus:$.proxy(this.show,this),keyup:$.proxy(this.update,this),keydown:$.proxy(this.keydown,this)}],[this.component,{click:$.proxy(this.show,this)}]]}else if(this.element.is("div")){this.isInline=true}else{this._events=[[this.element,{click:$.proxy(this.show,this)}]]}this._secondaryEvents=[[this.picker,{click:$.proxy(this.click,this)}],[$(window),{resize:$.proxy(this.place,this)}],[$(document),{mousedown:$.proxy(function(e){if(!(this.element.is(e.target)||this.element.find(e.target).length||this.picker.is(e.target)||this.picker.find(e.target).length)){this.hide()}},this)}]]},_attachEvents:function(){this._detachEvents();this._applyEvents(this._events)},_detachEvents:function(){this._unapplyEvents(this._events)},_attachSecondaryEvents:function(){this._detachSecondaryEvents();this._applyEvents(this._secondaryEvents)},_detachSecondaryEvents:function(){this._unapplyEvents(this._secondaryEvents)},_trigger:function(event,altdate){var date=altdate||this.date,local_date=this._utc_to_local(date);this.element.trigger({type:event,date:local_date,format:$.proxy(function(altformat){var format=altformat||this.o.format;return DPGlobal.formatDate(date,format,this.o.language)},this)})},show:function(e){if(!this.isInline)this.picker.appendTo("body");this.picker.show();this.height=this.component?this.component.outerHeight():this.element.outerHeight();this.place();this._attachSecondaryEvents();if(e){e.preventDefault()}this._trigger("show")},hide:function(e){if(this.isInline)return;if(!this.picker.is(":visible"))return;this.picker.hide().detach();this._detachSecondaryEvents();this.viewMode=this.o.startView;this.showMode();if(this.o.forceParse&&(this.isInput&&this.element.val()||this.hasInput&&this.element.find("input").val()))this.setValue();this._trigger("hide")},remove:function(){this.hide();this._detachEvents();this._detachSecondaryEvents();this.picker.remove();delete this.element.data().datepicker;if(!this.isInput){delete this.element.data().date}},_utc_to_local:function(utc){return new Date(utc.getTime()+utc.getTimezoneOffset()*6e4)},_local_to_utc:function(local){return new Date(local.getTime()-local.getTimezoneOffset()*6e4)},_zero_time:function(local){return new Date(local.getFullYear(),local.getMonth(),local.getDate())},_zero_utc_time:function(utc){return new Date(Date.UTC(utc.getUTCFullYear(),utc.getUTCMonth(),utc.getUTCDate()))},getDate:function(){return this._utc_to_local(this.getUTCDate())},getUTCDate:function(){return this.date},setDate:function(d){this.setUTCDate(this._local_to_utc(d))},setUTCDate:function(d){this.date=d;this.setValue()},setValue:function(){var formatted=this.getFormattedDate();if(!this.isInput){if(this.component){this.element.find("input").val(formatted).change()}}else{this.element.val(formatted).change()}},getFormattedDate:function(format){if(format===undefined)format=this.o.format;return DPGlobal.formatDate(this.date,format,this.o.language)},setStartDate:function(startDate){this._process_options({startDate:startDate});this.update();this.updateNavArrows()},setEndDate:function(endDate){this._process_options({endDate:endDate});this.update();this.updateNavArrows()},setDaysOfWeekDisabled:function(daysOfWeekDisabled){this._process_options({daysOfWeekDisabled:daysOfWeekDisabled});this.update();this.updateNavArrows()},place:function(){if(this.isInline)return;var calendarWidth=this.picker.outerWidth(),calendarHeight=this.picker.outerHeight(),visualPadding=10,windowWidth=$window.width(),windowHeight=$window.height(),scrollTop=$window.scrollTop();var zIndex=parseInt(this.element.parents().filter(function(){return $(this).css("z-index")!="auto"}).first().css("z-index"))+10;var offset=this.component?this.component.parent().offset():this.element.offset();var height=this.component?this.component.outerHeight(true):this.element.outerHeight(false);var width=this.component?this.component.outerWidth(true):this.element.outerWidth(false);var left=offset.left,top=offset.top;this.picker.removeClass("datepicker-orient-top datepicker-orient-bottom "+"datepicker-orient-right datepicker-orient-left");if(this.o.orientation.x!=="auto"){this.picker.addClass("datepicker-orient-"+this.o.orientation.x);if(this.o.orientation.x==="right")left-=calendarWidth-width}else{this.picker.addClass("datepicker-orient-left");if(offset.left<0)left-=offset.left-visualPadding;else if(offset.left+calendarWidth>windowWidth)left=windowWidth-calendarWidth-visualPadding}var yorient=this.o.orientation.y,top_overflow,bottom_overflow;if(yorient==="auto"){top_overflow=-scrollTop+offset.top-calendarHeight;bottom_overflow=scrollTop+windowHeight-(offset.top+height+calendarHeight);if(Math.max(top_overflow,bottom_overflow)===bottom_overflow)yorient="top";else yorient="bottom"}this.picker.addClass("datepicker-orient-"+yorient);if(yorient==="top")top+=height;else top-=calendarHeight+parseInt(this.picker.css("padding-top"));this.picker.css({top:top,left:left,zIndex:zIndex})},_allow_update:true,update:function(){if(!this._allow_update)return;var oldDate=new Date(this.date),date,fromArgs=false;if(arguments&&arguments.length&&(typeof arguments[0]==="string"||arguments[0]instanceof Date)){date=arguments[0];if(date instanceof Date)date=this._local_to_utc(date);fromArgs=true}else{date=this.isInput?this.element.val():this.element.data("date")||this.element.find("input").val();delete this.element.data().date}this.date=DPGlobal.parseDate(date,this.o.format,this.o.language);if(fromArgs){this.setValue()}else if(date){if(oldDate.getTime()!==this.date.getTime())this._trigger("changeDate")}else{this._trigger("clearDate")}if(this.date<this.o.startDate){this.viewDate=new Date(this.o.startDate);this.date=new Date(this.o.startDate)}else if(this.date>this.o.endDate){this.viewDate=new Date(this.o.endDate);this.date=new Date(this.o.endDate)}else{this.viewDate=new Date(this.date);this.date=new Date(this.date)}this.fill()},fillDow:function(){var dowCnt=this.o.weekStart,html="<tr>";if(this.o.calendarWeeks){var cell='<th class="cw">&nbsp;</th>';html+=cell;this.picker.find(".datepicker-days thead tr:first-child").prepend(cell)}while(dowCnt<this.o.weekStart+7){html+='<th class="dow">'+dates[this.o.language].daysMin[dowCnt++%7]+"</th>"}html+="</tr>";this.picker.find(".datepicker-days thead").append(html)},fillMonths:function(){var html="",i=0;while(i<12){html+='<span class="month">'+dates[this.o.language].monthsShort[i++]+"</span>"}this.picker.find(".datepicker-months td").html(html)},setRange:function(range){if(!range||!range.length)delete this.range;else this.range=$.map(range,function(d){return d.valueOf()});this.fill()},getClassNames:function(date){var cls=[],year=this.viewDate.getUTCFullYear(),month=this.viewDate.getUTCMonth(),currentDate=this.date.valueOf(),today=new Date;if(date.getUTCFullYear()<year||date.getUTCFullYear()==year&&date.getUTCMonth()<month){cls.push("old")}else if(date.getUTCFullYear()>year||date.getUTCFullYear()==year&&date.getUTCMonth()>month){cls.push("new")}if(this.o.todayHighlight&&date.getUTCFullYear()==today.getFullYear()&&date.getUTCMonth()==today.getMonth()&&date.getUTCDate()==today.getDate()){cls.push("today")}if(currentDate&&date.valueOf()==currentDate){cls.push("active")}if(date.valueOf()<this.o.startDate||date.valueOf()>this.o.endDate||$.inArray(date.getUTCDay(),this.o.daysOfWeekDisabled)!==-1){cls.push("disabled")}if(this.range){if(date>this.range[0]&&date<this.range[this.range.length-1]){cls.push("range")}if($.inArray(date.valueOf(),this.range)!=-1){cls.push("selected")}}return cls},fill:function(){var d=new Date(this.viewDate),year=d.getUTCFullYear(),month=d.getUTCMonth(),startYear=this.o.startDate!==-Infinity?this.o.startDate.getUTCFullYear():-Infinity,startMonth=this.o.startDate!==-Infinity?this.o.startDate.getUTCMonth():-Infinity,endYear=this.o.endDate!==Infinity?this.o.endDate.getUTCFullYear():Infinity,endMonth=this.o.endDate!==Infinity?this.o.endDate.getUTCMonth():Infinity,currentDate=this.date&&this.date.valueOf(),tooltip;this.picker.find(".datepicker-days thead th.datepicker-switch").text(dates[this.o.language].months[month]+" "+year);this.picker.find("tfoot th.today").text(dates[this.o.language].today).toggle(this.o.todayBtn!==false);this.picker.find("tfoot th.clear").text(dates[this.o.language].clear).toggle(this.o.clearBtn!==false);this.updateNavArrows();this.fillMonths();var prevMonth=UTCDate(year,month-1,28,0,0,0,0),day=DPGlobal.getDaysInMonth(prevMonth.getUTCFullYear(),prevMonth.getUTCMonth());prevMonth.setUTCDate(day);prevMonth.setUTCDate(day-(prevMonth.getUTCDay()-this.o.weekStart+7)%7);var nextMonth=new Date(prevMonth);nextMonth.setUTCDate(nextMonth.getUTCDate()+42);nextMonth=nextMonth.valueOf();var html=[];var clsName;while(prevMonth.valueOf()<nextMonth){if(prevMonth.getUTCDay()==this.o.weekStart){html.push("<tr>");if(this.o.calendarWeeks){var ws=new Date(+prevMonth+(this.o.weekStart-prevMonth.getUTCDay()-7)%7*864e5),th=new Date(+ws+(7+4-ws.getUTCDay())%7*864e5),yth=new Date(+(yth=UTCDate(th.getUTCFullYear(),0,1))+(7+4-yth.getUTCDay())%7*864e5),calWeek=(th-yth)/864e5/7+1;html.push('<td class="cw">'+calWeek+"</td>")}}clsName=this.getClassNames(prevMonth);clsName.push("day");if(this.o.beforeShowDay!==$.noop){var before=this.o.beforeShowDay(this._utc_to_local(prevMonth));if(before===undefined)before={};else if(typeof before==="boolean")before={enabled:before};else if(typeof before==="string")before={classes:before};if(before.enabled===false)clsName.push("disabled");if(before.classes)clsName=clsName.concat(before.classes.split(/\s+/));if(before.tooltip)tooltip=before.tooltip}clsName=$.unique(clsName);html.push('<td class="'+clsName.join(" ")+'"'+(tooltip?' title="'+tooltip+'"':"")+">"+prevMonth.getUTCDate()+"</td>");if(prevMonth.getUTCDay()==this.o.weekEnd){html.push("</tr>")}prevMonth.setUTCDate(prevMonth.getUTCDate()+1)}this.picker.find(".datepicker-days tbody").empty().append(html.join(""));var currentYear=this.date&&this.date.getUTCFullYear();var months=this.picker.find(".datepicker-months").find("th:eq(1)").text(year).end().find("span").removeClass("active");if(currentYear&&currentYear==year){months.eq(this.date.getUTCMonth()).addClass("active")}if(year<startYear||year>endYear){months.addClass("disabled")}if(year==startYear){months.slice(0,startMonth).addClass("disabled")}if(year==endYear){months.slice(endMonth+1).addClass("disabled")}html="";year=parseInt(year/10,10)*10;var yearCont=this.picker.find(".datepicker-years").find("th:eq(1)").text(year+"-"+(year+9)).end().find("td");year-=1;for(var i=-1;i<11;i++){html+='<span class="year'+(i==-1?" old":i==10?" new":"")+(currentYear==year?" active":"")+(year<startYear||year>endYear?" disabled":"")+'">'+year+"</span>";year+=1}yearCont.html(html)},updateNavArrows:function(){if(!this._allow_update)return;var d=new Date(this.viewDate),year=d.getUTCFullYear(),month=d.getUTCMonth();switch(this.viewMode){case 0:if(this.o.startDate!==-Infinity&&year<=this.o.startDate.getUTCFullYear()&&month<=this.o.startDate.getUTCMonth()){this.picker.find(".prev").css({visibility:"hidden"})}else{this.picker.find(".prev").css({visibility:"visible"})}if(this.o.endDate!==Infinity&&year>=this.o.endDate.getUTCFullYear()&&month>=this.o.endDate.getUTCMonth()){this.picker.find(".next").css({visibility:"hidden"})}else{this.picker.find(".next").css({visibility:"visible"})}break;case 1:case 2:if(this.o.startDate!==-Infinity&&year<=this.o.startDate.getUTCFullYear()){this.picker.find(".prev").css({visibility:"hidden"})}else{this.picker.find(".prev").css({visibility:"visible"})}if(this.o.endDate!==Infinity&&year>=this.o.endDate.getUTCFullYear()){this.picker.find(".next").css({visibility:"hidden"})}else{this.picker.find(".next").css({visibility:"visible"})}break}},click:function(e){e.preventDefault();var target=$(e.target).closest("span, td, th");if(target.length==1){switch(target[0].nodeName.toLowerCase()){case"th":switch(target[0].className){case"datepicker-switch":this.showMode(1);break;case"prev":case"next":var dir=DPGlobal.modes[this.viewMode].navStep*(target[0].className=="prev"?-1:1);switch(this.viewMode){case 0:this.viewDate=this.moveMonth(this.viewDate,dir);this._trigger("changeMonth",this.viewDate);break;case 1:case 2:this.viewDate=this.moveYear(this.viewDate,dir);if(this.viewMode===1)this._trigger("changeYear",this.viewDate);break}this.fill();break;case"today":var date=new Date;date=UTCDate(date.getFullYear(),date.getMonth(),date.getDate(),0,0,0);this.showMode(-2);var which=this.o.todayBtn=="linked"?null:"view";this._setDate(date,which);break;case"clear":var element;if(this.isInput)element=this.element;else if(this.component)element=this.element.find("input");if(element)element.val("").change();this._trigger("changeDate");this.update();if(this.o.autoclose)this.hide();break}break;case"span":if(!target.is(".disabled")){this.viewDate.setUTCDate(1);if(target.is(".month")){var day=1;var month=target.parent().find("span").index(target);var year=this.viewDate.getUTCFullYear();this.viewDate.setUTCMonth(month);this._trigger("changeMonth",this.viewDate);if(this.o.minViewMode===1){this._setDate(UTCDate(year,month,day,0,0,0,0))}}else{var year=parseInt(target.text(),10)||0;var day=1;var month=0;this.viewDate.setUTCFullYear(year);this._trigger("changeYear",this.viewDate);if(this.o.minViewMode===2){this._setDate(UTCDate(year,month,day,0,0,0,0))}}this.showMode(-1);this.fill()}break;case"td":if(target.is(".day")&&!target.is(".disabled")){var day=parseInt(target.text(),10)||1;var year=this.viewDate.getUTCFullYear(),month=this.viewDate.getUTCMonth();if(target.is(".old")){if(month===0){month=11;year-=1}else{month-=1}}else if(target.is(".new")){if(month==11){month=0;year+=1}else{month+=1}}this._setDate(UTCDate(year,month,day,0,0,0,0))}break}}},_setDate:function(date,which){if(!which||which=="date")this.date=new Date(date);if(!which||which=="view")this.viewDate=new Date(date);this.fill();this.setValue();this._trigger("changeDate");var element;if(this.isInput){element=this.element}else if(this.component){element=this.element.find("input")}if(element){element.change()}if(this.o.autoclose&&(!which||which=="date")){this.hide()}},moveMonth:function(date,dir){if(!dir)return date;var new_date=new Date(date.valueOf()),day=new_date.getUTCDate(),month=new_date.getUTCMonth(),mag=Math.abs(dir),new_month,test;dir=dir>0?1:-1;if(mag==1){test=dir==-1?function(){return new_date.getUTCMonth()==month}:function(){return new_date.getUTCMonth()!=new_month};new_month=month+dir;new_date.setUTCMonth(new_month);if(new_month<0||new_month>11)new_month=(new_month+12)%12}else{for(var i=0;i<mag;i++)new_date=this.moveMonth(new_date,dir);new_month=new_date.getUTCMonth();new_date.setUTCDate(day);test=function(){return new_month!=new_date.getUTCMonth()}}while(test()){new_date.setUTCDate(--day);new_date.setUTCMonth(new_month)}return new_date},moveYear:function(date,dir){return this.moveMonth(date,dir*12)},dateWithinRange:function(date){return date>=this.o.startDate&&date<=this.o.endDate},keydown:function(e){if(this.picker.is(":not(:visible)")){if(e.keyCode==27)this.show();return}var dateChanged=false,dir,day,month,newDate,newViewDate;switch(e.keyCode){case 27:this.hide();e.preventDefault();break;case 37:case 39:if(!this.o.keyboardNavigation)break;dir=e.keyCode==37?-1:1;if(e.ctrlKey){newDate=this.moveYear(this.date,dir);newViewDate=this.moveYear(this.viewDate,dir);this._trigger("changeYear",this.viewDate)}else if(e.shiftKey){newDate=this.moveMonth(this.date,dir);newViewDate=this.moveMonth(this.viewDate,dir);this._trigger("changeMonth",this.viewDate)}else{newDate=new Date(this.date);newDate.setUTCDate(this.date.getUTCDate()+dir);newViewDate=new Date(this.viewDate);newViewDate.setUTCDate(this.viewDate.getUTCDate()+dir)}if(this.dateWithinRange(newDate)){this.date=newDate;this.viewDate=newViewDate;this.setValue();this.update();e.preventDefault();dateChanged=true}break;case 38:case 40:if(!this.o.keyboardNavigation)break;dir=e.keyCode==38?-1:1;if(e.ctrlKey){newDate=this.moveYear(this.date,dir);newViewDate=this.moveYear(this.viewDate,dir);this._trigger("changeYear",this.viewDate)}else if(e.shiftKey){newDate=this.moveMonth(this.date,dir);newViewDate=this.moveMonth(this.viewDate,dir);this._trigger("changeMonth",this.viewDate)}else{newDate=new Date(this.date);newDate.setUTCDate(this.date.getUTCDate()+dir*7);newViewDate=new Date(this.viewDate);newViewDate.setUTCDate(this.viewDate.getUTCDate()+dir*7)}if(this.dateWithinRange(newDate)){this.date=newDate;this.viewDate=newViewDate;this.setValue();this.update();e.preventDefault();dateChanged=true}break;case 13:this.hide();e.preventDefault();break;case 9:this.hide();break}if(dateChanged){this._trigger("changeDate");var element;if(this.isInput){element=this.element}else if(this.component){element=this.element.find("input")}if(element){element.change()}}},showMode:function(dir){if(dir){this.viewMode=Math.max(this.o.minViewMode,Math.min(2,this.viewMode+dir))}this.picker.find(">div").hide().filter(".datepicker-"+DPGlobal.modes[this.viewMode].clsName).css("display","block");this.updateNavArrows()}};var DateRangePicker=function(element,options){this.element=$(element);this.inputs=$.map(options.inputs,function(i){return i.jquery?i[0]:i});delete options.inputs;$(this.inputs).datepicker(options).bind("changeDate",$.proxy(this.dateUpdated,this));this.pickers=$.map(this.inputs,function(i){return $(i).data("datepicker")});this.updateDates()};DateRangePicker.prototype={updateDates:function(){this.dates=$.map(this.pickers,function(i){return i.date});this.updateRanges()},updateRanges:function(){var range=$.map(this.dates,function(d){return d.valueOf()});$.each(this.pickers,function(i,p){p.setRange(range)})},dateUpdated:function(e){var dp=$(e.target).data("datepicker"),new_date=dp.getUTCDate(),i=$.inArray(e.target,this.inputs),l=this.inputs.length;if(i==-1)return;if(new_date<this.dates[i]){while(i>=0&&new_date<this.dates[i]){this.pickers[i--].setUTCDate(new_date)}}else if(new_date>this.dates[i]){while(i<l&&new_date>this.dates[i]){this.pickers[i++].setUTCDate(new_date)}}this.updateDates()},remove:function(){$.map(this.pickers,function(p){p.remove()});delete this.element.data().datepicker}};function opts_from_el(el,prefix){var data=$(el).data(),out={},inkey,replace=new RegExp("^"+prefix.toLowerCase()+"([A-Z])"),prefix=new RegExp("^"+prefix.toLowerCase());for(var key in data)if(prefix.test(key)){inkey=key.replace(replace,function(_,a){return a.toLowerCase()});out[inkey]=data[key]}return out}function opts_from_locale(lang){var out={};if(!dates[lang]){lang=lang.split("-")[0];if(!dates[lang])return}var d=dates[lang];$.each(locale_opts,function(i,k){if(k in d)out[k]=d[k]});return out}var old=$.fn.datepicker;$.fn.datepicker=function(option){var args=Array.apply(null,arguments);args.shift();var internal_return,this_return;this.each(function(){var $this=$(this),data=$this.data("datepicker"),options=typeof option=="object"&&option;if(!data){var elopts=opts_from_el(this,"date"),xopts=$.extend({},defaults,elopts,options),locopts=opts_from_locale(xopts.language),opts=$.extend({},defaults,locopts,elopts,options);if($this.is(".input-daterange")||opts.inputs){var ropts={inputs:opts.inputs||$this.find("input").toArray()};$this.data("datepicker",data=new DateRangePicker(this,$.extend(opts,ropts)))}else{$this.data("datepicker",data=new Datepicker(this,opts))}}if(typeof option=="string"&&typeof data[option]=="function"){internal_return=data[option].apply(data,args);if(internal_return!==undefined)return false}});if(internal_return!==undefined)return internal_return;else return this};var defaults=$.fn.datepicker.defaults={autoclose:false,beforeShowDay:$.noop,calendarWeeks:false,clearBtn:false,daysOfWeekDisabled:[],endDate:Infinity,forceParse:true,format:"mm/dd/yyyy",keyboardNavigation:true,language:"en",minViewMode:0,orientation:"auto",rtl:false,startDate:-Infinity,startView:0,todayBtn:false,todayHighlight:false,weekStart:0};var locale_opts=$.fn.datepicker.locale_opts=["format","rtl","weekStart"];$.fn.datepicker.Constructor=Datepicker;var dates=$.fn.datepicker.dates={en:{days:["Sunday","Monday","Tuesday","Wednesday","Thursday","Friday","Saturday","Sunday"],daysShort:["Sun","Mon","Tue","Wed","Thu","Fri","Sat","Sun"],daysMin:["Su","Mo","Tu","We","Th","Fr","Sa","Su"],months:["January","February","March","April","May","June","July","August","September","October","November","December"],monthsShort:["Jan","Feb","Mar","Apr","May","Jun","Jul","Aug","Sep","Oct","Nov","Dec"],today:"Today",clear:"Clear"}};var DPGlobal={modes:[{clsName:"days",navFnc:"Month",navStep:1},{clsName:"months",navFnc:"FullYear",navStep:1},{clsName:"years",navFnc:"FullYear",navStep:10}],isLeapYear:function(year){return year%4===0&&year%100!==0||year%400===0},getDaysInMonth:function(year,month){return[31,DPGlobal.isLeapYear(year)?29:28,31,30,31,30,31,31,30,31,30,31][month]},validParts:/dd?|DD?|mm?|MM?|yy(?:yy)?/g,nonpunctuation:/[^ -\/:-@\[\u3400-\u9fff-`{-~\t\n\r]+/g,parseFormat:function(format){var separators=format.replace(this.validParts,"\0").split("\0"),parts=format.match(this.validParts);if(!separators||!separators.length||!parts||parts.length===0){throw new Error("Invalid date format.")}return{separators:separators,parts:parts}},parseDate:function(date,format,language){if(date instanceof Date)return date;if(typeof format==="string")format=DPGlobal.parseFormat(format);if(/^[\-+]\d+[dmwy]([\s,]+[\-+]\d+[dmwy])*$/.test(date)){var part_re=/([\-+]\d+)([dmwy])/,parts=date.match(/([\-+]\d+)([dmwy])/g),part,dir;date=new Date;for(var i=0;i<parts.length;i++){part=part_re.exec(parts[i]);dir=parseInt(part[1]);switch(part[2]){case"d":date.setUTCDate(date.getUTCDate()+dir);break;case"m":date=Datepicker.prototype.moveMonth.call(Datepicker.prototype,date,dir);break;case"w":date.setUTCDate(date.getUTCDate()+dir*7);break;case"y":date=Datepicker.prototype.moveYear.call(Datepicker.prototype,date,dir);break}}return UTCDate(date.getUTCFullYear(),date.getUTCMonth(),date.getUTCDate(),0,0,0)}var parts=date&&date.match(this.nonpunctuation)||[],date=new Date,parsed={},setters_order=["yyyy","yy","M","MM","m","mm","d","dd"],setters_map={yyyy:function(d,v){return d.setUTCFullYear(v)},yy:function(d,v){return d.setUTCFullYear(2e3+v)},m:function(d,v){if(isNaN(d))return d;v-=1;while(v<0)v+=12;v%=12;d.setUTCMonth(v);while(d.getUTCMonth()!=v)d.setUTCDate(d.getUTCDate()-1);return d},d:function(d,v){return d.setUTCDate(v)}},val,filtered,part;setters_map["M"]=setters_map["MM"]=setters_map["mm"]=setters_map["m"];setters_map["dd"]=setters_map["d"];date=UTCDate(date.getFullYear(),date.getMonth(),date.getDate(),0,0,0);var fparts=format.parts.slice();if(parts.length!=fparts.length){fparts=$(fparts).filter(function(i,p){return $.inArray(p,setters_order)!==-1}).toArray()}if(parts.length==fparts.length){for(var i=0,cnt=fparts.length;i<cnt;i++){val=parseInt(parts[i],10);part=fparts[i];if(isNaN(val)){switch(part){case"MM":filtered=$(dates[language].months).filter(function(){var m=this.slice(0,parts[i].length),p=parts[i].slice(0,m.length);return m==p});val=$.inArray(filtered[0],dates[language].months)+1;break;case"M":filtered=$(dates[language].monthsShort).filter(function(){var m=this.slice(0,parts[i].length),p=parts[i].slice(0,m.length);return m==p});val=$.inArray(filtered[0],dates[language].monthsShort)+1;break}}parsed[part]=val}for(var i=0,_date,s;i<setters_order.length;i++){s=setters_order[i];if(s in parsed&&!isNaN(parsed[s])){_date=new Date(date);setters_map[s](_date,parsed[s]);if(!isNaN(_date))date=_date}}}return date},formatDate:function(date,format,language){if(typeof format==="string")format=DPGlobal.parseFormat(format);var val={d:date.getUTCDate(),D:dates[language].daysShort[date.getUTCDay()],DD:dates[language].days[date.getUTCDay()],m:date.getUTCMonth()+1,M:dates[language].monthsShort[date.getUTCMonth()],MM:dates[language].months[date.getUTCMonth()],yy:date.getUTCFullYear().toString().substring(2),yyyy:date.getUTCFullYear()};val.dd=(val.d<10?"0":"")+val.d;val.mm=(val.m<10?"0":"")+val.m;var date=[],seps=$.extend([],format.separators);for(var i=0,cnt=format.parts.length;i<=cnt;i++){if(seps.length)date.push(seps.shift());date.push(val[format.parts[i]])}return date.join("")},headTemplate:"<thead>"+"<tr>"+'<th class="prev">&laquo;</th>'+'<th colspan="5" class="datepicker-switch"></th>'+'<th class="next">&raquo;</th>'+"</tr>"+"</thead>",contTemplate:'<tbody><tr><td colspan="7"></td></tr></tbody>',footTemplate:'<tfoot><tr><th colspan="7" class="today"></th></tr><tr><th colspan="7" class="clear"></th></tr></tfoot>'};DPGlobal.template='<div class="datepicker">'+'<div class="datepicker-days">'+'<table class=" table-condensed">'+DPGlobal.headTemplate+"<tbody></tbody>"+DPGlobal.footTemplate+"</table>"+"</div>"+'<div class="datepicker-months">'+'<table class="table-condensed">'+DPGlobal.headTemplate+DPGlobal.contTemplate+DPGlobal.footTemplate+"</table>"+"</div>"+'<div class="datepicker-years">'+'<table class="table-condensed">'+DPGlobal.headTemplate+DPGlobal.contTemplate+DPGlobal.footTemplate+"</table>"+"</div>"+"</div>";$.fn.datepicker.DPGlobal=DPGlobal;$.fn.datepicker.noConflict=function(){$.fn.datepicker=old;return this};$(document).on("focus.datepicker.data-api click.datepicker.data-api",'[data-provide="datepicker"]',function(e){var $this=$(this);if($this.data("datepicker"))return;e.preventDefault();$this.datepicker("show")});$(function(){$('[data-provide="datepicker-inline"]').datepicker()})}(window.jQuery);
const SelfDeclaration = (props) => {

    const state = {
        isActive: false,
    };

    const setActive = (bool) => {
        //console.log('/SelfDeclaration/ -setActive', bool);
        state.isActive = bool;
    };

    const init = () => {

        state.isActive = true;

        props.events.on('AWAIT_FETCH', (payload) => {
            //console.log('/SelfDeclaration/ -', state.isActive);
            if (!state.isActive) return;
            //console.log('/popover/ -AWAIT_FETCH', payload.args);
            getData(payload.args);
        });
    };

    const getData = (options) => {

        if (!options.datasource) {
            //console.warn('/SelfDeclaration/ -getData --no datasource, quitting');
            return;
        }

        const fetchOptions = {
            datasource: `${options.datasource}`,
            caller: props.name,
        };
        const requestParams = props.requestModel.format({
            Key: '', Values: '', // *** simple request doesn't need anything
        });

        const fetchData = async () => {
            const data = await props.fetchData(fetchOptions, requestParams);
            //console.log('/SelfDeclaration/ -fetchData --success?', data.payload['Success']);

            if (data.payload['Success']) {
                //console.log('/SelfDeclaration/ -fetchData DONE');

                // redirect to new page url if redirection url is there
                const hcpConfirmationYes = document.getElementById('hcpConfirmationYes');
                const redirectionUrl = hcpConfirmationYes.dataset.redirectionUrl;
                props.events.emit(props.config.eventNames.CLOSE_POPOVER, {
                    args: {
                        CLOSE_POPOVER: 'closed on fetch success',
                        options,
                    }
                })
                if (redirectionUrl) {
                    window.location.href = redirectionUrl;
                }
                // we have to check wether marketing popup is open or not
                // calling one api in init function entire logic will preset in popover script init function
                props.events.emit('LAUNCH_POPOVER', {
                    type: 'marketing-email-popover',
                    popoverType: 'marketing-email-popover',
                    popoverDelay: 0.5,
                });
            }
            // *** do something on failure
        };

        fetchData();
    };


    const destroy = () => {

    };

    return {
        init,
        setActive,
        destroy,
    }
};

const FormChangeEmail = (props) => {
    const els = {
        el: null,
        fields: null,
    };

    const setActive = (bool) => {
    };

    const init = (data) => {
        objectify(data);
        // get the relevant fields
        els.el = props.el.querySelector('form[data-form-type=change-email]');
        if (els.el) {
            els.el.fields = [...els.el.querySelectorAll('input[type=email]')];
        }
        props.events.on(props.config.eventNames.FORM_PARTIAL_SUCCESS, (payload) => {
            if (payload.type !== 'change-email') return;
            closePopup(payload);
            window.location.reload();
            //openCodePopupAndClose(payload);
        });
    };

    const emptyFields = () => {
        if (els.el.fields) {
            els.el.fields.map((item) => {
                item.value = '';
            });
        }
    };

    const closePopup = (data = {}) => {
        emptyFields();
        // close current popup first
        props.events.emit(props.config.eventNames.CLOSE_POPOVER);
    };

    /* This is just for data coming in from the dom element being clicked to launch popup */
    const objectify = (data) => {
        const items = data.split(',');
        items.map((item) => {
            const itemPair = item.split(':');
            itemPair[0].trim();
            itemPair[1].trim();
        });
    };

    return {
        init,
        setActive,
    };
};

const FormChangeEmailCode = (props) => {
    const els = {
        el: null,
        fields: null,
    };

    const state = {
        uid: null,
        isActive: false,
        dataObject: {},
    };

    const setActive = (bool) => {
        state.isActive = bool;
    };

    const init = (data) => {
        // add form id and element id so we can use them later..
        state.dataObject = props.utils.toFlatPropertyMap(data);
        state.isActive = true;
        // get the relevant fields
        els.el = props.el.querySelector('form[data-form-type=change-email-code]');
        if (els.el) {
            els.el.fields = [...els.el.querySelectorAll('input[type=text]')];
        }
        props.events.on(props.config.eventNames.FORM_PARTIAL_SUCCESS, (payload) => {
            if (payload.type !== 'change-email-code') return;
            saveEmailAndClose(payload);
        });
    };

    const emptyFields = () => {
        if (els.el.fields) {
            els.el.fields = [...els.el.querySelectorAll('input[type=text]')];
            els.el.fields.map((item) => {
                item.value = '';
            });
        }
    };

    const saveEmailAndClose = (payload) => {
        emptyFields();
        props.events.emit(props.config.eventNames.CLOSE_POPOVER, {
            data: {
                formId: state.dataObject.formId,
                elementId: state.dataObject.elementId,
                elementValue: state.dataObject['data.Result.Profile.SecondEmail'],
                Success: payload['data']['Success'],
                StatusMessage: payload['data']['StatusMessage'],
            },
        });
    };

    return {
        init,
        setActive,
    };
};

const FormChangePassword = (props) => {
    const els = {
        el: null,
        form: null,
    };

    const state = {
        uid: null,
        isActive: false,
        dataObject: {},
    };

    const setActive = (bool) => {
        state.isActive = bool;
    };

    const init = (data) => {
        state.isActive = true;
        // add form id and element id so we can use them later..
        objectify(data);
        // get the relevant fields
        els.el = props.el.querySelector('form[data-form-type=change-password]');
        if (els.el) {
            els.el.fields = [...els.el.querySelectorAll('input[type=password]')];
        }
        // listen for the form submit event from formController
        props.events.on(props.config.eventNames.FORM_PARTIAL_SUCCESS, (payload) => {
            if (payload.type !== 'change-password') return;
            ClosePopup(payload);
        });
    };

    const emptyFields = () => {
        if (els.el.fields) {
            els.el.fields = [...els.el.querySelectorAll('input[type=password]')];
            els.el.fields.map((item) => {
                item.value = '';
            });
        }
    };

    const ClosePopup = (payload) => {
        emptyFields();
        props.events.emit(props.config.eventNames.CLOSE_POPOVER, {
            data: {
                formId: state.dataObject.formId,
                elementId: state.dataObject.elementId,
                Success: payload['data']['Success'],
                StatusMessage: payload['data']['StatusMessage'],
            },
        });
    };

    /* This is just for data coming in from the dom element being clicked to launch popup */
    const objectify = (data) => {
        const items = data.split(',');
        items.map((item) => {
            const itemPair = item.split(':');
            const key = itemPair[0].trim();
            const val = itemPair[1].trim();
            state.dataObject[key] = val;
        });
    };

    return {
        init,
        setActive,
    };
};

const ProductQuickview = (props) => {

    const classes = {
        title: 'product-quickview__title',
        productDescriptor: 'product-quickview__title__product-descriptor',
        description: 'product-quickview__description',
        imageWrapper: 'image-wrapper__popup',
        ctaButton: 'product-quickview__cta-button',
        ctaButtonLabel: 'product-quickview__cta-button__label',
    };

    const els = {
        el: null,
    };

    const setActive = (bool) => {
        //console.log('/ProductQuickview/ -setActive', bool);
    };

    const init = (options) => {
        update(options, props);
    };

    // ***
    const update = (options, props) => {

        // console.log('/ProductQuickview/ -update --options:', options);
        // console.log('/ProductQuickview/ -update --props:', props);

        els.el = props.el.querySelector(`[data-popover-type="product-quickview"]`);
        els.title = els.el.querySelector(`.${classes.title}`);
        els.description = els.el.querySelector(`.${classes.description}`);
        els.imageWrapper = els.el.querySelector(`.${classes.imageWrapper}`);

        els.title.innerHTML = options.raw.title;
        els.description.innerHTML = options.raw.description;

        els.ctaButton = els.el.querySelector(`.${classes.ctaButton}`);
        els.ctaButton.href = options.raw.url;
        els.ctaButton.addEventListener("click", () => {
            trackAalytics(options);
        });
        els.ctaButtonLabel = els.ctaButton.querySelector(`.${classes.ctaButtonLabel}`);
        els.ctaButtonLabel.innerText = options.raw.ctaButtonLabel;

        // console.log('/ProductQuickview/ -update --els:', els);

        if (options.raw.productDescriptor) {
            const span = document.createElement('span');
            span.classList.add(classes.productDescriptor);
            span.innerText = options.raw.productDescriptor;
            els.title.append(span);
        }

        // *** image
        const oldImage = els.imageWrapper.querySelector('img');
        if (oldImage) oldImage.remove();
        const image = document.createElement('img');
        image.setAttribute('src', options.raw.image);
        image.setAttribute('alt', options.raw.title);
        els.imageWrapper.appendChild(image);
    };

    const trackAalytics = (options) => {
        const trackingObj = {
            event: "click",
            click_element_type: "link",
            click_text: options.raw.ctaButtonLabel,
            link_url: options.raw.url
        }
        window.dataLayer.push(trackingObj);
    }

    const destroy = () => {

    };

    return {
        init,
        setActive,
        update,
        destroy,
    }
};


const PageSharePopOver = (props) => {

    const els = {
        el: null,
        urlField: null,
        copyBtn: null,
    };

    const setActive = (bool) => {
    };

    const init = () => {

        els.el = props.el;
        els.urlField = els.el.querySelector('.share-url-field');
        els.urlField.value = window.location.href;
        els.shareButtons = els.el.querySelector('.st-inline-share-buttons');
        if (els.shareButtons) {
            for (item in els.shareButtons.children) {
                if (els.shareButtons.children[item] && els.shareButtons.children[item].innerHTML) {
                    if (window.location.pathname.toLowerCase().includes('zh-cn') && ['email', 'wechat'].indexOf(els.shareButtons.children[item].dataset.network) === -1) {
                        els.shareButtons.children[item].setAttribute('style', 'display:none !important');
                    }
                    els.shareButtons.children[item].addEventListener('click', (e) => {
                        let networkType = e.target.dataset.network;
                        if (!networkType && e.target.closest('.st-btn')) {
                            networkType = e.target.closest('.st-btn').dataset.network;
                            const trackingDetails = {
                                event: 'share',
                                method: networkType,
                                content_type: 'web page',
                                item_id: els.urlField.value || null,
                            }
                            window.dataLayer = window.dataLayer || [];
                            window.dataLayer.push(trackingDetails);
                        }
                    })
                }

            }
        
    }

    };


return {
    init,
    setActive,
   };
};

// import Behaviours from '../../../core/js/behaviours';

const LanguageSelector = (props) => {

    const els = {
        el: null,
        parentInner: null, // *** for calcs only
        tabstack: null,
    };

    const state = {
        groups: null,
    };

    const classes = {
        group: 'language-selector__group',
        tabstack: 'tabstack',
        selectorItem: 'language-selector__item',
        itemIsEnabled: 'popover__item--is-enabled',
    };

    const setActive = (bool) => {
        state.isActive = bool;
    };


    const init = () => {

        // console.log('/LanguageSelector/ -init', props);

        els.selectorItem = [...document.body.querySelectorAll(`.${classes.selectorItem}`)];

        els.selectorItem.map((item) => {

            item.onclick = function () {
                const languageConfirmationYes = document.getElementById('language-confirmation-yes');
                const languageConfirmationText = document.getElementById('languageConfirmationText');
                languageConfirmationText.innerHTML = `${item.dataset.languageConfirmationText}`
                const redirectionUrl = getRedirectionUrl(item.dataset.redirectionUrl);
                languageConfirmationYes.dataset.redirectionUrl = redirectionUrl;
                const languageSelector = document.querySelector('[data-popover-type="language-selector"]');
                languageSelector.classList.remove(classes.itemIsEnabled);
            }

        })
    }

    // get redirection url
    const getRedirectionUrl = (url) => {
        let redirectionUrl = url;
        const country = localStorage.getItem("country");
        if (country === "true") {
            const productsList = ['allevyn-foam-dressings-new', 'allevyn-adhesive-global', 'allevyn-gentle-border-lite-global', 'allevyn-gentle-border', 'allevyn-life'];
            productsList.forEach(item => {
                if (window.location.pathname.includes(item)) {
                    let pathArr = window.location.pathname.split('/');
                    pathArr.splice(0, 2);
                    const productUrl = pathArr.join('/');
                    redirectionUrl = `${url}${productUrl}`;
                    localStorage.removeItem("country");
                }
            });
        }
        return redirectionUrl;
    }

    // *** invoked on parent animation done, use this optional method if dom inspection required
    const ready = (parentEls, props) => {
        if (!els.parentInner) {
            els.parentInner = parentEls.inner;
        }
        props.events.on(props.config.eventNames.APP_BREAKPOINT_READY, (payload) => {
            setHeights(props);
        });
        setHeights(props);
    };

    const setHeights = (props) => {

        if (!els.el) {
            els.el = document.body.querySelector(`[data-popover-type="language-selector"]`);
            state.groups = [...els.el.querySelectorAll(`.${classes.group}`)];
            els.tabstack = els.parentInner.querySelector(`.${classes.tabstack}`);

            // *** override tabstack defaults and force update
            const tabstackOptions = props.getBehaviourRaw(els.tabstack).options;
            tabstackOptions.state.selfAnimate = true;
            tabstackOptions.state.setHeight = false;
            tabstackOptions.update(0);
        }

        let maxHeight = 0;
        state.groups.map((item) => {
            const h = item.getBoundingClientRect().height;
            if (h > maxHeight) maxHeight = h;
        });

        els.tabstack.style.height = `${maxHeight}px`;
    };

    return {
        init,
        setActive,
        ready,
    };


};

const LanguageConfirmation = (props) => {
    const state = {
        isActive: false,
    };

    const classes = {
        itemIsEnabled: 'popover__item--is-enabled',
    }
    const setActive = (bool) => {

        state.isActive = bool;

    };

    const init = () => {

        // console.log('/LanguageConfirmation/ -init', props);

        const languageConfirmationNo = document.getElementById('language-confirmation-no');
        const languageConfirmationYes = document.getElementById('language-confirmation-yes');

        languageConfirmationYes.onclick = () => {
            onLanguageConfirmation();
        }

        languageConfirmationNo.onclick = function () {

            const languageConfirmationYes = document.getElementById('language-confirmation-yes');
            const corporatePageLink = languageConfirmationYes.dataset.corporatePageLink;
            const exploreExternalPopup = languageConfirmationYes.dataset.exploreExternalPopup;
            const isCountryPage = languageConfirmationYes.dataset.iscountryPage;
            if (corporatePageLink === "true" || exploreExternalPopup === "true") {
                delete languageConfirmationYes.dataset.corporatePageLink;
                delete languageConfirmationYes.dataset.exploreExternalPopup;
                props.events.emit(props.config.eventNames.CLOSE_POPOVER, {
                    args: {
                        CLOSE_POPOVER: 'closed confirmation popup'
                    }
                });
            } else if (isCountryPage === "true") {
                delete languageConfirmationYes.dataset.isCountryPage;
                props.events.emit(props.config.eventNames.CLOSE_POPOVER, {
                    args: {
                        CLOSE_POPOVER: 'closed confirmation popup'
                    }
                });
            } else {
                const languageSelector = document.querySelector('[data-popover-type="language-selector"]');
                const languageConfirmation = document.querySelector('[data-popover-type="language-confirmation"]');
                languageConfirmation.classList.remove(classes.itemIsEnabled)
                languageSelector.classList.add(classes.itemIsEnabled);
            }
        }

    }

    const onLanguageConfirmation = async () => {
        const languageConfirmationYes = document.getElementById('language-confirmation-yes');
        const redirectionUrl = languageConfirmationYes.dataset && languageConfirmationYes.dataset.redirectionUrl ?
            languageConfirmationYes.dataset.redirectionUrl : '';
        const corporatePageLink = languageConfirmationYes.dataset.corporatePageLink;
        const isCountryPage = languageConfirmationYes.dataset.iscountryPage;
        if (corporatePageLink === "true") {
            window.open(`${redirectionUrl}`, '_blank');
            delete languageConfirmationYes.dataset.corporatePageLink;
            props.events.emit(props.config.eventNames.CLOSE_POPOVER, {
                args: {
                    CLOSE_POPOVER: 'closed confirmation popup'
                }
            });
        } else if (isCountryPage === "true") {
            window.location.href = redirectionUrl;
            delete languageConfirmationYes.dataset.isCountryPage;
            props.events.emit(props.config.eventNames.CLOSE_POPOVER, {
                args: {
                    CLOSE_POPOVER: 'closed confirmation popup'
                }
            });
        } else {
            const fetchOptions = {
                datasource: `/en/api/hcp/ManualCountrySelection`,
                caller: props.name,
            };
            const requestParams = props.requestModel.format({
                Key: '', Values: '', // *** simple request doesn't need anything
            });
            const data = await props.fetchData(fetchOptions, requestParams);
            if (data.payload && data.payload['Success'] && data.payload['Result'] && redirectionUrl) {
                window.location.href = redirectionUrl;
            }
        }
    }

    return {
        init,
        setActive,
    };
};





const LMSDetails = (props) => {

    const classes = {
        title: 'lms-details__title',
        description: 'lms-details__description',
        imageWrapper: 'image-wrapper__popup',
        ctaButton: 'lms-details__cta-button',
        ctaButtonLabel: 'lms-details__cta-button__label',
    };

    const els = {
        el: null,
    };

    const setActive = (bool) => {
        //console.log('/LMSDetails/ -setActive', bool);
    };

    const init = (options) => {
        update(options, props);
    };

    // ***
    const update = (options, props) => {

        // console.log('/LMSDetails/ -update --options:', options);
        // console.log('/LMSDetails/ -update --props:', props);

        els.el = props.el.querySelector(`[data-popover-type="lms-details"]`);
        els.title = els.el.querySelector(`.${classes.title}`);
        els.description = els.el.querySelector(`.${classes.description}`);
        //els.imageWrapper = els.el.querySelector(`.${classes.imageWrapper}`);

        els.title.innerHTML = options.raw.args.title;
        els.description.innerHTML = options.raw.args.description;

        els.ctaButton = els.el.querySelector(`.${classes.ctaButton}`);
        els.ctaButton.href = options.raw.args.url;

        els.ctaButtonLabel = els.ctaButton.querySelector(`.${classes.ctaButtonLabel}`);
        els.ctaButtonLabel.innerText = options.raw.args.ctaButtonLabel;

        // console.log('/LMSDetails/ -update --els:', els);

        // *** image, if ever needed
        //const oldImage = els.imageWrapper.querySelector('img');
        //if (oldImage) oldImage.remove();
        //const image = document.createElement('img');
        //image.setAttribute('src', options.raw.image);
        //image.setAttribute('alt', options.raw.title);
        //els.imageWrapper.appendChild(image);
    };

    const destroy = () => {

    };

    return {
        init,
        setActive,
        update,
        destroy,
    }
};

const HcpAhpraVerification = (props) => {

    const state = {
        isActive: false,
    };

    const classes = {
        itemIsEnabled: 'popover__item--is-enabled',
        toggleHcpAhpraSection: 'toggle-hcp-ahpra-section'
    }

    const setActive = (bool) => {
        state.isActive = bool;
    };

    const init = () => {
        // console.log('/HcpAhpraVerification/ -init', props);
    }

    return {
        init,
        setActive,
    };
};

const MarketingEmailPopover = (props) => {

    const state = {
        isActive: false,
    };

    const classes = {
        itemIsEnabled: 'popover__item--is-enabled',
        toggleHcpAhpraSection: 'toggle-hcp-ahpra-section'
    }

    const setActive = (bool) => {
        state.isActive = bool;
    };

    const init = () => {
        // console.log('/MarketingEmailPopover/ -init', props);
    }

    return {
        init,
        setActive,
    };

}
function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; }

function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { _defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }

function _toConsumableArray(arr) { return _arrayWithoutHoles(arr) || _iterableToArray(arr) || _unsupportedIterableToArray(arr) || _nonIterableSpread(); }

function _nonIterableSpread() { throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }

function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }

function _iterableToArray(iter) { if (typeof Symbol !== "undefined" && Symbol.iterator in Object(iter)) return Array.from(iter); }

function _arrayWithoutHoles(arr) { if (Array.isArray(arr)) return _arrayLikeToArray(arr); }

function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; }

function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }

var script = function script(props) {
    var _types;

    // *** optional js helpers - mapped with same name as the markup blob
    var types = (_types = {}, _defineProperty(_types, 'self-declaration', SelfDeclaration), _defineProperty(_types, 'form-change-email', FormChangeEmail), _defineProperty(_types, 'form-change-email-code', FormChangeEmailCode), _defineProperty(_types, 'form-change-password', FormChangePassword), _defineProperty(_types, 'product-quickview', ProductQuickview), _defineProperty(_types, 'page-share-popover', PageSharePopOver), _defineProperty(_types, 'language-selector', LanguageSelector), _defineProperty(_types, 'language-confirmation', LanguageConfirmation), _defineProperty(_types, 'lms-details', LMSDetails), _defineProperty(_types, 'ahpra-self-declaration', HcpAhpraVerification), _defineProperty(_types, 'marketing-email-popover', MarketingEmailPopover), _types);
    var state = {
        initialisedScripts: [],
        // TEST
        currentScript: null,
        // *** ref to item script
        hasItem: false // *** true if has item (via dom)

    };
    var classes = {
        isEnabled: 'popover--is-enabled',
        itemIsEnabled: 'popover__item--is-enabled',
        inner: 'popover__inner',
        item: 'popover__item',
        closeBtn: 'popover__close-btn',
        preventScroll: 'scrolling--prevent'
    };
    var els = {
        el: null,
        inner: null,
        closeBtn: null,
        items: []
    };
    var subProps = {
        animateYValue: '+30vh'
    };

    var init = function init() {
        //console.log('/popovers/ -init -props:', props); 
        //console.log('/popovers/ -init --types:', types);

        els.el = props.el;
        els.inner = els.el.querySelector(".".concat(classes.inner));
        els.closeBtn = els.el.querySelector(".".concat(classes.closeBtn));
        els.items = _toConsumableArray(els.inner.querySelectorAll(".".concat(classes.item)));
        /*props.events.on(props.config.eventNames.APP_BREAKPOINT_READY, (payload) => {
          console.log('/popover/ -APP_BREAKPOINT_READY', state.currentScript);
        });*/

        props.events.on(props.config.eventNames.LAUNCH_POPOVER, function (payload) {
            // console.log('/popovers/ -LAUNCH_POPOVER', payload);
            // check for product page while page render through qr code or not
            let isPopoverEnable = true;
            if (window.location.hash.includes('#country')) {
                if (payload.popoverLaunch === 'onload') {
                    isPopoverEnable = false;
                }
            }
            if (isPopoverEnable) {
                var vo = payload.args ? {
                    type: payload.args['LAUNCH_POPOVER']
                } : payload;
                vo.raw = _objectSpread({}, payload); // extra thing here for form stuff

                if (payload.args && payload.args['DATA']) vo['data'] = payload.args['DATA'];
                console.log('my vo', vo)
                
                if (vo.popoverType === "marketing-email-popover") {
                    const isMarketingPopUp = checkForMarketingPopup();
                    isMarketingPopUp.then((res) => {
                        if (res) {
                            if (isMarketingPopUp) {
                                const marketingPopoverDiv = document.querySelector('[data-popover-type="marketing-email-popover"]');
                                if (marketingPopoverDiv) {
                                    const popoverDuration = marketingPopoverDiv && marketingPopoverDiv.dataset.popoverDuration || 20;
                                    // by adding this class we can change background color of marketing email popup 
                                    if (els.inner && !els.inner.classList.contains('marketing-email')) {
                                        els.inner.classList.add('marketing-email')
                                    }
                                    const productUrl = window.location.href;
                                    setTimeout(() => {
                                        if (productUrl === window.location.href) {
                                            initItem(vo);
                                            show(vo);
                                    }
                                    }, popoverDuration * 1000)
                                }
                            }
                        }
                    })
                } else {
                    if (els.inner && els.inner.classList.contains('marketing-email')) {
                        els.inner.classList.remove('marketing-email')
                    }
                    initItem(vo);
                    show(vo);
                }
            }
        });
        props.events.on(props.config.eventNames.CLOSE_POPOVER, function (payload) {
            // console.log('/popover/ -CLOSE_POPOVER', payload);
            if (payload && payload.args && payload.args.popovertype === 'marketing-email') {
                if (els.inner && els.inner.classList.contains('marketing-email')) {
                    els.inner.classList.remove('marketing-email')
                }
                const today = new Date();
                let expire = new Date();
                expire.setTime(today.getTime() + 3600000 * 24 * 7)
                document.cookie = `${'marketingEmail'}=${true};expires=${expire.toGMTString()};path=${'/'}`;
            }
            deactivateItems();
            hide();
        });
        props.events.on('FOLLOW_LINK', function (payload) {
            ////console.log('/popover/ -FOLLOW_LINK', payload);
            // TODO 'target' (e.g. '_self') available in payload, honour this
            window.location = payload.args['FOLLOW_LINK'];
        });

        inspectGenericButtonAction();
        // *** auto open language selector popup for less waste more care page Qr code product page
        if (window.location.hash.includes('#country')) {
            inspectLessWasteAndMoreCareQRCodeProductPage();
        }
    };

    var checkForMarketingPopup = async () => {
        const fetchOptions = {
            datasource: `/en/api/hcp/showmarketingpopup`,
            caller: props.name,
        };
        const sitecoreContextItemID = document.getElementById('sitecoreContextItemID');
        const sitecoreContextLanguage = document.getElementById('sitecoreContextItemLanguage');
        if (sitecoreContextItemID) {
            const requestParams = {
                contextItemId: sitecoreContextItemID.value,
                contextLanguage: sitecoreContextLanguage.value,
            };
            const data = await props.fetchData(fetchOptions, requestParams);
            if (data.payload['Success'] && data.payload['showMarkettingPopUp']) {
                return true;
            }
            return false;
        }
    }

    var inspectLessWasteAndMoreCareQRCodeProductPage = function inspectLessWasteAndMoreCareQRCodeProductPage() {
        localStorage.setItem("country", "true");
        const productsList = ['allevyn-foam-dressings-new', 'allevyn-adhesive-global', 'allevyn-gentle-border-lite-global', 'allevyn-gentle-border', 'allevyn-life'];
        productsList.forEach(item => {
            if (window.location.pathname.includes(item)) {
                props.events.emit('LAUNCH_POPOVER', {
                    args: {
                        "LAUNCH_POPOVER": 'language-selector',
                    },
                });
            }
        })
    }

    // *** inspect page for relevant button actions
    var inspectGenericButtonAction = function inspectGenericButtonAction() {
        var actions = [props.config.eventNames.LAUNCH_POPOVER, props.config.eventNames.CLOSE_POPOVER, 'FOLLOW_LINK', 'AWAIT_FETCH'];

        _toConsumableArray(document.body.querySelectorAll("[data-button-action]")).map(function (item) {
            var action = item.getAttribute('data-button-action');
            if (!action) return;
            var args = props.utils.attributeParser(action, null, 'json');
            var key = Object.keys(args)[0];
            if (!actions.includes(key)) return;
            item.addEventListener('click', function () {
                ////console.log('/popover/ -button click:', key, args[key]);
                props.events.emit(key, {
                    args: args
                });
            });
        });
    }; // *** manage item scripts if present


    var getScript = function getScript(options) {
        var script = types[options.type];
        if (!script) return; // *** no matching script, quit

        state.currentScript = script;
        state.currentScript().setActive(true); // TEST see below FIXIT

        var existing = state.initialisedScripts.find(function (item) {
            return item.type === options.type;
        });

        if (existing) {
            // ***  script already init'd
            // existing.script().setActive(true); // FIXIT - fires twice, test against state.currentScript().setActive(true);
            var updateFn = existing.script()['update'];
            if (updateFn) updateFn(options, props);
            return;
        } ////console.log('/index/ -getScript', options);
        // *** init and store


        if (options.data) {
            options.data;
            script(props).init(options.data);
        } else {
            script(props).init(options);
        }

        state.initialisedScripts.push({
            type: options.type,
            script: script
        });
    }; // *** deactivate item scripts (requires defence implemented in script)


    var deactivateItems = function deactivateItems() {
        state.initialisedScripts.map(function (item) {
            if (item) item.script().setActive(false);
        });
    };

    var initItem = function initItem(options) {
        var target = els.items.find(function (item) {
            return item.getAttribute('data-popover-type') === options.type;
        }); //console.log('/popover/ -initItem --options', options);
        //console.log('/popover/ -initItem --target', target);

        if (target) {
            getScript(options); // *** script is optional

            target.classList.add(classes.itemIsEnabled);
            state.hasItem = true;
            return;
        }

        state.hasItem = false;
    };

    var show = function show(options) {
        //console.log('/popover/ -show', options);
        if (!state.hasItem) {
            //console.warn('/popover/ -show --no matching item, quitting');
            return;
        }

        var tm = props.config.timings.animation.medium() / 1.5;
        var preDelay = options.popoverDelay ? options.popoverDelay : 0; //els.el.style.top = `${window.scrollY}px`;
        //console.log('/index/ -show', window.scrollY);

        props.TweenMax.to(els.el, tm, {
            opacity: 1,
            delay: preDelay,
            ease: 'Expo.out',
            onStart: function onStart() {
                els.el.classList.add(classes.isEnabled);
                disableScrolling(true);
            },
            onComplete: function onComplete() {
                // *** add an optional 'ready' method to subclasses if dom inspection required (e.g. getBoundingClientRect)
                var readyFn = state.currentScript()['ready'];
                if (readyFn) readyFn(els, props);
            }
        });
        props.TweenMax.set(els.inner, {
            y: subProps.animateYValue // scale: 0.98

        });
        props.TweenMax.to(els.inner, tm, {
            opacity: 1,
            y: 0,
            scale: 1,
            delay: preDelay + tm * 1.1,
            ease: 'Expo.out'
        });
    }; // *** HIDE


    var hide = function hide() {
        var tm = props.config.timings.animation.medium() / 1.75;
        props.TweenMax.to(els.el, tm, {
            opacity: 0,
            delay: tm * 1.1,
            onComplete: function onComplete() {
                els.el.classList.remove(classes.isEnabled);
                els.items.map(function (item) {
                    item.classList.remove(classes.itemIsEnabled); // *** clear children
                });
                disableScrolling(false);
                state.currentScript = null; // TEST
            }
        });
        props.TweenMax.to(els.inner, tm / 1.25, {
            opacity: 0,
            ease: 'Expo.in',
            y: subProps.animateYValue
        });
    };

    var disableScrolling = function disableScrolling(bool) {
        if (bool) {
            document.body.classList.add(classes.preventScroll);
        } else {
            document.body.classList.remove(classes.preventScroll);
        }
    }; // REMOVE testing only

    /*  window.h = () => {
        hide();
      };
      window.s = () => {
        show({});
      };*/
    // ---


    return {
        init: init
    };
};

window.app.add({
    name: 'popoverDriver_4e9f45076f35',
    script: script
});

