/******/ ( () => { // webpackBootstrap /******/ var __webpack_modules__ = ({ /***/ "./content/default/abstracts/grid/grid.js": /*!************************************************!*\ !*** ./content/default/abstracts/grid/grid.js ***! \************************************************/ /***/ ( (__unused_webpack_module, __webpack_exports__, __webpack_require__) => { "use strict"; __webpack_require__.r(__webpack_exports__); /* harmony export */ __webpack_require__.d(__webpack_exports__, { /* harmony export */ "default": () => (/* binding */ Grid)/* harmony export */ }); let grid; class Grid { init() { grid = this.get_storage(); if (grid) { this.render(); } else { this.get(); } this.init_events(); } } /***/ } ), /***/ "./content/default/blocks/country-picker/country-picker.js": /*!*****************************************************************!*\ !*** ./content/default/blocks/country-picker/country-picker.js ***! \*****************************************************************/ /***/ ( (__unused_webpack_module, __webpack_exports__, __webpack_require__) => { "use strict"; __webpack_require__.r(__webpack_exports__); /* harmony export */ __webpack_require__.d(__webpack_exports__, { /* harmony export */ "default": () => (/* binding */ CountryPicker)/* harmony export */ }); class CountryPicker { constructor() { this.init() } init() { let countrypickers = document.querySelectorAll(".country-picker") countrypickers.forEach( (element) => { element.addEventListener("click", function() { element.querySelector("svg").classList.toggle("open") element.querySelector("ul").classList.toggle("active") }) } ) } } /***/ } ), /***/ "./content/default/blocks/newsletters/newsletter.js": /*!**********************************************************!*\ !*** ./content/default/blocks/newsletters/newsletter.js ***! \**********************************************************/ /***/ ( (__unused_webpack_module, __webpack_exports__, __webpack_require__) => { "use strict"; __webpack_require__.r(__webpack_exports__); /* harmony export */ __webpack_require__.d(__webpack_exports__, { /* harmony export */ "default": () => (/* binding */ Newsletter)/* harmony export */ }); /* harmony import */ var _scripts_utils_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../../scripts/utils.js */ "./content/default/scripts/utils.js"); let newsletter; class Newsletter { constructor() { this.init_events(); } init_events() { document.querySelectorAll('.newsletter-form').forEach(form => { form.addEventListener('submit', event => this.handleEvent(form, event)); } ); } handleEvent(form, event) { event.preventDefault(); let email = form.querySelector(".email").value; let country = form.querySelector(".country").value; let interest_id = form.querySelector(".interest_id").value; form.classList.remove("--error"); if (/^\b[A-ZÅÄÖåäö0-9._%+-]+@[A-ZÅÄÖåäö0-9.-]+\.[A-Z]{2,4}\b$/i.test(email)) { this.add_to_newsletter(email, country, interest_id, form); } else { form.classList.add("--error"); } } async add_to_newsletter(email, country, interest_id, form) { const data = new URLSearchParams(); data.append('funk', 'add_to_newsletter'); data.append('email', email); data.append('country', country); data.append('interest_id', interest_id); data.append('profile', "1"); const response = await fetch('/shop', { method: 'POST', body: data }); const result = await response.json(); if (result.status.code == 200) { newsletter = result.data.newsletter; this.pixels = result.data.pixels; this.render(); form.classList.remove("--error"); form.classList.add("--success"); } } async delete_from_newsletter(element) { const data = new URLSearchParams(); data.append('funk', 'delete_from_newsletter'); data.append('email', element.target.value); const response = await fetch('/shop', { method: 'POST', body: data }); const result = await response.json(); if (result.status.code == 200) { newsletter = result.data.newsletter; this.pixels = result.data.pixels; this.render(); } } render() { let page = "/sv/info/nyhetsbrev-tack.html"; if (document.querySelector(".webpage_url")) { page = document.querySelector(".webpage_url").value; } const temporary_element = document.createElement('div'); temporary_element.innerHTML = this.pixels; (0, _scripts_utils_js__WEBPACK_IMPORTED_MODULE_0__.executeJs)(temporary_element); document.querySelectorAll('.newsletter__input').forEach(element => { element.classList.add('--success'); } ); setTimeout(function() { window.location.href = page; }, 200); } } /***/ } ), /***/ "./content/default/blocks/productlists/recentlyviewed.js": /*!***************************************************************!*\ !*** ./content/default/blocks/productlists/recentlyviewed.js ***! \***************************************************************/ /***/ ( (__unused_webpack_module, __webpack_exports__, __webpack_require__) => { "use strict"; __webpack_require__.r(__webpack_exports__); /* harmony export */ __webpack_require__.d(__webpack_exports__, { /* harmony export */ "default": () => (/* binding */ RecentlyViewed)/* harmony export */ }); /* harmony import */ var _default_views_product_simple_slider__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../../../default/views/product/simple_slider */ "./content/default/views/product/simple_slider.js"); const storage_name = 'air_viewed'; const expire_time = 60 * 24 * 365; // In minutes. class RecentlyViewed { constructor() { this.init(); this.init_events(); } init() { const _this = this; window.lazyFunctions.recentlyViewed = function(element) { const data = _this.get(element); } } init_events() { const _this = this; document.addEventListener("product_page_viewed", function() { const id = window.product_id; if (!id) return; let viewed = _this.get_storage(); if (!viewed) { viewed = { items: [] }; } else if (viewed.items.includes(id)) { viewed.items = viewed.items.filter(function(e) { return e !== id }) } viewed.items.unshift(id); viewed.items.length = 100; _this.save_storage(viewed.items); }); } get_storage() { if (typeof (Storage) === 'undefined') return null; let str = window.localStorage.getItem(storage_name); if (str == null) return undefined; let data; try { data = JSON.parse(str); } catch (e) { return undefined; } if (data.expires < Date.now()) { return undefined; } return data; } save_storage(data) { if (typeof (Storage) === 'undefined') return null; let air_viewed = {}; air_viewed.items = data; air_viewed.expires = Date.now() + expire_time * 60000; window.localStorage.setItem(storage_name, JSON.stringify(air_viewed)); } async get(element) { const viewed = this.get_storage(); if (viewed) { if (viewed.items <= 1) { return; } const id = window.product_id; if (id) { viewed.items = viewed.items.filter(function(e) { return e !== id }) } const recently_viewed = JSON.stringify(viewed.items).replace(/\[|\]|\"/g, ""); const response = await fetch('/shop?funk=get_recently_viewed&recently_viewed=' + recently_viewed + '&lazy=1'); const result = await response.json(); if (result.status.code == 200) { element.innerHTML = result.data; document.dispatchEvent(new CustomEvent("product_cell_update")); document.dispatchEvent(new CustomEvent("pdp_latestviewed_loaded")); window.lazyLoadInstance.update(); const slider = document.querySelector('.recently_viewed .snapping--wrapper'); if (slider) { new _default_views_product_simple_slider__WEBPACK_IMPORTED_MODULE_0__["default"](slider); } } } } } /***/ } ), /***/ "./content/default/blocks/productlists/styleview.js": /*!**********************************************************!*\ !*** ./content/default/blocks/productlists/styleview.js ***! \**********************************************************/ /***/ ( (__unused_webpack_module, __webpack_exports__, __webpack_require__) => { "use strict"; __webpack_require__.r(__webpack_exports__); /* harmony export */ __webpack_require__.d(__webpack_exports__, { /* harmony export */ "default": () => (/* binding */ StyleView)/* harmony export */ }); /* harmony import */ var _views_product_simple_slider__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../../views/product/simple_slider */ "./content/default/views/product/simple_slider.js"); class StyleView { constructor() { this.init(); } init() { const _this = this; window.lazyFunctions.styleView = function(element) { const data = _this.get(element); } } async get(element) { const id = window.product_id; const response = await fetch("/shop?funk=get_product_page_styleview&product_page_styleview=" + id + "&lazy=1"); const result = await response.json(); if (result.status.code == 200) { element.innerHTML = result.data; document.dispatchEvent(new CustomEvent("product_cell_update")); window.lazyLoadInstance.update(); const slider = document.querySelector('.styleview .snapping--wrapper'); if (slider) { new _views_product_simple_slider__WEBPACK_IMPORTED_MODULE_0__["default"](slider); } } } } /***/ } ), /***/ "./content/default/blocks/search/search.js": /*!*************************************************!*\ !*** ./content/default/blocks/search/search.js ***! \*************************************************/ /***/ ( (__unused_webpack_module, __webpack_exports__, __webpack_require__) => { "use strict"; __webpack_require__.r(__webpack_exports__); /* harmony export */ __webpack_require__.d(__webpack_exports__, { /* harmony export */ "default": () => (/* binding */ Search)/* harmony export */ }); let search; const suggestResult = document.getElementById("suggest-result") const suggestInit = document.getElementById("suggest-init") const suggestArea = document.getElementById("suggest-area") class Search { constructor() { this.suggest_highlight = (typeof (window.suggest_highlight) !== "undefined" && window.suggest_highlight === "1") ? true : false; this.full_search_url_fallback = "/shop?funk=gor_sokning&term="; this.search_history_count = (typeof (window.search_history_count) !== "undefined") ? window.search_history_count : 10; this.prev_chars = ""; this.prev_search_chars = ""; this.timeout_suggest; this.timeout_suggest_ms = 100; this.history_reload = false; this.history_url = ""; this.init(); } init() { if (window.shop_settings.other.search_url) { this.full_search_url = window.shop_settings.other.search_url; } else { this.full_search_url = this.full_search_url_fallback; } if (document.getElementById("search-history")) { this.history_init(); } this.init_events(); } init_events() { if (document.getElementById("search")) { document.getElementById("search").addEventListener("keyup", (e) => { this.suggest(e); } ); document.getElementById("search").addEventListener("focus", () => { this.show(); } ); document.getElementById("search-form").addEventListener("submit", (e) => { this.search(e); } ); } if (document.getElementById("search-wrapper")) { document.addEventListener("click", (e) => { var container = document.getElementById('search-wrapper'); if (!container.contains(e.target)) { this.hide(); } } ); } if (document.getElementById("search-history-clear")) { document.getElementById("search-history-clear").addEventListener("click", (e) => { e.preventDefault(); this.history_clear(); } ); } document.addEventListener("search-loaded", (e) => { this.history_save(e.detail.q, e.detail.hits); } ); } search(e) { e.preventDefault(); const chars = document.getElementById("search").value; if (chars.length > 0) { window.location.href = this.full_search_url + chars; } } nomatch() { const noresult = document.querySelector(".noHit") if (suggestResult.contains(noresult)) { suggestArea.classList.add("no-results") } else { suggestArea.classList.remove("no-results") } } suggest() { const chars = document.getElementById("search").value; if ((chars != '') && (chars.length > 1)) { if (chars !== this.prev_chars) { this.prev_chars = chars; this.suggest_request(chars); this.nomatch(); } document.querySelector(".backdrop").classList.add("active") document.querySelector("#header .header__search #suggest-area.active").style.maxHeight = "1000px"; suggestResult.style.display = "block" suggestInit.style.display = "none" } else { if (!chars.length) { if (suggestResult) { suggestResult.style.display = "none" } suggestInit.style.display = "block" document.querySelector("#header .header__search #suggest-area.active").style.maxHeight = "0px" document.body.style.overflow = "" document.querySelector(".backdrop").classList.remove("active") } } } async suggest_request(chars) { const chars_encoded = encodeURIComponent(chars); let response = await fetch("/shop?funk=autosuggest&q=" + chars_encoded); let html = await response.text(); suggestResult.innerHTML = html if (this.suggest_highlight) { this.highlight(chars); } } show() { if (document.getElementById("search").value !== "") { document.querySelector(".backdrop").classList.add("active") suggestArea.classList.add("active") document.querySelector("#header .header__search #suggest-area.active").style.maxHeight = "1000px" suggestInit.style.display = "none" suggestResult.style.display = "block" if (this.prev_chars === "") { this.suggest(); } } else { suggestInit.style.display = "block" } suggestArea.classList.add("active") } hide() { suggestArea.classList.remove("active") } highlight(chars) { chars = chars.trim(); var reg = new RegExp(this._escape_regexp(chars),'gi'); document.querySelectorAll("#suggest-result .term").forEach(function(elem) { var t = elem.innerHTML; t = t.replace(reg, "$&"); elem.innerHTML = t; }); } _escape_regexp(string) { return string.replace(/[.*+?^${}()|[\]\\]/g, '\\$&'); } history_init() { if (typeof (Storage) === "undefined") return null; const history_str = window.localStorage.getItem('search_history'); if (history_str == null || history_str === "") return null; const search_history = JSON.parse(history_str); let history_html = ""; for (let i = 0; i < search_history.length; i++) { const value = search_history[i].value; const url = this.full_search_url + encodeURIComponent(value); const link = '' + value + ''; history_html += '
  • ' + link + '
  • '; } if (history_html) { history_html = "
    " + search_texts['history'] + "" + search_texts['clear'] + "
    "; } document.getElementById("search-history").innerHTML = history_html; } history_save(query, hits) { if (typeof (Storage) === "undefined") return null; if (hits > 0) { var search_history = JSON.parse(window.localStorage.getItem('search_history')); if (search_history == null || search_history === "") { search_history = [{ 'value': query }]; } else { // remove if already exists. for (var i = 0; i < search_history.length; i++) { if (search_history[i].value === query) { search_history.splice(i, 1); i--; } } search_history.unshift({ 'value': query }); if (search_history.length > search_history_count) { search_history.length = search_history_count; } } window.localStorage.setItem('search_history', JSON.stringify(search_history)); } } history_clear() { if (typeof (Storage) === "undefined") return null; window.localStorage.removeItem('search_history'); document.getElementById("search-history").innerHTML = ""; } } /***/ } ), /***/ "./content/default/components/ace/Ace.js": /*!***********************************************!*\ !*** ./content/default/components/ace/Ace.js ***! \***********************************************/ /***/ ( (__unused_webpack_module, __webpack_exports__, __webpack_require__) => { "use strict"; __webpack_require__.r(__webpack_exports__); /* harmony export */ __webpack_require__.d(__webpack_exports__, { /* harmony export */ "default": () => (/* binding */ Ace)/* harmony export */ }); class Ace { constructor() { this.init(); } init() { this.selectedCategoriesImg = document.getElementById('img-toggle'); this.init_events(); } init_events() { if (this.selectedCategoriesImg) { const selectedCategories = document.querySelectorAll('.category-list--item'); selectedCategories.forEach(item => { item.addEventListener('mouseenter', (e) => this.set_active_category(e.target)); if (item.classList.contains('open')) { this.selectedCategoriesOpen = item; } } ); } } set_active_category(elem) { if (!elem.classList.contains('open')) { const img_tag = elem.getElementsByTagName('img'); if (img_tag.length) { this.selectedCategoriesImg.src = img_tag[0].src; if (this.selectedCategoriesOpen) { this.selectedCategoriesOpen.classList.remove('open'); } elem.classList.add('open'); this.selectedCategoriesOpen = elem; } } } } /***/ } ), /***/ "./content/default/components/atoms/Navigation/main-navigation.js": /*!************************************************************************!*\ !*** ./content/default/components/atoms/Navigation/main-navigation.js ***! \************************************************************************/ /***/ ( (__unused_webpack_module, __webpack_exports__, __webpack_require__) => { "use strict"; __webpack_require__.r(__webpack_exports__); /* harmony export */ __webpack_require__.d(__webpack_exports__, { /* harmony export */ "default": () => (/* binding */ Nav)/* harmony export */ }); class Nav { constructor() { this.init(); } init() { /* Toggle nav */ let menuBtn = document.querySelectorAll("#main--nav-icon") let menuBtnClose = document.querySelectorAll(".menu__categories--close") this.mainNav = document.querySelectorAll("#main--nav") this.scrollPosition = 0 if (window.matchMedia("screen and (min-width: 65rem)").matches) return; /* Show nav */ for (var i = 0; i < menuBtn.length; ++i) { menuBtn[i].addEventListener("click", () => { this.showMainNav(this) } ) } /* hide nav */ for (var i = 0; i < menuBtnClose.length; ++i) { menuBtnClose[i].addEventListener("click", () => { this.hideMainNav(this) } ) } if (/Android|webOS|iPhone|iPad|iPod|BlackBerry/i.test(navigator.userAgent)) { document.querySelector("header").addEventListener("click", (event) => { if (!event.target.closest("#nav-wrapper, #main--nav-icon")) { this.hideMainNav(this) } } , false) } /* toggle level 1*/ const navItemsLink = document.querySelectorAll(".menu__categories > li.has__children > a") const navItemsBack = document.querySelectorAll(".menu__categories--back") this.ScrolltoTop = document.querySelector(".menu__categories") navItemsLink.forEach( (listItem) => { listItem.classList.remove('navigate') listItem.addEventListener("click", (e) => { this.setActiveLink(e, this) } ) } ) navItemsBack.forEach( (listItem) => { listItem.addEventListener("click", (e) => { this.setActiveBack(e, this) } ) } ) } showMainNav(_self) { for (let i = 0; i < _self.mainNav.length; ++i) { /* add active classes */ _self.mainNav[i].classList.add("active") document.body.classList.add("modal_active") } /* add scrollpostion */ _self.scrollPosition = window.pageYOffset document.body.style.overflow = "hidden" document.body.style.position = "fixed" document.body.style.top = `-${_self.scrollPosition}px` } hideMainNav(_self) { for (let i = 0; i < _self.mainNav.length; ++i) { /* remove active classes */ _self.mainNav[i].classList.remove("active") document.body.classList.remove("modal_active") } /* remove scrollpostion */ document.body.style.removeProperty("overflow") document.body.style.removeProperty("position") document.body.style.removeProperty("top") document.body.classList.remove("activeNav") document.querySelector(".backdrop").classList.remove('active') // window.scrollTo(0, _self.scrollPosition) } setActiveLink(e, _self) { const parent = e.target.parentNode /* if children prevent link follow - level1 */ e.preventDefault() /* show level - 1 if children */ e.target.parentNode.classList.toggle("open") e.target.parentNode.parentNode.classList.toggle("open") /* scroll menu to top on click */ _self.ScrolltoTop.scrollIntoView() } /* toggle back to level0 */ setActiveBack(e, _self) { const parent = e.target.parentNode e.target.parentNode.parentNode.classList.toggle("open") e.target.parentNode.parentNode.parentNode.classList.toggle("open") /* scroll menu to top on click */ _self.ScrolltoTop.scrollIntoView() } } /***/ } ), /***/ "./content/default/components/molecules/cart/cart.js": /*!***********************************************************!*\ !*** ./content/default/components/molecules/cart/cart.js ***! \***********************************************************/ /***/ ( (__unused_webpack_module, __webpack_exports__, __webpack_require__) => { "use strict"; __webpack_require__.r(__webpack_exports__); /* harmony export */ __webpack_require__.d(__webpack_exports__, { /* harmony export */ "default": () => (/* binding */ Cart)/* harmony export */ }); /* harmony import */ var _scripts_utils_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../../../scripts/utils.js */ "./content/default/scripts/utils.js"); const storage_name = 'air_cart'; const expire_time = 60; // In minutes. class Cart { constructor(wrapper_id='air-cart-wrapper', content_id='air-cart', label_id='air-cart-label') { this.wrapper_id = wrapper_id; this.content_id = content_id; this.label_id = label_id; this.cartErrorHeading = ''; this.cartErrorText = ''; if (window.shop_texts) { this.cartErrorHeading = window.shop_texts.text1 this.cartErrorText = window.shop_texts.text2 } this.currency_prefix = window.shop_settings['currency_prefix'] || ''; this.currency_suffix = window.shop_settings['currency_suffix'] || ''; this.init(); } init() { if (!(0, _scripts_utils_js__WEBPACK_IMPORTED_MODULE_0__.getCookie)('SESS')) return; if (!document.getElementById(this.wrapper_id)) return; let getCart = false; if (window.shop_settings) { if (window.shop_settings.request === 'checkout_complete') { getCart = true; localStorage.removeItem(storage_name); } } if (!getCart) { this.cart = this.get_storage(); } if (this.cart) { this.render(); } else { this.get(); } } add_item_event(e) { const elem = e.target; const quantity_field = document.getElementById('cart-quantity'); const product_id = elem.dataset.id; const quantity = quantity_field ? quantity_field.value : 1; this.add_item(product_id, quantity, undefined); } remove_item_event(e) { const elem = e.target; const item_id = elem.parentElement.dataset.itemId; this.remove_item(item_id); } inc_item_event(e) { const elem = e.target; const item_id = elem.parentElement.dataset.itemId; this.inc_item(item_id); } sub_item_event(e) { const elem = e.target; const item_id = elem.parentElement.dataset.itemId; this.sub_item(item_id); } _show() { document.querySelector("body").classList.add("cart-open") document.querySelector(".backdrop").classList.add("active") document.getElementById(this.content_id).classList.add("active"); } _hide() { document.getElementById(this.content_id).classList.remove("active") document.querySelector(".backdrop").classList.remove("active") document.querySelector("body").classList.remove("cart-open") } _toggle() { let elementClasslist = document.getElementById(this.content_id).classList; console.log("hejhej") if (!elementClasslist.contains("active")) { this._show() } else { this._hide() } } async get(action, opt) { // let response = await fetch('/api/cart'); const response = await fetch('/shop?funk=get_cart'); const result = await response.json(); if (result.status.code == 200) { this.cart = result.data; this.save_storage(); this.render(action, opt); } } async add_item(product_id, quantity, extra_data) { const data = new URLSearchParams(); this.get() data.append('funk', 'add_cart_item'); data.append('product_id', product_id); data.append('quantity', quantity); if (extra_data) { // Hantera SET-artiklar. if (extra_data.bundle_fields) { data.append('bundle_fields', JSON.stringify(extra_data.bundle_fields)); } // Hantera presentkort. if (extra_data.giftcard_value_id) { data.append('giftcard_value_id', extra_data.giftcard_value_id); } } const response = await fetch('/shop', { method: 'POST', body: data }); const result = await response.json(); if (result.status.code == 200) { this.cart = result.data.cart; this.pixels = result.data.pixels; this.save_storage(); this.render('add', { product_id: product_id }); if (product_id) { const data = new URLSearchParams(); data.append('funk', 'google_article_path'); data.append('artnr', product_id); data.append('path', window.shop_settings['product_referrer']); const response = fetch('/cgi-bin/ibutik/API.fcgi', { method: 'POST', body: data }); } } else { this.show_error(result.status); } } inc_item(item_id) { const item = this._get_item_from_cart(item_id); const new_quantity = item.quantity + 1; this._update_item(item, new_quantity); } sub_item(item_id) { const item = this._get_item_from_cart(item_id); const new_quantity = item.quantity - 1; if (new_quantity <= 0) { this.remove_item(item_id); } else { this._update_item(item, new_quantity); } } _get_item_from_cart(item_id) { let matched_item; this.cart.items.forEach( (item, i) => { if (item.id == item_id) { matched_item = item; } } ); return matched_item; } async _update_item(item, new_quantity) { const data = new URLSearchParams(); this.get() data.append('funk', 'update_cart_item'); data.append('id', item.id); data.append('quantity', new_quantity); const response = await fetch('/shop', { method: 'POST', body: data }); const result = await response.json(); // Update cart model if (result.status.code == 200) { this.cart.total_cost += item.price * (new_quantity - item.quantity); item.row_cost = item.price * new_quantity; item.quantity = new_quantity; this.save_storage(); this.render(); } else { this.show_error(result.status); } } async remove_item(item_id) { const data = new URLSearchParams(); this.get() data.append('funk', 'delete_cart_item'); data.append('id', item_id); const response = await fetch('/shop', { method: 'POST', body: data }); const result = await response.json(); // Update cart model if (result.status.code == 200) { this.cart.items.forEach( (item, i) => { if (item.id == item_id) { this.cart.total_cost -= item.row_cost; this.cart.items.splice(i, 1); } } ); this.save_storage(); this.render(); } else { this.show_error(result.status); } } save_storage() { if (typeof (Storage) === 'undefined') return null; this.cart.expires = Date.now() + expire_time * 60000; window.localStorage.setItem(storage_name, JSON.stringify(this.cart)); } get_storage() { if (typeof (Storage) === 'undefined') return null; let str = window.localStorage.getItem(storage_name); if (str == null) return undefined; let data; try { data = JSON.parse(str); } catch (e) { return undefined; } if (data.expires < Date.now()) { return undefined; } return data; } show_error(error) { const container = document.getElementById(this.content_id); let html = `

    ${this.cartErrorHeading}

    ${this.cartErrorText}

    ` container.innerHTML = html; document.body.classList.add("cart-open") const backdropBlur = document.querySelector(".backdrop") const airCartModule = document.querySelector("#air-cart-module") document.body.style.overflow = "hidden" document.querySelector("#air-cart").parentElement.classList.add("active") document.querySelector("#air-cart").parentElement.classList.add("error") backdropBlur.classList.add("active") } show(action, opt) { this.get(action, opt); } render(action, opt) { if (this.cart.total_count) { document.getElementById("air-cart-label-text").innerHTML = this.cart.total_count } if (this.cart.total_count > 0) { document.getElementById(this.label_id).classList.add("active") } document.getElementById(this.label_id).addEventListener("click", () => { if (window.checkout_url) { window.location.href = window.checkout_url; } else { window.location.href = "/shop?funk=bestall_steg1" } } ); if (action === 'add') { const container = document.getElementById(this.content_id); const product_id = opt.product_id; const items = this.cart.items; document.querySelector("header").classList.add("header__scrolled") document.querySelector("header").classList.remove("header__notScrolled") document.querySelector("body").classList.add("header__scrolled") document.querySelector("body").classList.remove("header__notScrolled") let item; if (opt.order == 'update_time') { item = items[items.length - 1]; for (let i = items.length - 1; i > 0; i--) { if (items[i - 1].update_time > items[i].update_time) { item = items[i - 1]; } } } else { for (let i = items.length; i > 0; i--) { if (items[i - 1].product_id === product_id) { item = items[i - 1]; break; } } } if (item) { let html = `
    ${item.product.name}
    ${this.currency_prefix}${item.price}${this.currency_suffix}
    ${this.pixels}
    ` container.innerHTML = html; (0, _scripts_utils_js__WEBPACK_IMPORTED_MODULE_0__.executeJs)(container); document.body.style.overflow = "hidden" document.body.classList.add("cart-open") const backdropBlur = document.querySelector(".backdrop") const airCartModule = document.querySelector("#air-cart-module") document.querySelector("#air-cart").parentElement.classList.add("active") backdropBlur.classList.add("active") } } } } /***/ } ), /***/ "./content/default/components/molecules/login/login.js": /*!*************************************************************!*\ !*** ./content/default/components/molecules/login/login.js ***! \*************************************************************/ /***/ ( (__unused_webpack_module, __webpack_exports__, __webpack_require__) => { "use strict"; __webpack_require__.r(__webpack_exports__); /* harmony export */ __webpack_require__.d(__webpack_exports__, { /* harmony export */ "default": () => (/* binding */ Login)/* harmony export */ }); class Login { constructor(icon_id='login-icon', form_id='login-form', popup_id='#login-wrapper', error_id='login-error', login_success_id='login-wrapper-content-success') { this.icon_id = icon_id; this.form_id = form_id; this.popup_id = popup_id; this.error_id = error_id; this.login_success_id = login_success_id; this.from_checklogin = false; this.isImboxHandling = false; // Flag to prevent loop this.init(); } init() { this.init_events(); this.setupImboxListener(); // Set up the _imbox listener } init_events() { if (!document.getElementById(this.icon_id)) return; if (window.checklogin) { this.init_checklogin(); } document.getElementById(this.icon_id).addEventListener('click', () => { this.show_login(); } ); document.querySelector(this.popup_id + ' .close').addEventListener('click', (e) => { e.stopPropagation(); this.hide_login(); } ); document.getElementById(this.form_id).addEventListener('submit', (e) => { e.preventDefault(); this.login(); } ); document.querySelector('.login-success-button').addEventListener('click', () => { this.handleRedirection(); } ); } init_checklogin() { this.from_checklogin = true; let text = window.checklogin_text || ''; let email = window.checklogin_email || ''; if (text) { let h3 = document.querySelector('#login-wrapper h3'); if (h3) { h3.innerHTML = text; } let ulElements = document.querySelectorAll('#login-wrapper-content ul'); ulElements.forEach(ul => ul.remove()); } if (email) { document.querySelector('#login-wrapper input[name="user"]').value = email; } this.show_login(); } handleRedirection() { if (window.location.href.includes('funk=logout')) { window.location.href = '/'; // Redirect to homepage } else { location.reload(); } } show_login() { const login_form = document.querySelector(this.popup_id); const backdrop = document.querySelector('.backdrop'); // Ensure _imbox is hidden when show_login is called this.hideImbox(); login_form.classList.add('active'); backdrop.classList.add('active'); document.body.classList.add('fullbackdrop'); } hide_login() { const login_form = document.querySelector(this.popup_id); login_form.classList.remove('active'); document.body.classList.remove('fullbackdrop'); } async login() { const form = document.getElementById(this.form_id); if (!form.user.value && !form.pass.value) return; const data = new URLSearchParams(new FormData(form)); const response = await fetch('/shop', { method: 'POST', body: data }); const result = await response.json(); if (result.status.code == 200) { if (typeof (Storage) !== 'undefined') { window.localStorage.removeItem('air_wishlist'); window.localStorage.removeItem('air_cart'); } if (this.from_checklogin) { this.handleRedirection(); } else { document.getElementById(this.form_id).classList.add('hide'); document.getElementById(this.login_success_id).classList.remove('hide'); } } else { document.getElementById(this.error_id).innerHTML = result.status.msg; } } hideImbox() { if (typeof (_imbox) !== "undefined") { this.isImboxHandling = true; // Disable the callback _imbox.push(['hideLauncher']); _imbox.push(['hideWidget']); setTimeout( () => { this.isImboxHandling = false; } , 100); // Re-enable the callback after a delay } } setupImboxListener() { const debounce = (func, wait) => { let timeout; return (...args) => { clearTimeout(timeout); timeout = setTimeout( () => func.apply(this, args), wait); } ; } ; const onToggleCallback = debounce( () => { if (!this.isImboxHandling) { // Only execute if not handling _imbox manually this.hideImbox(); } } , 100); if (typeof (_imbox) !== "undefined") {//_imbox.push(["onToggle", onToggleCallback]); } } } /***/ } ), /***/ "./content/default/components/molecules/toplist/toplist.js": /*!*****************************************************************!*\ !*** ./content/default/components/molecules/toplist/toplist.js ***! \*****************************************************************/ /***/ ( (__unused_webpack_module, __webpack_exports__, __webpack_require__) => { "use strict"; __webpack_require__.r(__webpack_exports__); /* harmony export */ __webpack_require__.d(__webpack_exports__, { /* harmony export */ "default": () => (/* binding */ Toplist)/* harmony export */ }); let toplist; class Toplist { init() { toplist = this.get_storage() if (toplist) { this.render() } else { this.get() } this.init_events(); } init_events() {} } /***/ } ), /***/ "./content/default/components/mystyle.js": /*!***********************************************!*\ !*** ./content/default/components/mystyle.js ***! \***********************************************/ /***/ ( (__unused_webpack_module, __webpack_exports__, __webpack_require__) => { "use strict"; __webpack_require__.r(__webpack_exports__); /* harmony export */ __webpack_require__.d(__webpack_exports__, { /* harmony export */ "default": () => (/* binding */ MyStyle)/* harmony export */ }); class MyStyle { constructor() { this.init_events(); } init_events() { window.liveEvent(".myStyle__switch input", "change", (event, element) => { this.toggleMyStyle(element) } ); document.addEventListener("sort_changed", function(e) { if (e.detail) { if (e.detail.sort !== "most_popular-asc") { document.cookie = "bloomreach_sort_active=" + false + "; max-age=" + 30 * 24 * 60 * 60 + "; path=/"; document.querySelectorAll('.myStyle__switch input').forEach(checkbox => { checkbox.checked = false; } ); } } }); } toggleMyStyle(element) { let checked = element.checked; let type = element.dataset.type; exponea.track('site_click', { 'action': checked, 'type': 'my_style', 'parameter': 'toggle' }); document.querySelectorAll('.myStyle__switch input').forEach(checkbox => { checkbox.checked = checked; } ); document.cookie = "bloomreach_sort_active=" + checked + "; max-age=" + 30 * 24 * 60 * 60 + "; path=/"; if (type == "group") { if (checked) { this.setPopularSort(); } document.dispatchEvent(new Event("refresh_filter")); } else if (type == "widget") { let group_id = element.dataset.group_id; let limit = element.dataset.limit; let sort = element.dataset.sort; this.get(group_id, limit, sort); } } setPopularSort() { document.querySelectorAll('#sort-order-ul li').forEach(sort_li => { if (sort_li.dataset.value == "most_popular-asc") { sort_li.classList.add("--active"); document.querySelectorAll('.active_sort_label').forEach(label => { label.innerHTML = sort_li.innerHTML; } ); } else { sort_li.classList.remove("--active"); } } ); } async get(group_id, limit, sort) { const data = new URLSearchParams(); data.append('funk', 'get_filter'); data.append('json', 1); data.append('id', group_id); data.append('limit', limit); data.append('sort', sort); data.append('type', "product_group"); const response = await fetch('/shop', { method: 'POST', body: data }); const result = await response.json(); if (result.request_data) {} } } /***/ } ), /***/ "./content/default/components/organisms/accordion.js": /*!***********************************************************!*\ !*** ./content/default/components/organisms/accordion.js ***! \***********************************************************/ /***/ ( (__unused_webpack_module, __webpack_exports__, __webpack_require__) => { "use strict"; __webpack_require__.r(__webpack_exports__); /* harmony export */ __webpack_require__.d(__webpack_exports__, { /* harmony export */ "default": () => (/* binding */ accordion)/* harmony export */ }); class accordion { constructor() { this.init() } init() { function initAcc(elem, option) { document.addEventListener('click', function(e) { if (!e.target.matches(elem + ' .accordion__item--btn')) return; else { if (!e.target.parentElement.classList.contains('active')) { if (option == true) { var elementList = document.querySelectorAll(elem + ' .accordion__item'); Array.prototype.forEach.call(elementList, function(e) {// e.classList.remove('active'); }); } e.target.parentElement.classList.add('active'); } else { e.target.parentElement.classList.remove('active'); } } }); } initAcc('.accordion', true); } } /***/ } ), /***/ "./content/default/components/organisms/header/header.js": /*!***************************************************************!*\ !*** ./content/default/components/organisms/header/header.js ***! \***************************************************************/ /***/ ( (__unused_webpack_module, __webpack_exports__, __webpack_require__) => { "use strict"; __webpack_require__.r(__webpack_exports__); /* harmony export */ __webpack_require__.d(__webpack_exports__, { /* harmony export */ "default": () => (/* binding */ Header)/* harmony export */ }); class Header { constructor() { this.init() } init() { const ElementLegend = {} function GetElement(selector, refresh) { try { if (refresh) return document.querySelector(selector) if (!(selector in ElementLegend)) { ElementLegend[selector] = document.querySelector(selector) } return ElementLegend[selector] } catch (err) { console.log(err) return null } } var scrollPos = window.scrollY window.addEventListener("scroll", function() { if (!GetElement("header")) return else if (window.scrollY < 130) { scrollPos = window.scrollY GetElement("body").classList.remove("header__scrolled") GetElement("header").classList.remove("header__scrolled") GetElement("header").classList.remove("header__notScrolled") GetElement("header").classList.add("top") } else if (window.scrollY > scrollPos + 100) { scrollPos = window.scrollY GetElement("header").classList.remove("top") GetElement("header").classList.remove("header__scrolled") GetElement("body").classList.remove("header__scrolled") GetElement("body").classList.add("header__notScrolled") GetElement("header").classList.add("header__notScrolled") document.body.style.overflow = "" document.querySelector(".backdrop").classList.remove("active") if (document.querySelector("#header .header__search #suggest-area.active")) { document.querySelector("#header .header__search #suggest-area.active").style.maxHeight = "0px" } if (document.getElementById("suggest-result")) { document.getElementById("suggest-result").style.display = "none" } if (document.getElementById("suggest-init")) { document.getElementById("suggest-init").style.display = "none" } document.querySelector(".backdrop").classList.remove("active") if (document.querySelector("#search")) { document.querySelector("#search").blur() } } else if (window.scrollY < scrollPos - 100) { scrollPos = window.scrollY GetElement("header").classList.remove("header__notScrolled") GetElement("body").classList.remove("header__notScrolled") GetElement("header").classList.add("header__scrolled") GetElement("body").classList.add("header__scrolled") } }) } } /***/ } ), /***/ "./content/default/components/size_and_fit/sizeAndFit.js": /*!***************************************************************!*\ !*** ./content/default/components/size_and_fit/sizeAndFit.js ***! \***************************************************************/ /***/ ( (__unused_webpack_module, __webpack_exports__, __webpack_require__) => { "use strict"; __webpack_require__.r(__webpack_exports__); /* harmony export */ __webpack_require__.d(__webpack_exports__, { /* harmony export */ "default": () => (/* binding */ SizeAndFit)/* harmony export */ }); class SizeAndFit { constructor() { this.init_events(); window.addEventListener('pdp_ajax_loaded', () => { this.init_events(); } ); } init_events() { const snfPDP = document.querySelector('.buybox .sizeAndFitTrigger'); const sizeAndFit = document.getElementById('sizeandfit2'); if (sizeAndFit) { if (snfPDP) { SizeAndFit.showGeneratedSize(); } this.activeFit(); this.activeStep(); this.snfBtn(); this.bodyTypeHandler(); this.rangeSlider(); const backdropBlur = document.querySelector('.backdrop'); const sizeNFit = document.getElementById('sizeandfit'); const sizeNFitStep = sessionStorage.getItem('snf_step'); // Assuming window.sizeNFitInitialized is not defined anywhere else in your code. if (typeof window.sizeNFitInitialized === 'undefined') { window.sizeNFitInitialized = false; } window.liveEvent('.sizeAndFitTrigger', 'click', () => { if (sizeNFitStep == '1' && !window.sizeNFitInitialized) { trackExponeaStart(); _imbox.push(['hideLauncher']); window.sizeNFitInitialized = true; // Set the flag to true after the first initialization } const productPage = document.querySelector('.single-product'); const sizeAndFit = document.getElementById('sizeandfit'); document.body.classList.add("sizeandfit-open"); document.body.style.overflow = ''; if (productPage) { const images = document.querySelectorAll('.productImg--wrapper img'); const productArtNr = document.querySelector('.product-id-info'); sizeAndFit.classList.add('from-pdp'); const imageSource = images[0].getAttribute('src'); sessionStorage.setItem('snf_image', imageSource); sessionStorage.setItem('snf_artnr', productArtNr.textContent); } backdropBlur.classList.add('active'); sizeNFit.classList.add('active'); this.activeStep(); if (sizeNFitStep > '1') { this.snfBackBtn(); } } ); window.liveEvent('.sizeandfit__header svg', 'click', () => { backdropBlur.classList.remove('active'); document.body.classList.remove("sizeandfit-open"); sizeNFit.classList.remove('active'); window.sizeNFitInitialized = false; } ); window.liveEvent('.sizeandfit__close', 'click', () => { backdropBlur.classList.remove('active'); sizeNFit.classList.remove('active'); document.body.classList.remove("sizeandfit-open"); sessionStorage.setItem('snf_step', '1'); window.sizeNFitInitialized = false; } ); if (!sizeNFitStep) { sessionStorage.setItem('snf_step', '1'); } } } rangeSlider() { const rangeLabels = document.querySelectorAll('.range__label'); const slider = document.getElementById('snf_slider'); rangeLabels.forEach( (label) => { label.addEventListener('click', (event) => { const value = event.target.getAttribute('data-value'); slider.value = value; // Trigger the change event manually to update the slider's value slider.dispatchEvent(new Event('change')); } ); } ); // Listen for changes in the slider's value slider.addEventListener('change', (event) => { const value = event.target.value; // Add or remove 'active' class based on the slider's value rangeLabels.forEach( (label) => { const labelValue = label.getAttribute('data-value'); if (labelValue === value) { label.classList.add('active'); } else { label.classList.remove('active'); } } ); } ); } activeFit() { const sliderLabels = document.querySelectorAll('.range__label'); const slider = document.getElementById('snf_slider'); if (slider) { slider.addEventListener('input', () => { const sliderValue = slider.value; sliderLabels.forEach( (label) => { const labelValue = label.getAttribute('data-value'); if (labelValue === sliderValue) { label.classList.add('active'); } else { label.classList.remove('active'); } } ); } ); } } snfBtn() { const snfContinue = document.querySelector('.sizeandfit__continue'); snfContinue.addEventListener('click', () => { let step = sessionStorage.getItem('snf_step'); const typesActive = document.querySelector('.sizeandfit__types'); const closeBtn = document.querySelector('.sizeandfit__header svg'); const clickEvent = new Event('click'); if (step === '1') { const snfHeight = document.getElementById('snf-height'); const snfWeight = document.getElementById('snf-weight'); const height = snfHeight.value; const weight = snfWeight.value; // Check if both height and weight have values if (height === '' || weight === '') { // Show an error message if either height or weight is missing document.getElementById('step_1_error_message').classList.remove('hide'); return; // Stop the function from proceeding } else { document.getElementById('step_1_error_message').classList.add('hide'); } step = parseInt(step) + 1; step = step.toString(); localStorage.setItem('snf_height', height); localStorage.setItem('snf_weight', weight); sessionStorage.setItem('snf_step', step); sessionStorage.setItem('snf_height', height); sessionStorage.setItem('snf_weight', weight); this.activeStep(); } else if (step === '2' && typesActive) { step = parseInt(step) + 1; step = step.toString(); sessionStorage.setItem('snf_step', step); this.activeStep(); } else if ((step === '3' && typesActive) || (step === '2' && !typesActive)) { const snfFit = document.getElementById('snf_slider'); const fit = snfFit.value; let formValue = ''; if (fit === '1') { formValue = 'tight'; } else if (fit === '2') { formValue = 'normal'; } else if (fit === '3') { formValue = 'spacious'; } step = parseInt(step) + 1; step = step.toString(); sessionStorage.setItem('snf_step', step); sessionStorage.setItem('snf_form', formValue); this.activeStep(); } else if ((step === '4' && typesActive) || (step === '3' && !typesActive)) { closeBtn.dispatchEvent(clickEvent); } this.snfBackBtn(); } ); } activeStep() { const step = sessionStorage.getItem('snf_step'); const continueButton = document.querySelector('.sizeandfit__continue'); const fromPDP = document.querySelector('.sizeandfit.from-pdp'); const snfHeader = document.querySelector('.sizeandfit__header'); const elements = [document.querySelector('.sizeandfit__metrics'), document.querySelector('.sizeandfit__fits'), document.querySelector('.sizeandfit__results-fromPDP'), document.querySelector('.sizeandfit__back'), document.querySelector('.sizeandfit__header h2'), document.querySelector('.sizeandfit__steps p'), document.querySelector('.sizeandfit__continue'), document.querySelector('.sizeandfit__results'), document.querySelector('.sizeandfit__finish'), document.querySelector('.sizeandfit__resultsfail'), document.querySelector('.sizeandfit__close')]; const typesActive = document.querySelector('.sizeandfit__types'); if (typesActive) { elements.splice(1, 0, typesActive); } elements.forEach( (element) => element.classList.add('hide')); if (step === '1' && typesActive) { [elements[0], elements[5], elements[6], elements[7]].forEach( (element) => element.classList.remove('hide')); elements[6].textContent = step; snfHeader.className = snfHeader.className.replace(/\bstep\d\b/g, 'step1'); } else if (step === '2' && typesActive) { [elements[1], elements[4], elements[6], elements[7]].forEach( (element) => element.classList.remove('hide')); elements[6].textContent = step; snfHeader.className = snfHeader.className.replace(/\bstep\d\b/g, 'step2'); } else if (step === '3' && typesActive) { [elements[2], elements[4], elements[6], elements[7]].forEach( (element) => element.classList.remove('hide')); elements[6].textContent = step; snfHeader.className = snfHeader.className.replace(/\bstep\d\b/g, 'step3'); } else if (step === '4' && typesActive && fromPDP) { this.fetchSize([elements[3], elements[4], elements[6]]); elements[6].textContent = step; snfHeader.className = snfHeader.className.replace(/\bstep\d\b/g, 'step4'); } else if (step === '4' && typesActive && !fromPDP) { this.fetchSize([elements[9], elements[4], elements[6], elements[8], elements[7]]); elements[6].textContent = step; snfHeader.className = snfHeader.className.replace(/\bstep\d\b/g, 'step4'); // Logic for inactive bodytypes below } else if (step === '1' && !typesActive) { [elements[0], elements[4], elements[5], elements[6]].forEach( (element) => element.classList.remove('hide')); elements[5].textContent = step; snfHeader.className = snfHeader.className.replace(/\bstep\d\b/g, 'step1'); } else if (step === '2' && !typesActive) { [elements[1], elements[3], elements[5], elements[6]].forEach( (element) => element.classList.remove('hide')); continueButton.classList.remove('hide'); elements[5].textContent = step; snfHeader.className = snfHeader.className.replace(/\bstep\d\b/g, 'step2'); } else if (step === '3' && !typesActive && fromPDP) { [elements[5]].forEach( (element) => element.classList.remove('hide')); elements[5].textContent = step; this.fetchSize([elements[2], elements[3]]); snfHeader.className = snfHeader.className.replace(/\bstep\d\b/g, 'step4'); } else if (step === '3' && !typesActive && !fromPDP) { [elements[5]].forEach( (element) => element.classList.remove('hide')); elements[5].textContent = step; this.fetchSize([elements[7], elements[3]]); snfHeader.classList.replace('step2', 'step4'); } } snfBackBtn() { const backBtn = document.querySelector('.sizeandfit__back'); const step = sessionStorage.getItem('snf_step'); const stepBackValue = parseInt(step) - 1; const stepBackString = stepBackValue.toString(); backBtn.addEventListener('click', () => { sessionStorage.setItem('snf_step', stepBackString); this.activeStep(); this.snfBackBtn(); } ); } fetchSize(elementArray) { const sizeResult = document.querySelectorAll('.size-result'); const sizeResultImage = document.querySelector('.sizeandfit__results--img img'); const height = sessionStorage.getItem('snf_height'); const weight = sessionStorage.getItem('snf_weight'); const form = sessionStorage.getItem('snf_form'); const image = sessionStorage.getItem('snf_image'); const loadingWrapper = document.querySelector('.sizeandfit__loading_pageWrapper'); const stepCounter = document.querySelector('.sizeandfit__steps'); const articleNumber = sessionStorage.getItem('snf_artnr'); const resultFailed = document.querySelector('.sizeandfit__resultsfail'); const resultFromPDP = document.querySelector('.sizeandfit__results-fromPDP'); const continueButton = document.querySelector('.sizeandfit__continue'); const finishButton = document.querySelector('.sizeandfit__finish'); const fromPDP = document.querySelector('.sizeandfit.from-pdp'); const closeButton = document.querySelector('.sizeandfit__close'); let type = sessionStorage.getItem('snf_type'); let artnr = ''; if (!type) { type = 'rectangular'; } if (articleNumber) { artnr = `&product_id=${articleNumber}`; } const fetchQuery = `&match_id=1&field_1=${type}&field_2=${form}&field_x=${weight}&field_y=${height}${artnr}`; stepCounter.classList.add('hide'); loadingWrapper.style.display = 'block'; this.loading_start(); fetch(`/cgi-bin/ibutik/API.fcgi?funk=PM${fetchQuery}`, { method: 'GET', headers: { 'Content-Type': 'application/json' } }).then( (response) => response.json()).then( (data) => { // Simulating a delay to ensure the loader animation finishes first setTimeout( () => { loadingWrapper.style.display = 'none'; if (elementArray && Array.isArray(elementArray)) { elementArray.forEach( (element) => element.classList.remove('hide')); } stepCounter.classList.remove('hide'); if (data.alt_value && data.alt_value_unavailable !== 1) { sizeResult.forEach( (result) => { result.textContent = data.alt_value; } ); sizeResultImage.setAttribute('src', image); } else if (data.value && !data.alt_value && data.value_unavailable !== 1) { sizeResult.forEach( (result) => { result.textContent = data.value; } ); sizeResultImage.setAttribute('src', image); } else if (data.value_unavailable === 1 || data.alt_value_unavailable === 1) { sizeResult.forEach( (result) => { result.textContent = data.value; } ); finishButton.classList.add('hide'); resultFailed.classList.remove('hide'); resultFromPDP.classList.add('hide'); closeButton.classList.remove('hide'); } if (fromPDP) { if (closeButton.classList.contains('hide')) { finishButton.classList.remove('hide'); } continueButton.classList.add('hide'); SizeAndFit.showGeneratedSize(); } else { continueButton.classList.remove('hide'); finishButton.classList.add('hide'); continueButton.querySelector('.finish').classList.remove('hide'); continueButton.querySelector('.continue').classList.add('hide'); } } , 1500); } ).catch( (error) => { console.error('Error:', error); } ); } bodyTypeHandler() { const types = document.querySelectorAll('.sizeandfit__types-wrapper img'); types.forEach( (type) => { if (type.classList.contains('active')) { // Check if 'snf_type' does not exist in sessionStorage if (!sessionStorage.getItem('snf_type')) { const formValue = type.getAttribute('data-value'); sessionStorage.setItem('snf_type', formValue); } } // Then attach the click event listener to all types regardless type.addEventListener('click', () => { const formValue = type.getAttribute('data-value'); types.forEach( (otherType) => { otherType.classList.remove('active'); } ); type.classList.add('active'); sessionStorage.setItem('snf_type', formValue); } ); } ); } loading_start() { document.getElementsByClassName('progress')[0].style.width = '0%'; document.getElementsByClassName('percentage')[0].innerHTML = '0%'; let count = 0; const progressBar = document.querySelector('.progress'); const percentage = document.querySelector('.percentage'); const interval = setInterval( () => { count = count + 2; progressBar.style.width = count + '%'; percentage.innerHTML = count + '%'; if (count === 100) { clearInterval(interval); this.handleFinishBtn(); } } , 30); } static async showGeneratedSize() { const sizeMatchFailed = document.querySelector('.sizematchfailed'); const generatedsize = document.querySelector('.generatedsize'); const snf_result = document.querySelector('.snf_result'); const generatedsizeValue = document.querySelector('.generatedsize .size'); const sizeMatchFailedValue = document.querySelector('.sizematchfailed .size'); const sizes = document.querySelectorAll('.buybox__variant--item'); const snfTriggerButton = document.querySelectorAll('.snf-trigger__btn'); const sizeHolder = document.getElementById('variation-1'); const trueSizeFields = document.querySelectorAll('.TrueSize'); const articleNumber = sessionStorage.getItem('snf_artnr'); const pdpArtnr = document.querySelector('.product-id-info').textContent; sessionStorage.setItem('snf_step', '1'); try { let artnr = ''; if (articleNumber && 1 == 0) {} else if (pdpArtnr) { artnr = `&product_id=${pdpArtnr}`; } let startTime = performance.now(); const response = await fetch(`/cgi-bin/ibutik/API.fcgi?funk=PM&match_id=1&get_customer=1${artnr}`, { method: 'GET', headers: { 'Content-Type': 'application/json' } }); let eventHandledTime = performance.now(); exponea.track('speed', { 'action': 'snf_getSize', 'speed': `${eventHandledTime - startTime}` }); const data = await response.json(); if (data.value && generatedsize) { let sizeFound = false; let data_size = data.value; let data_size_variant = data.value_variant; if (data.alt_value) { data_size = data.alt_value; } if (data.alt_value_variant) { data_size_variant = data.alt_value_variant; } // Matching sizes and checking for disabled class sizes.forEach( (size) => { const sizeValue = size.getAttribute('data-value'); if (data_size === sizeValue || data_size_variant === sizeValue) { sizeFound = true; const snfTriggerButton = document.querySelectorAll('.snf-trigger__btn'); snfTriggerButton[0].classList.add('hide'); if (size.classList.contains('disabled')) { sizes.forEach( (size) => size.classList.remove('active')); generatedsize.classList.add('hide'); sizeMatchFailed.classList.remove('hide'); snf_result.classList.remove('hide'); sizeMatchFailedValue.textContent = data_size; } else { if (data_size_variant) { sizeHolder.dataset.value = data_size_variant; } else { sizeHolder.dataset.value = data_size; } sessionStorage.setItem('snf_size', data_size); if (size.classList.contains('active')) { return; } else { size.click(); } if (data.value_variant) { generatedsizeValue.textContent = data_size_variant; } else { generatedsizeValue.textContent = data_size; } generatedsize.classList.remove('hide'); snf_result.classList.remove('hide') sizeMatchFailed.classList.add('hide'); } } } ); // If the size was not found if (!sizeFound) { generatedsize.classList.add('hide'); sizeMatchFailed.classList.remove('hide'); if (data.value_variant) { sizeMatchFailedValue.textContent = data.value_variant; } else { sizeMatchFailedValue.textContent = data_size; } snf_result.classList.remove('hide') const triggerButton = document.querySelector('button.sizeAndFitTrigger'); sessionStorage.setItem('snf_size', 'not_found'); if (triggerButton) { triggerButton.classList.add('hide'); } trueSizeFields.forEach(function(field) { field.classList.add('hide'); // Add the 'hide' class to each element }); } else { trueSizeFields.forEach(function(field) { field.classList.add('hide'); // Add the 'hide' class to each element }); } } const height = document.getElementById('snf-height'); const weight = document.getElementById('snf-weight'); if (data.field_x && data.field_y) { if (height && weight) { height.value = data.field_y; weight.value = data.field_x; } } else if (localStorage.getItem('snf_height') && localStorage.getItem('snf_weight')) { if (height && weight) { height.value = localStorage.getItem('snf_height'); weight.value = localStorage.getItem('snf_weight'); } } window.dispatchEvent(new CustomEvent("snf_done")); } catch (error) { console.error('Error:', error); } } handleFinishBtn() { const finishButton = document.querySelector('.sizeandfit__finish'); const buyButton = document.getElementById('air-buy'); const sizeAndFit = document.querySelector('.sizeandfit'); finishButton.addEventListener('click', (e) => { e.stopPropagation(); e.preventDefault(); const sizeNFit = document.getElementById('sizeandfit'); const backdropBlur = document.querySelector('.backdrop'); SizeAndFit.showGeneratedSize(); buyButton.click(); sessionStorage.setItem('snf_step', '1'); finishButton.classList.add('hide'); sizeAndFit.classList.remove('from-pdp'); backdropBlur.classList.remove('active'); sizeNFit.classList.remove('active'); } , { once: true }); } } /***/ } ), /***/ "./content/default/components/style_advisor/styleadvisor.js": /*!******************************************************************!*\ !*** ./content/default/components/style_advisor/styleadvisor.js ***! \******************************************************************/ /***/ ( (__unused_webpack_module, __webpack_exports__, __webpack_require__) => { "use strict"; __webpack_require__.r(__webpack_exports__); /* harmony export */ __webpack_require__.d(__webpack_exports__, { /* harmony export */ "default": () => (/* binding */ StyleAdvisor)/* harmony export */ }); /* harmony import */ var _views_product_simple_slider__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../../views/product/simple_slider */ "./content/default/views/product/simple_slider.js"); let animating = false; let decisionVal = 80; let pullDeltaX = 0; let startX = 0; let $card; let _this; class StyleAdvisor { constructor() { this.init_events() if (document.getElementById('datepicker')) { this.initCalendar(); } } init_events() { const backdropBlur = document.querySelector(".backdrop") const styleadvisor = document.getElementById("styleadvisor") window.liveEvent(".StyleAdviceTrigger", "click", (event, element) => { if (sessionStorage) { this.uuid = sessionStorage.getItem("style_uuid"); if (!this.uuid) { this.uuid = this.uuidv4(); sessionStorage.setItem("style_uuid", this.uuid); } this.styleCounter = sessionStorage.getItem("style_counter"); if (!this.styleCounter) { this.styleCounter = 1; } this.stored_style_type = sessionStorage.getItem("style_type"); } if (typeof (_imbox) !== "undefined") { _imbox.push(['hideLauncher']); _imbox.push(['hideWidget']); } styleadvisor.classList.add("active") if (styleadvisor.hasAttribute("data-step")) { const step = styleadvisor.dataset.step; if (step === "2" || step === "3") { styleadvisor.classList.add("live"); } } backdropBlur.classList.add("active") document.body.classList.add("styleadvisor") if (!styleadvisor.dataset.step) { if (this.stored_style_type) { this.getContent(4, 1) } else { this.getContent(1) } if (document.querySelectorAll(".styleadvisor .snapping--wrapper").length) { document.querySelectorAll(".styleadvisor .snapping--wrapper").forEach(function(elem) { new _views_product_simple_slider__WEBPACK_IMPORTED_MODULE_0__["default"](elem) }) } } } ) window.liveEvent(".menu__styleadvicer a", "click", (event, element) => { if (sessionStorage) { this.uuid = sessionStorage.getItem("style_uuid"); if (!this.uuid) { this.uuid = this.uuidv4(); sessionStorage.setItem("style_uuid", this.uuid); } this.styleCounter = sessionStorage.getItem("style_counter"); if (!this.styleCounter) { this.styleCounter = 1; } this.stored_style_type = sessionStorage.getItem("style_type"); } if (typeof (_imbox) !== "undefined") { _imbox.push(['hideLauncher']); _imbox.push(['hideWidget']); } styleadvisor.classList.add("active") if (styleadvisor.hasAttribute("data-step")) { const step = styleadvisor.dataset.step; if (step === "2" || step === "3") { styleadvisor.classList.add("live"); } } backdropBlur.classList.add("active") document.body.classList.add("styleadvisor") if (!styleadvisor.dataset.step) { if (this.stored_style_type) { this.getContent(4, 1) } else { this.getContent(1) } const styleAdvisorSlider = document.querySelector(".styleadvisor .snapping--wrapper") if (styleAdvisorSlider) { new _views_product_simple_slider__WEBPACK_IMPORTED_MODULE_0__["default"](styleAdvisorSlider) } } } ) window.liveEvent(".continuePop .restart, .StyleAdviceRestart", "click", (event, element) => { this.currentSlide = 1; this.updateCurrentSlide(); document.querySelectorAll(".brands_list_brand.--checked").forEach( (elem) => { elem.classList.remove("--checked"); } ); if (document.querySelectorAll(".brand_continue .styleadvisor__continue").length) { document.querySelectorAll(".brand_continue .styleadvisor__continue")[0].classList.add("--disabled"); } document.querySelectorAll('.styleadvisor__step').forEach( (item) => { if (item.dataset.step === '4') { item.remove(); } } ); this.getContent(1, 0, 1) styleadvisor.classList.remove("live") } ) window.liveEvent(".continuePop .continue", "click", (event, element) => { styleadvisor.classList.remove("live") } ) window.liveEvent(".styleadvisor_back", "click", (event, element) => { const styleadvisor = document.getElementById("styleadvisor") this.getContent(parseInt(styleadvisor.dataset.step) - 1) } ) window.liveEvent(".styleadvisor__header .close, .personlizedContent .cm_article_wrapper a", "click", () => { if (typeof (_imbox) !== "undefined") { _imbox.push(['showLauncher']) } styleadvisor.classList.remove("active") backdropBlur.classList.remove("active") document.body.classList.remove("styleadvisor") if (sessionStorage) { this.test_completed = sessionStorage.getItem("test_completed"); if (this.test_completed && this.test_completed !== '') { location.reload(); sessionStorage.setItem("test_completed", ""); } } } ) window.liveEvent(".styleadvisor__continue", "click", (event, element) => { if (element.classList.contains("--disabled")) return var step = document.querySelector('.styleadvisor__step.--active').dataset.step; if (step === "1") { if (sessionStorage) { this.styleCounter++; sessionStorage.setItem("style_counter", this.styleCounter); } exponea.track('style_event', { 'action': 'start', 'type': 'styleadvisor', 'stylerun': this.uuid + "_" + this.styleCounter }); } if (step === "3") { if (document.getElementsByClassName("styleadvisor__loading_pageWrapper")[0].style.display === 'none') { document.getElementsByClassName("brands_list")[0].style.display = "none"; document.getElementsByClassName("brand_continue")[0].style.display = "none"; document.getElementsByClassName("styleadvisor__loading_pageWrapper")[0].style.display = "block"; this.loading_start(); } } const styleadvisor = document.getElementById("styleadvisor") this.getContent(parseInt(styleadvisor.dataset.step) + 1) } ) /* SWIPE FUNKTIONALITET */ // window.liveEvent(".styleadvisor_swipe", "mousedown", (event, element) => { // if (event.buttons == 1) { // this.swipeHandler(event, element); // } // }); // window.liveEvent(".styleadvisor_swipe", "touchstart", (event, element) => { // this.swipeHandler(event, element); // }); window.liveEvent(".styleadvisor_brand", "click", (event, element) => { if (document.querySelectorAll(".styleadvisor_brand.--checked").length < 800 || element.classList.contains("--checked")) { element.classList.toggle("--checked") } const checkedBrands = document.querySelectorAll(".styleadvisor_brand.--checked").length if (checkedBrands >= 2) { this.toggleContinueButton(0) } else { this.toggleContinueButton(1) } } ) window.liveEvent("#styleadvisor_like", "click", (event, element) => { if (!this.buttonsLocked) { this.buttonsLocked = true; this.triggerSwipe(event, element, "liked"); this.updateCurrentSlide(); } } ) window.liveEvent("#styleadvisor_dislike", "click", (event, element) => { if (!this.buttonsLocked) { this.buttonsLocked = true; this.triggerSwipe(event, element, "disliked"); this.updateCurrentSlide(); } } ) window.liveEvent(".styleadvisor__loginBtn", "click", (event, element) => { const styleadvisor_login_form = document.getElementById("styleadvisor-login-form-wrapper") if (styleadvisor_login_form) { styleadvisor_login_form.classList.toggle("hidden") } } ) window.liveEvent("#styleadvisor-login-form-wrapper .close", "click", (event, element) => { const styleadvisor_login_form = document.getElementById("styleadvisor-login-form-wrapper") styleadvisor_login_form.classList.toggle("hidden") } ) window.liveEvent("#styleadvisor__createprofile .close", "click", (event, element) => { const styleadvisor_login_form = document.getElementById("styleadvisor__createprofile") styleadvisor_login_form.classList.toggle("hidden") } ) window.liveEvent("#styleadvisor-login-form", "submit", (event, element) => { event.preventDefault() this.login(element) } ) window.liveEvent("#styleadvisor-create-form", "submit", (event, element) => { event.preventDefault() this.createProfile(element) } ) window.liveEvent("#styleadvisor__create", "keyup", (event, element) => { if (/^([a-zA-Z0-9_\.\-])+\@(([a-zA-Z0-9\-])+\.)+([a-zA-Z0-9]{2,4})+$/.test(element.value)) { this.toggleContinueButton(0) } else { this.toggleContinueButton(1) } } ) } async getContent(step, restoring, restart) { const styleadvisor = document.getElementById("styleadvisor") styleadvisor.classList.add("loading") if (step == 1 && !restoring && !restart) { const response = await fetch("shop?funk=get_restoring_style&custom_func=1") const result = await response.json() if (result.restoring_style_type) { step = 4; restoring = 1; } } if (!restoring) { restoring = 0; } if (step == 4 && !restoring) { this.save_styleadvisor(1); } let existing_step = styleadvisor.querySelector('.styleadvisor__step[data-step="' + step + '"]') if (existing_step) { document.querySelectorAll(".styleadvisor__step.--active").forEach( (element) => { element.classList.remove("--active") } ) existing_step.classList.add("--active") styleadvisor.dataset.step = step document.querySelectorAll(".styleadvisor_swipe").forEach( (element) => { element.classList.remove("--liked") element.classList.remove("--disliked") element.classList.remove("--current") element.setAttribute("style", "") } ) styleadvisor.classList.remove("loading") if (step === 3) { // Reset the counter if its visible if (document.getElementsByClassName("styleadvisor__loading_pageWrapper")[0].style.display === 'block') { document.getElementsByClassName("brands_list")[0].style.display = ""; document.getElementsByClassName("brand_continue")[0].style.display = ""; document.getElementsByClassName("styleadvisor__loading_pageWrapper")[0].style.display = "none"; document.getElementsByClassName("progress")[0].style.width = "0%"; document.getElementsByClassName("percentage")[0].innerHTML = "0%"; } } } else { const response = await fetch("shop?funk=get_style_advisor&custom_func=1&step=" + step + "&restoring=" + restoring) const result = await response.json() if (result.html) { var newElement = document.createElement("div") newElement.className = "styleadvisor__step --active" newElement.dataset.step = step newElement.innerHTML = result.html document.querySelectorAll(".styleadvisor__step.--active").forEach( (element) => { element.classList.remove("--active") } ) styleadvisor.appendChild(newElement) styleadvisor.dataset.step = step if (step == 2) { // Set the total number of slides this.totalSlides = document.getElementsByClassName("styleadvisor_swipe").length; this.currentSlide = 1; document.getElementById("sa-totalSlides").innerHTML = this.totalSlides; this.updateCurrentSlide(); } if (step == 4 && !restoring) { var error_display = document.getElementById("style_advisor_error"); if (error_display && window.getComputedStyle(error_display).display === 'block') { // error exponea.track('style_event', { 'action': 'error', 'type': 'styleadvisor', 'parameter': 'no_segment' }); } else { // result_page exponea.track('style_event', { 'action': 'result_page', 'type': 'styleadvisor', 'stylerun': this.uuid + "_" + this.styleCounter, 'parameter': result.style_type }); sessionStorage.setItem("style_type", result.style_type); } } if (step == 6) { grecaptcha.render('captcha_element', { 'sitekey': '6Lcs9cYUAAAAAO6RWrvcXgKPFUCI86ARhIsI7c5t' }); } styleadvisor.classList.remove("loading") } } } loading_start() { var interval; var count = 0; var progressBar = document.querySelector(".progress"); var percentage = document.querySelector(".percentage"); interval = setInterval(function() { count++; progressBar.style.width = count + "%"; percentage.innerHTML = count + "%"; if (count === 100) { clearInterval(interval); } }, 50); } updateCurrentSlide() { if (this.currentSlide <= this.totalSlides) { document.getElementById("sa-count").innerHTML = this.currentSlide; this.currentSlide++; } } releaseSlide() { if (pullDeltaX >= decisionVal) { $card.classList.add("--liked") $card.classList.remove("--current") _this.scaleBackgroundImages(1) const segment_data = _this.get_segment_data_from_element($card) _this.bloomreach_track("liked", "style_segment_image", segment_data) } else if (pullDeltaX <= -decisionVal) { $card.classList.add("--disliked") $card.classList.remove("--current") _this.scaleBackgroundImages(1) const segment_data = _this.get_segment_data_from_element($card) _this.bloomreach_track("disliked", "style_segment_image", segment_data) } else { $card.setAttribute("style", "transform: translateY(0) scale(1);") _this.scaleBackgroundImages(0) } pullDeltaX = 0 animating = false if (!document.querySelectorAll(".styleadvisor_swipe:not(.--liked, .--disliked)").length) { _this.getContent(3) } } swipeHandler(e, element) { if (animating) return $card = element $card.classList.add("--current") startX = e.pageX || e.originalEvent.touches[0].pageX document.addEventListener("mousemove", this.handleMove, true) document.addEventListener("touchmove", this.handleMove, true) _this = this document.addEventListener("mouseup", this.handleRelease, true) document.addEventListener("touchend", this.handleRelease, true) } /* SWIPE FUNKTIONALITET */ // handleMove(e) { // let x = e.pageX || e.originalEvent.touches[0].pageX; // pullDeltaX = (x - startX); // if (!pullDeltaX) return; // let percent = pullDeltaX < 1 ? pullDeltaX / 350 * -1 : pullDeltaX / 350 * 1; // animating = true; // let deg = pullDeltaX / 10; // $card.style.transform = "translateX(" + pullDeltaX + "px) translateY(0px) scale(1) rotate(" + deg + "deg)"; // let opacity = pullDeltaX < 0 ? (pullDeltaX / 100 * -1) : pullDeltaX / 100; // $card.style.opacity = 1 - opacity * 0.3; // $card.classList.add("--current"); // _this.scaleBackgroundImages(percent); // } // handleRelease(e) { // document.removeEventListener("mousemove", _this.handleMove, true); // document.removeEventListener("touchmove", _this.handleMove, true); // document.removeEventListener("mouseup", _this.handleRelease, true); // document.removeEventListener("touchend", _this.handleRelease, true); // _this.releaseSlide(); // } triggerSwipe(e, element, type) { const currentImage = document.querySelectorAll(".styleadvisor_swipe:not(.--liked, .--disliked)")[0] if (!currentImage) { return } currentImage.classList.add("--current") _this = this let counter = 0 let swipeInterval = setInterval(function() { counter++ let pullDeltaX = type == "liked" ? counter * 5 : counter * -5 let deg = pullDeltaX / 10 let opacity = pullDeltaX < 0 ? (pullDeltaX / 100) * -1 : pullDeltaX / 100 currentImage.style.transform = "translateX(" + pullDeltaX + "px) translateY(0px) scale(1) rotate(" + deg + "deg)" currentImage.style.opacity = 1 - opacity * 0.3 if (counter == 100) { clearInterval(swipeInterval) currentImage.classList.add("--" + type) const segment_data = _this.get_segment_data_from_element(currentImage) _this.bloomreach_track(type, "style_segment_image", segment_data) _this.buttonsLocked = false; if (!document.querySelectorAll(".styleadvisor_swipe:not(.--liked, .--disliked)").length) { _this.getContent(3) } } _this.scaleBackgroundImages(counter / 5) }, 0) } scaleBackgroundImages(percent) { const activeImages = document.querySelectorAll(".styleadvisor_swipe:not(.--liked, .--disliked, .--current)") let scale_drag = 0.1 * percent let translate_drag = 2 * percent let opacity_drag = 0.3 * percent let scaleIncrement = scale_drag > 0.1 ? 1 : 0.9 + scale_drag let transform = translate_drag > 2 ? 0 : 2 - translate_drag let opacity = opacity_drag > 0.3 ? 1 : 0.7 + opacity_drag activeImages.forEach( (element) => { element.style.transform = "translateY(" + transform + "px) scale(" + scaleIncrement + ")" element.style.opacity = opacity scaleIncrement = scaleIncrement - 0.1 transform = transform + 2 opacity = opacity > 0.4 ? opacity - 0.4 : 0 } ) } bloomreach_track(like_type, event_type, segment_data, title) { if (!window.exponea) return; window.exponea.track("style_event", { type: "styleadvisor", action: like_type == "liked" ? "like" : "dislike", parameter: event_type, title: segment_data.title, style_segment_1: segment_data.segment_1, style_segment_2: segment_data.segment_2, style_segment_3: segment_data.segment_3, timestamp: Date.now(), stylerun: this.uuid + '_' + this.styleCounter }) } get_segment_data_from_element(element) { return { title: element.dataset.id, segment_1: element.dataset.id, segment_2: element.dataset.id, segment_3: element.dataset.id, } } get_segment_data_from_brand(brand) { return { title: brand.dataset.name, segment_1: brand.dataset.segment_1, segment_2: brand.dataset.segment_2, segment_3: brand.dataset.segment_3, } } async login(form) { if (!form.user.value && !form.pass.value) return const data = new URLSearchParams(new FormData(form)) const response = await fetch("/shop", { method: "POST", body: data, }) const result = await response.json() if (result.status.code == 200) { document.getElementById("styleadvisor__loginwrapper").style.display = "none" document.getElementById("styleadvisor__createwrapper").style.display = "none" this.toggleContinueButton(0) this.setLoginIcon(); } else { document.getElementById("styleadvisor__login-error").innerHTML = "Fel användaruppgifter" } } async createProfile(form) { if (!form.user.value) return const data = new URLSearchParams(new FormData(form)) const response = await fetch("/shop", { method: "POST", body: data, }) const result = await response.json() if (result.status == 1) { this.save_styleadvisor(); document.getElementById("styleadvisor__createprofile").classList.add("hide"); if (document.querySelectorAll("#styleadvisor__loginwrapper").length) { document.getElementById("styleadvisor__loginwrapper").classList.add("hide"); } this.setLoginIcon(); } else if (result.status == 2) { document.getElementById("styleadvisor-create-password").classList.remove("hide"); document.getElementById("create-error").innerHTML = result.message; } } async save_styleadvisor(track) { const brandList = []; const segmentImages = []; document.querySelectorAll(".styleadvisor_brand.--checked").forEach( (element) => { const segment_data = _this.get_segment_data_from_brand(element) if (track) { _this.bloomreach_track("liked", "brand", segment_data) } brandList.push(element.dataset.id); } ); if (track) { // Complete exponea.track('style_event', { 'action': 'complete', 'type': 'styleadvisor', 'stylerun': this.uuid + "_" + this.styleCounter }); sessionStorage.setItem("test_completed", "completed"); } document.querySelectorAll('.styleadvisor_swipe').forEach( (element) => { const imgs = element.getElementsByTagName('img'); let answer; if (element.classList.contains('--disliked')) { answer = '0'; } else if (element.classList.contains('--liked')) { answer = '1'; } if (imgs.length && answer !== '') { segmentImages.push({ segment: element.dataset.id, image: imgs[0].getAttribute('src'), like: answer }); } } ); const data = new URLSearchParams(); data.append('funk', 'save_styleadvisor'); data.append('brands', JSON.stringify(brandList)); data.append('segment_data', JSON.stringify(segmentImages)); const response = await fetch('/shop', { method: 'POST', body: data }); const result = await response.json(); } toggleContinueButton(locked) { document.querySelectorAll(".styleadvisor__step.--active .styleadvisor__continue").forEach( (element) => { if (locked) { element.classList.add("--disabled") } else { element.classList.remove("--disabled") } } ) } test async initCalendar() { // let link = document.createElement("link"); link.href = '/themes/hypefront/design/css/vanilla-calendar.min.css'; link.type = "text/css"; link.rel = "stylesheet"; document.getElementsByTagName("head")[0].appendChild(link); const d = new Date(); let currDay = d.getDate(); let currMonth = d.getMonth() + 1; let currYear = d.getFullYear(); let monthLength = new Date(currYear,currMonth,0).getDate(); if (currMonth < 10) { currMonth = "0" + currMonth; } if (currDay < 10) { currDay = "0" + currDay; } const qs = new URLSearchParams({ funk: 'Stilradgivning_Populate_Calendar', year: currYear, month: currMonth, day: currDay, monthLength: monthLength }).toString(); const response = await fetch('/shop?' + qs); const result = await response.json(); const enabledDays = []; if (result && result['status'] === '1') { if (result.json) { this.dates = JSON.parse(result.json); const dayExists = []; for (let i = 0; i < this.dates.data.length; i++) { const day = this.dates.data[i].starts_at.split("T")[0]; if (!dayExists[day]) { enabledDays.push(day); dayExists[day] = true; } } } } const obj = this; const calendar = new VanillaCalendar('#datepicker',{ settings: { lang: 'define', range: { enabled: enabledDays } }, locale: { months: ['Januari', 'Februari', 'Mars', 'April', 'Maj', 'Juni', 'Juli', 'Augusti', 'September', 'Oktober', 'November', 'December'], weekday: ['Sö', 'Må', 'Ti', 'On', 'To', 'Fr', 'Lö'] }, actions: { clickDay(e, dates) { if (dates.length == 0) return; obj.getTimes(dates[0]) } } }); calendar.init(); document.getElementById('booking-btn').addEventListener('click', function() { obj.bookTimeslot(); }); } getTimes(day) { const d = new Date(day); let currDate = d.getDate(); let currMonth = d.getMonth() + 1; if (currMonth < 10) { currMonth = "0" + currMonth; } if (currDate < 10) { currDate = "0" + currDate; } let timesHtml = ''; const obj = this; for (let i = 0; i < this.dates.data.length; i++) { const dateDay = this.dates.data[i].starts_at.split("T")[0]; if (day !== dateDay) continue; const time = this.dates.data[i].starts_at.split("T")[1].split(":00+")[0]; const timestamp = parseInt(new Date(this.dates.data[i].starts_at).getTime() / 1000); // Tider måste vara minst 6h from nu. const timestampMin = parseInt(new Date().getTime() / 1000) + (6 * 60 * 60); if (timestamp >= timestampMin) { timesHtml += "
    " + time + "
    "; } document.getElementById('timepicker_times').innerHTML = timesHtml; document.querySelectorAll('.timepicker_time').forEach(elem => { elem.addEventListener('click', function() { obj.reserveTimeslot(elem.dataset.start, elem.dataset.end, elem); }); } ); } } async reserveTimeslot(start, end, elem) { if (!this.reserved_times) { this.reserved_times = []; } if (!this.reserved_times[start]) { const qs = new URLSearchParams({ funk: 'Stilradgivning_Reservera_Tid', starts_at: start, ends_at: end }).toString(); const response = await fetch('/shop?' + qs); const result = await response.json(); if (result && result['status'] === '1') { document.querySelectorAll('.timepicker_time').forEach(elem => { elem.classList.remove('reserved'); } ); const json = JSON.parse(result.json); elem.classList.add('reserved'); elem.setAttribute('res_id', json.id); this.reserved_times[start] = json.id; } } } async bookTimeslot() { const timeDiv = document.querySelector('.timepicker_time.reserved'); const phoneInput = document.getElementById('customer_phone'); const phone = phoneInput.value; const thankyou_page_url = document.getElementById('thankyou_page_url').value; if (phone) { phoneInput.classList.remove('error'); } else { phoneInput.classList.add('error'); return false; } if (!timeDiv) return false; const start = timeDiv.dataset.start; const end = timeDiv.dataset.end; const newDate = new Date(start); const newDate_Ends = new Date(end); const timestamp = parseInt(newDate.getTime() / 1000); const timestamp_ends = parseInt(newDate_Ends.getTime() / 1000); const resId = timeDiv.getAttribute('res_id'); const qs = new URLSearchParams({ funk: 'Stilradgivning_Boka_Tid', starts_at: start, starts_unix: timestamp, ends_at: end, ends_unix: timestamp_ends, phone: phone, res_id: resId }).toString(); const response = await fetch('/shop?' + qs); const result = await response.json(); if (result && result['status'] === '1') { window.location.href = thankyou_page_url; var br_phone = phone.replace(/^0/, "0046"); br_phone = br_phone.replace(/\s/g, ''); exponea.track('style_event', { 'action': 'accept', 'type': 'styleadvisor', 'parameter': 'meeting', 'meeting_date': timestamp, 'meeting_phone': br_phone }); } else { alert('bokning kunde inte genomföras'); } } uuidv4() { return ([1e7] + -1e3 + -4e3 + -8e3 + -1e11).replace(/[018]/g, c => (c ^ crypto.getRandomValues(new Uint8Array(1))[0] & 15 >> c / 4).toString(16)); } setLoginIcon() { const login_icon = document.querySelector("#login-icon svg"); const login_wrapper = document.getElementById("login-wrapper"); const login_icon_html = login_icon.outerHTML; login_icon.outerHTML = "" + login_icon_html + ""; document.querySelector("#login-icon svg").setAttribute("fill", "black"); login_wrapper.style.visibility = "hidden"; } } /***/ } ), /***/ "./content/default/scripts/utils.js": /*!******************************************!*\ !*** ./content/default/scripts/utils.js ***! \******************************************/ /***/ ( (__unused_webpack_module, __webpack_exports__, __webpack_require__) => { "use strict"; __webpack_require__.r(__webpack_exports__); /* harmony export */ __webpack_require__.d(__webpack_exports__, { /* harmony export */ "executeJs": () => (/* binding */ executeJs), /* harmony export */ "formatPriceHtml": () => (/* binding */ formatPriceHtml), /* harmony export */ "getCookie": () => (/* binding */ getCookie), /* harmony export */ "getStorage": () => (/* binding */ getStorage), /* harmony export */ "removeStorage": () => (/* binding */ removeStorage), /* harmony export */ "setStorage": () => (/* binding */ setStorage)/* harmony export */ }); function formatPriceHtml(price, price_regular, campaign, price_prefix="") { const currency_prefix = window.shop_settings['currency_prefix'] || ''; const currency_suffix = window.shop_settings['currency_suffix'] || ''; price = _prettyPrice(price); if (campaign) { price_regular = _prettyPrice(price_regular); return `${currency_prefix}${price_prefix}${price_regular}${currency_suffix} ${currency_prefix}${price_prefix}${price}${currency_suffix}`; } else { return `${currency_prefix}${price_prefix}${price}${currency_suffix}`; } } function _prettyPrice(price) { price = price.toString().replace(/\B(?=(\d{3})+(?!\d))/g, ' '); return price.replace(/\./g, ','); } function executeJs(container) { const scripts = container.getElementsByTagName('script'); for (let i = 0; i < scripts.length; i++) { let execute = true; if (scripts[i].getAttribute('type') === 'application/ld+json') { execute = false; } if (execute) { const consentType = scripts[i].getAttribute('consent_type'); if (consentType) { execute = check_consent(consentType, ""); } } if (execute) { const s = document.createElement("script"); if (scripts[i].getAttribute('type') !== 'application/ld+json') { s.text = scripts[i].innerHTML; try { document.head.appendChild(s).parentNode.removeChild(s); } catch (err) { console.log(err); } } } } } function getCookie(name) { var cookieArr = document.cookie.split(";"); for (var i = 0; i < cookieArr.length; i++) { var cookiePair = cookieArr[i].split("="); if (name == cookiePair[0].trim()) { return decodeURIComponent(cookiePair[1]); } } return null; } function setStorage(name, value, expires) { if (typeof (Storage) === 'undefined') return null; if (expires) { this.cart.expires = Date.now() + expires * 60000; } window.localStorage.setItem(name, JSON.stringify(value)); } function removeStorage(name) { if (typeof (Storage) === 'undefined') return null; window.localStorage.removeItem(name); } function getStorage(name, expires) { if (typeof (Storage) === 'undefined') return null; let str = window.localStorage.getItem(name); if (str == null) return undefined; let data; try { data = JSON.parse(str); } catch (e) { return undefined; } if (data.expires && data.expires < Date.now()) { return undefined; } return data; } /***/ } ), /***/ "./content/default/views/brand/brandsearch.js": /*!****************************************************!*\ !*** ./content/default/views/brand/brandsearch.js ***! \****************************************************/ /***/ ( (__unused_webpack_module, __webpack_exports__, __webpack_require__) => { "use strict"; __webpack_require__.r(__webpack_exports__); /* harmony export */ __webpack_require__.d(__webpack_exports__, { /* harmony export */ "default": () => (/* binding */ BrandSearch)/* harmony export */ }); class BrandSearch { constructor() { this.init_events(); } init_events() { window.liveEvent(".brands_list_filter", "keyup", (event, element) => { this.filter_brands(element.value, element.closest(".brands_list")); } ); window.liveEvent(".brands_list_show_all", "click", (event, element) => { this.filter_brands("", element.closest(".brands_list")) } ); window.liveEvent(".brands_list_letter", "click", (event, element) => { this.filter_brands_letter(element.innerText, element.closest(".brands_list")) } ); } filter_brands(value, parent) { if (!value) { parent.querySelectorAll('.brands_list_brand, .brands_list_wrapper').forEach(element => { element.classList.remove("--hidden"); } ); parent.querySelectorAll('.brands_list_filter').forEach(element => { element.value = ""; } ); } else { parent.querySelectorAll(".brands_list_wrapper").forEach( (element) => { element.classList.remove("--hidden") } ) parent.querySelectorAll('.brands_list_brand').forEach(element => { element.classList.add("--hidden"); } ); parent.querySelectorAll('.brands_list_brand[data-value*="' + value.toLowerCase() + '"]').forEach(element => { element.classList.remove("--hidden"); } ); parent.querySelectorAll('.brands_list_wrapper').forEach(element => { if (element.querySelectorAll('.brands_list_brand').length == element.querySelectorAll('.brands_list_brand.--hidden').length) { element.classList.add("--hidden"); } } ); } } filter_brands_letter(letter, parent) { parent.querySelectorAll('.brands_list_brand').forEach(element => { element.classList.remove("--hidden"); } ); parent.querySelectorAll('.brands_list_wrapper').forEach(element => { element.classList.add("--hidden"); } ); parent.querySelectorAll('.brands_list_wrapper[data-letter*="' + letter.toLowerCase() + '"]').forEach(element => { element.classList.remove("--hidden"); } ); parent.querySelectorAll('.brands_list_filter').forEach(element => { element.value = ""; } ); } } /***/ } ), /***/ "./content/default/views/checkout/checkout.js": /*!****************************************************!*\ !*** ./content/default/views/checkout/checkout.js ***! \****************************************************/ /***/ ( (__unused_webpack_module, __webpack_exports__, __webpack_require__) => { "use strict"; __webpack_require__.r(__webpack_exports__); /* harmony export */ __webpack_require__.d(__webpack_exports__, { /* harmony export */ "default": () => (/* binding */ Checkout)/* harmony export */ }); class Checkout { } /***/ } ), /***/ "./content/default/views/mypages/reservation.js": /*!******************************************************!*\ !*** ./content/default/views/mypages/reservation.js ***! \******************************************************/ /***/ ( (__unused_webpack_module, __webpack_exports__, __webpack_require__) => { "use strict"; __webpack_require__.r(__webpack_exports__); /* harmony export */ __webpack_require__.d(__webpack_exports__, { /* harmony export */ "default": () => (/* binding */ Reservation)/* harmony export */ }); class Reservation { constructor(cart) { this.cart = cart; this.init(); } init() { document.querySelectorAll('.Stilradgivning_Artikel .Knapp_Kop a').forEach(element => { element.addEventListener('click', (e) => { e.preventDefault(); let form = element.parentNode.parentNode.parentNode.parentNode.parentNode; let product_id = form.altnr.value; if (product_id) { this.cart.add_item(product_id, 1); } } ); } ); } } /***/ } ), /***/ "./content/default/views/product/ajaxify.js": /*!**************************************************!*\ !*** ./content/default/views/product/ajaxify.js ***! \**************************************************/ /***/ ( (__unused_webpack_module, __webpack_exports__, __webpack_require__) => { "use strict"; __webpack_require__.r(__webpack_exports__); /* harmony export */ __webpack_require__.d(__webpack_exports__, { /* harmony export */ "default": () => (/* binding */ Ajaxify)/* harmony export */ }); /* harmony import */ var _views_product_simple_slider__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../../views/product/simple_slider */ "./content/default/views/product/simple_slider.js"); /* harmony import */ var _scripts_utils_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../../scripts/utils.js */ "./content/default/scripts/utils.js"); /* harmony import */ var _components_size_and_fit_sizeAndFit__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../../components/size_and_fit/sizeAndFit */ "./content/default/components/size_and_fit/sizeAndFit.js"); class Ajaxify { constructor(productPage, nav, filter) { this.productPage = productPage; this.navMenu = nav; this.filter = filter; this.isSetup = false; this.productLoading = false; this.productLoaded = false; this.fromReqestType = ''; this.offset = 0; this.initEvents(); } initEvents() { window.liveEvent('.navigate-product', 'click', (event, element) => { if (document.querySelector('.backdrop').classList.contains('active')) { document.querySelector('.backdrop').classList.remove('active'); document.querySelector('#air-cart-module').classList.remove('active'); document.body.classList.remove('cart-open'); document.body.style.overflow = ''; } if (element.href) { event.preventDefault(); if (this.fromList(element)) { // Pass the element to the getProduct function this.getProduct(element.href, element); } else { this.navigatePage(element.href, 'product'); } } } ); document.querySelectorAll('.Din_Sida_Onskelista_Wrapper .Knapp_Kop a').forEach( (element) => { element.addEventListener('click', (e) => { e.preventDefault(); let form = element.parentNode.parentNode.parentNode.parentNode.parentNode; let product_id = form.altnr.value; if (product_id) { this.cart.add_item(product_id, 1); } } ); } ); document.querySelectorAll('.toggle_content').forEach( (toggleElement) => { toggleElement.addEventListener('click', function() { const targetSelector = toggleElement.getAttribute('data-target'); const targetElement = document.querySelector(targetSelector); if (targetElement) { targetElement.classList.toggle('hide'); } }); } ); const faqContainer = document.querySelector('.faq'); if (faqContainer) { const faqItems = faqContainer.querySelectorAll('ul li.accordion__item'); const faqData = []; faqItems.forEach( (item, index) => { const question = item.querySelector('.accordion__item--btn').textContent.trim(); const answer = item.querySelector('ul').textContent.trim(); faqData.push({ '@type': 'Question', name: question, acceptedAnswer: { '@type': 'Answer', text: answer } }); } ); // Create JSON-LD script element for schema markup const script = document.createElement('script'); script.type = 'application/ld+json'; script.innerHTML = ` { "@context": "https://schema.org", "@type": "FAQPage", "mainEntity": ${JSON.stringify(faqData)} } `; // Append the script element to the head of the document document.head.appendChild(script); } window.liveEvent('#air-cart-module .close', 'click', (event, element) => { document.querySelector('.backdrop').classList.remove('active'); document.querySelector('#air-cart-module').classList.remove('active'); if (document.querySelector('#air-cart-module').classList.contains('error')) { document.querySelector('#air-cart-module').classList.remove('error'); } document.body.classList.remove('cart-open'); document.body.style.overflow = ''; } ); window.liveEvent('.backdrop', 'click', (event, element) => { if (document.querySelector('.backdrop').classList.contains('active')) { document.querySelector('.backdrop').classList.remove('active'); document.querySelector('#air-cart-module').classList.remove('active'); var sizeandfitcontainer = document.querySelector('#sizeandfit'); if (sizeandfitcontainer) { sizeandfitcontainer.classList.remove('active'); window.sizeNFitInitialized = false; } document.querySelector('#kundradgivning').classList.remove('active'); document.querySelector('#styleadvisor').classList.remove('active'); document.querySelector('#modal_area').classList.remove('active'); if (document.querySelector('#air-cart-module').classList.contains('error')) { document.querySelector('#air-cart-module').classList.remove('error'); } document.body.classList.remove('cart-open', 'sizeandfit-open', 'styleadvisor', 'kundradgivning'); document.body.style.overflow = ''; } } ); window.liveEvent('.navigate', 'click', async (event, element) => { if (element.href) { this.hash = window.location.hash; this.element = element; let listLoading = false; var listSpinner = document.querySelector('.listspinner'); event.preventDefault(); listLoading = true; if ((listLoading = true)) { // Set a timeout to show the spinner after 100ms var listTimeout = setTimeout(function() { listSpinner.style.display = 'block'; }, 100); } await this.navigatePage(element.href, 'list'); clearTimeout(listTimeout); listSpinner.style.display = 'none'; listLoading = false; if (element.closest('.has__children')) { element.closest('.has__children').classList.add('reload'); } } } ); window.liveEvent('.productpage-back', 'click', (event, element) => { history.back(); } ); window.onpopstate = (event) => { if (this.productLoaded) { this.hideProduct(); if (document.querySelector('.backdrop').classList.contains('active')) { document.querySelector('.backdrop').classList.remove('active'); document.querySelector('#air-cart-module').classList.remove('active'); if (document.querySelector('#air-cart-module').classList.contains('error')) { document.querySelector('#air-cart-module').classList.remove('error'); } document.body.classList.remove('cart-open'); document.body.style.overflow = ''; } } else { if (event.state && event.state.ajax_nav) { window.location = location.href; } } } ; } showTooltip(elementWrapper, tooltip) { elementWrapper.onmousemove = function(e) { var x = e.clientX , y = e.clientY; tooltip.style.top = y + 15 + 'px'; if (tooltip.classList.contains('position-right')) { tooltip.style.left = x - 120 + 'px'; } else { tooltip.style.left = x + 15 + 'px'; } if (/Android|webOS|iPhone|iPad|iPod|BlackBerry/i.test(navigator.userAgent)) { tooltip.classList.add('active'); setTimeout( () => { tooltip.classList.remove('active'); } , 3000); } else { tooltip.classList.add('active'); } } ; elementWrapper.onmouseout = function(e) { tooltip.classList.remove('active'); } ; } fromList(element) { let requestType = ''; if (this.productLoaded) return true; if (window.shop_settings) { requestType = window.shop_settings['request_type']; } if (requestType === 'product') { return false; } else if (requestType === 'product_group' || requestType === 'brand' || requestType === 'brand_in_group' || requestType === 'search') { return true; } else { // check for sliders if (element.parentNode.parentNode.classList.contains('snapping') || element.parentNode.parentNode.parentNode.classList.contains('product--list')) { return true; } else { return false; } } } setup() { this.mainContainer = document.getElementsByClassName('main')[0]; this.productContainer = document.createElement('main'); this.productContainer.id = 'main-second'; this.mainContainer.after(this.productContainer); this.isSetup = true; } async getProduct(url, element) { // Get the spinner element var spinner = element.querySelector('.spinner'); // Make sure the spinner element exists if (!spinner) { // If the spinner element does not exist, create a new element spinner = document.createElement('div'); spinner.classList.add('spinner'); // Append the spinner element to the clicked element element.appendChild(spinner); } // Set a timeout to show the spinner after 100ms var timeout = setTimeout(function() { spinner.style.display = 'block'; }, 100); if (!this.isSetup) this.setup(); if (this.productLoading) return; if (!this.offset) { this.offset = window.pageYOffset; } this.productLoading = true; let separator = url.includes('?') ? '&' : '?'; let productUrl = url + separator + 'sw=1'; const response = await fetch(productUrl); const html = await response.text(); this.saveMeta(); if (window.shop_settings) { this.fromReqestType = window.shop_settings['request_type']; } this.showProduct(html); this.showProductBack(); if (this.productLoaded) { clearTimeout(timeout); spinner.style.display = 'none'; window.history.replaceState({}, null, url); } else { window.history.pushState({ ajax_nav: true }, null, url); } clearTimeout(timeout); spinner.style.display = 'none'; this.productLoading = false; this.productLoaded = true; window.dispatchEvent(new CustomEvent("pdp_ajax_loaded")) setTimeout( () => { sessionStorage.setItem('snf_artnr', document.querySelector('.product-id-info').textContent); } , 500); const sizeAndFit = document.getElementById('sizeandfit'); if (sizeAndFit) { const backdropBlur = document.querySelector('.backdrop'); const sizeNFit = document.getElementById('sizeandfit'); const sizeNFitStep = sessionStorage.getItem('snf_step'); document.querySelectorAll('.sizeAndFitTrigger').forEach(element => { element.addEventListener('click', () => { const productPage = document.querySelector('.single-product'); const sizeAndFit = document.getElementById('sizeandfit'); document.body.classList.add("sizeandfit-open"); if (productPage) { const images = document.querySelectorAll('.productImg--wrapper img'); const productArtNr = document.querySelector('.product-id-info'); sizeAndFit.classList.add('from-pdp'); const imageSource = images[0].getAttribute('src'); sessionStorage.setItem('snf_image', imageSource); sessionStorage.setItem('snf_artnr', productArtNr.textContent); } backdropBlur.classList.add('active'); sizeNFit.classList.add('active'); this.activeStep(); if (sizeNFitStep > '1') { this.snfBackBtn(); } } ); } ); } } showProductBack() { this.productContainer.querySelectorAll('.productpage-back').forEach(function(elem) { elem.classList.remove('hidden'); }); } async navigatePage(url, type) { if (!url) return; if (!this.isSetup) this.setup(); let separator = url.includes('?') ? '&' : '?'; let pageURL = url + separator + 'sw=1'; const response = await fetch(pageURL); const html = await response.text(); if (this.productLoaded) { this.hideProduct(); } this.navMenu.hideMainNav(this.navMenu); this.mainContainer.innerHTML = html; window.history.pushState({ ajax_nav: true }, null, url); (0, _scripts_utils_js__WEBPACK_IMPORTED_MODULE_1__.executeJs)(this.mainContainer); if (type === 'product') { this.productPage.reinit(); this.mainContainer.querySelectorAll('.productpage-back').forEach(function(elem) { elem.classList.remove('hidden'); }); window.dispatchEvent(new CustomEvent("pdp_ajax_loaded")); setTimeout( () => { sessionStorage.setItem('snf_artnr', document.querySelector('.product-id-info').textContent); } , 500); } else if (type === 'list') { if (this.element && this.element.classList.contains('page__category--item')) { if (this.hash) { window.location.hash = this.hash; } } window.dispatchEvent(new CustomEvent("plp_ajax_loaded")); initializePage(); this.filter.reinit(); } this.initJs(document); this.ajax_ga_pageview(); this.atm_pixels_after(); document.querySelectorAll('.tooltip-span').forEach( (tooltip) => { const parent = tooltip.parentNode; this.showTooltip(parent, tooltip); } ); //if (type === "list") { // Create and dispatch the custom event // window.dispatchEvent(new CustomEvent("plp_ajax_loaded")) //} setTimeout( () => { window.scrollTo(0, 0); } , 10); } showProduct(html) { this.productContainer.innerHTML = html; this.productContainer.style.display = 'block'; this.mainContainer.style.display = 'none'; window.scrollTo(0, 0); (0, _scripts_utils_js__WEBPACK_IMPORTED_MODULE_1__.executeJs)(this.productContainer); this.productPage.reinit(); this.initJs(this.productContainer); this.ajax_ga_pageview(); this.atm_pixels_after(); document.querySelector('#header').classList.remove('header__notScrolled'); } hideProduct() { if ('scrollRestoration'in history) { history.scrollRestoration = 'manual'; } this.mainContainer.style.display = 'block'; this.productContainer.style.display = 'none'; this.productContainer.innerHTML = ''; this.productLoaded = false; this.resetMeta(); setTimeout( () => { window.scrollTo(0, this.offset); this.offset = 0; } , 10); } saveMeta() { const titleElem = document.getElementsByTagName('title')[0]; const relElem = document.querySelector("link[rel='canonical']"); if (!titleElem.dataset.reset) { titleElem.dataset.reset = document.title; } if (relElem && !relElem.dataset.reset) { relElem.dataset.reset = relElem.href; } } resetMeta() { const titleElem = document.getElementsByTagName('title')[0]; const relElem = document.querySelector("link[rel='canonical']"); if (window.shop_settings) { window.shop_settings['request_type'] = this.fromReqestType; } if (titleElem.dataset.reset) { document.title = titleElem.dataset.reset; titleElem.dataset.reset = ''; } if (relElem && relElem.dataset.reset) { relElem.href = relElem.dataset.reset; relElem.dataset.reset = ''; } } initJs(container) { container.querySelectorAll('.snapping--wrapper').forEach(function(elem) { new _views_product_simple_slider__WEBPACK_IMPORTED_MODULE_0__["default"](elem); }); window.lazyLoadInstance.update(); /* Produkt grid bredd toggle - mobil */ let tabLink = document.querySelectorAll('.tab-link'); let videoWrapper = document.querySelector('.video'); let videoElem = document.querySelector('video'); // Init videos if needed. container.querySelectorAll('video, .videoInfoWrapper').forEach(function(elem) { elem.addEventListener('click', function() { if (videoElem.paused) { videoElem.play(); } else { videoElem.pause(); } videoWrapper.classList.toggle('playing'); videoWrapper.classList.add('started'); }); }); } ajax_ga_pageview() { if (typeof ga !== 'undefined') { setTimeout( () => { const page = window.location.pathname + window.location.search; ga('set', 'page', page); ga('send', 'pageview'); } , 1); } } atm_pixels_after() { if (typeof atm_pixels_after_function !== 'undefined' && typeof atm_pixels_after_function === 'function') { atm_pixels_after_function(); } } } /***/ } ), /***/ "./content/default/views/product/bundle_product.js": /*!*********************************************************!*\ !*** ./content/default/views/product/bundle_product.js ***! \*********************************************************/ /***/ ( (__unused_webpack_module, __webpack_exports__, __webpack_require__) => { "use strict"; __webpack_require__.r(__webpack_exports__); /* harmony export */ __webpack_require__.d(__webpack_exports__, { /* harmony export */ "default": () => (/* binding */ BundleProduct)/* harmony export */ }); /* harmony import */ var _scripts_utils_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../../scripts/utils.js */ "./content/default/scripts/utils.js"); class BundleProduct { constructor(bundleData, buyButton) { this.bundleData = bundleData; this.fields = document.getElementsByClassName('buybox__bundles--items'); this.fieldItems = document.getElementsByClassName('buybox__bundles--item'); this.buyButton = buyButton; this.init(); } init() { this.initEvents(); } initEvents() { // if bundle fields are selects. // for (const f of this.fields) { // f.addEventListener('change', () => this.updateField()); // } for (const f of this.fieldItems) { f.addEventListener('click', (e) => this.updateFieldEvent(e)); } } updateFieldEvent(e) { let button = e.target; const field = button.parentNode; this.buyButton.classList.remove('alert-disabled'); const alert = document.getElementById('alert-popup'); if (alert) { alert.remove(); } for (const c of field.children) { if (c == button) { c.classList.add('active'); field.dataset.value = c.dataset.value; } else { c.classList.remove('active'); } } this.updateField(); } updateField() { this.updateFields(); } updateFields() { let ids = []; for (const field of this.fields) { ids.push(field.dataset.value); } let price = 0; let priceRegular = 0; let campaign = false; for (const [index,field] of this.bundleData.entries()) { ids.sort(); field.items.sort(); for (const item of field.items) { if (ids[index] == item.id) { if (!item.price) { return; } if (item.campaign) { campaign = true; priceRegular += Number(item.price_regular); } else { priceRegular += Number(item.price); } price += Number(item.price); } } } const elems = document.getElementsByClassName('price-info'); for (var elem of elems) { elem.innerHTML = (0, _scripts_utils_js__WEBPACK_IMPORTED_MODULE_0__.formatPriceHtml)(price, priceRegular, campaign); } } } /***/ } ), /***/ "./content/default/views/product/filter.js": /*!*************************************************!*\ !*** ./content/default/views/product/filter.js ***! \*************************************************/ /***/ ( (__unused_webpack_module, __webpack_exports__, __webpack_require__) => { "use strict"; __webpack_require__.r(__webpack_exports__); /* harmony export */ __webpack_require__.d(__webpack_exports__, { /* harmony export */ "default": () => (/* binding */ Filter)/* harmony export */ }); /* harmony import */ var _scripts_utils_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../../scripts/utils.js */ "./content/default/scripts/utils.js"); class Filter { constructor() { this.init(); } reinit() { this.init(); document.dispatchEvent(new Event("after_filter")); } init() { if (document.getElementsByClassName('page__filter').length == 0) return; if (window.location.hash) this.setFilterFromHash(); let main = document.querySelector("main") let grid = document.querySelector(".product--group") let gridToggles = document.querySelectorAll(".grid-icon") if (screen.width < 768 && (0, _scripts_utils_js__WEBPACK_IMPORTED_MODULE_0__.getStorage)('air_view_' + filterSettings.get('id')) == 'single') { main.classList.add("single") grid.classList.add("single") gridToggles.forEach( (element) => { if (element.classList.contains('single')) { element.classList.add("active") } else { element.classList.remove("active") } } ) } gridToggles.forEach( (element) => { element.addEventListener("click", function() { gridToggles.forEach(function(item) { item.classList.remove("active") }) element.classList.add("active") if (element.classList.contains("single")) { main.classList.add("single") grid.classList.add("single"); (0, _scripts_utils_js__WEBPACK_IMPORTED_MODULE_0__.setStorage)('air_view_' + filterSettings.get('id'), 'single'); } else { main.classList.remove("single") grid.classList.remove("single"); (0, _scripts_utils_js__WEBPACK_IMPORTED_MODULE_0__.removeStorage)('air_view_' + filterSettings.get('id')); } }) } ) document.querySelectorAll(".filter_link").forEach( (element) => { element.addEventListener("click", () => { this.clearFilter(); const ids = element.dataset.id.split(','); const values = element.dataset.value.toLowerCase().split(','); ids.forEach( (id) => { document.querySelectorAll(".filter__container").forEach( (w) => { if (w.dataset.id == id) { w.querySelectorAll(".filter__container--items").forEach( (input) => { if (values.includes(input.dataset.filter.toLowerCase())) { input.click(); } } ); } } ); } ); } ); } ); this.moreButton = document.getElementById('filter_more'); this.sortSelect = document.getElementById("sort-order"); document.querySelectorAll('.filter__title').forEach(filter => { filter.addEventListener('click', function(event) { var active_filter = document.querySelector('.filter.--active'); if (active_filter) { if (active_filter != filter.parentNode) { active_filter.classList.remove("--active"); } } filter.parentNode.classList.toggle('--active'); }) } ); document.querySelectorAll('.ul-li-list span').forEach(element => { element.addEventListener('click', event => element.parentNode.classList.toggle('--active')); } ); document.querySelectorAll('.btn--filter, .page--settings--head').forEach(button => { button.addEventListener('click', function(event) { document.querySelectorAll(".page--settings--wrapper, departments--settings--wrapper").forEach( (element) => { element.classList.toggle("--active") document.querySelector(".backdrop").classList.toggle("filter-open") } ) }); } ); document.querySelectorAll('.filter__container--items').forEach(element => { element.addEventListener('click', event => this.handleEvent(element, event)); } ); this.paginationEvents(); document.querySelectorAll('.filter_clear').forEach(element => { element.addEventListener('click', event => { this.clearFilter(); this.get() } ); } ); if (this.moreButton) this.moreButton.addEventListener('click', event => { if (!this.load) { this.load = true; this.get(filterSettings.get('current_offset') ? filterSettings.get('current_offset') : filterSettings.get('page_size'), 1); this.infinit_scroll(); history.scrollRestoration = "manual"; } ; } ); if (this.sortSelect) this.sortSelect.addEventListener('change', event => { this.get(); let[sort,order] = this.sortSelect ? this.sortSelect.value.split('-') : ["", ""]; this.setState({ "sort": sort, "order": order, "page": '', }); } ); document.querySelectorAll('#sort-order-ul li').forEach(element => { element.addEventListener('click', event => { document.querySelectorAll('#sort-order-ul li').forEach(sort_li => { sort_li.classList.remove("--active"); } ); document.querySelectorAll('.active_sort_label').forEach(label => { label.innerHTML = element.innerHTML; } ); element.classList.add("--active"); element.parentNode.parentNode.classList.remove('--active'); this.get(); let[sort,order] = element.dataset.value.split('-'); this.setState({ "sort": sort, "order": order, "page": '' }); document.dispatchEvent(new CustomEvent("sort_changed",{ 'detail': { 'sort': sort, 'order': order } })); } ); } ); document.querySelectorAll('.brand_filter_input').forEach(element => { element.addEventListener('keyup', event => { this.filter_brands(element.value); } ); } ); window.liveEvent("body", "click", (event, element) => { document.querySelectorAll('.filter.--active').forEach(active_filter => { if (!active_filter.contains(event.target)) { active_filter.classList.remove("--active"); } } ); document.querySelectorAll('.filter.--active, .ul-li-list.--active').forEach(active_filter => { if (!active_filter.contains(event.target)) { active_filter.classList.remove("--active"); } } ); } ); document.addEventListener('refresh_filter', () => { this.get(); } ); } handleEvent(element, event) { event.preventDefault(); if (element.classList.contains('--disabled')) return; element.classList.toggle('--active'); this.get(); /* Scroll to filter on filterselect */ const ScrollToFilter = document.getElementById('FilterAnchor'); const headerHeight = document.getElementById('header').offsetHeight window.scrollTo({ top: ScrollToFilter.offsetTop - headerHeight, left: 0, behavior: 'smooth' }); } updateFilterCount() { /* Filter choice counter*/ let filters = document.querySelectorAll(".page__filter .filter") filters.forEach( (filter) => { let activeFilter = filter.querySelectorAll(".filter__container--items.--active") if (activeFilter.length > 0) { filter.querySelector(".active_nbr").innerHTML = "(" + activeFilter.length + ")" } else { filter.querySelector(".active_nbr").innerHTML = '' } } ) } async get(offset, append) { this.updateFilterCount(); const data = new URLSearchParams(); let filterParams = ""; offset = offset ? offset : 0; const selectedFilters = this.getSelectedFilters(); this.setSelectedFilterBoxes(selectedFilters); Object.keys(selectedFilters).forEach(id => { if (filterParams) filterParams += ";"; filterParams += id + ":"; let values = ""; selectedFilters[id].forEach(value => { if (values) values += ","; values += value; } ); filterParams += values; } ); const json_filter = JSON.stringify(selectedFilters); if (window.location.hash || json_filter !== "{}") { window.location.hash = json_filter } let[sort,order] = this.sortSelect ? this.sortSelect.value.split('-') : ["", ""]; let sort_ul = document.querySelectorAll('#sort-order-ul li.--active')[0]; [sort,order] = sort_ul ? sort_ul.dataset.value.split('-') : ["", ""]; data.append('funk', 'get_filter'); filterSettings.get('request_type') === 'search' ? data.append('q', filterSettings.get('q')) : data.append('id', filterSettings.get('id')); data.append('type', filterSettings.get('request_type')); data.append('filter_params', json_filter); data.append('json', 1); data.append('sort', sort); data.append('order', order); data.append('offset', offset ? offset : 0); const response = await fetch('/shop', { method: 'POST', body: data }); const result = await response.json(); if (result.request_data) { let container = document.querySelector(".row.product--group"); if (!container) return; if (result.request_data.filters) this.setInactive(result.request_data.filters); if (append) { container.insertAdjacentHTML("beforeend", result.request_data.html); } else { container.innerHTML = result.request_data.html; } if (this.moreButton) { if (offset + result.request_data.count >= result.request_data.total_count) { console.log() this.moreButton.style.display = 'none'; this.moreButton.classList.remove('infinite'); } else { this.moreButton.style.display = ''; let currentUrl = window.location.pathname if (typeof ga !== 'undefined') { ga("set", "page", currentUrl + "#" + offset + result.request_data.count) ga("send", "pageview") } } } document.querySelectorAll('.filter_count_showing').forEach(element => { element.innerHTML = offset + result.request_data.count; } ); document.querySelectorAll('.filter_count_total').forEach(element => { element.innerHTML = result.request_data.total_count; } ); window.lazyLoadInstance.update(); filterSettings.set('total_count', result.request_data.total_count); filterSettings.set('current_offset', offset + result.request_data.count); if (!offset) { this.setState({ "page": '' }); this.updatePagination(1); } document.dispatchEvent(new Event("after_filter")); if (this.moreButton) this.moreButton.classList.remove('loading'); this.load = false; } } getSelectedFilters() { let selectedFilters = {}; document.querySelectorAll('.filter__container').forEach(filter_type => { filter_type.querySelectorAll('.filter__container--items.--active').forEach(option => { if (!selectedFilters[filter_type.dataset.id]) { selectedFilters[filter_type.dataset.id] = []; } selectedFilters[filter_type.dataset.id].push(option.dataset.value); } ); } ); return selectedFilters; } clearFilter() { document.querySelectorAll('.filter__container .--active').forEach(item => { item.classList.remove('--active'); } ); } setSelectedFilterBoxes(selectedFilters) { let selectedFilterBoxes = ""; const parent = document.getElementById('selected_filters'); if (!parent) return; Object.keys(selectedFilters).forEach(id => { selectedFilters[id].forEach(value => { selectedFilterBoxes += '' + value + ''; } ); } ); parent.innerHTML = selectedFilterBoxes; document.querySelectorAll('.selected_filter').forEach(element => { element.addEventListener('click', event => { this.toggleFilterValue(element.getAttribute('data-id'), element.getAttribute('data-value')); this.get(); } ); } ); document.querySelectorAll('.filter_clear').forEach(element => { selectedFilterBoxes ? element.classList.remove("hide") : element.classList.add("hide"); selectedFilterBoxes ? element.parentNode.classList.remove("hide") : element.parentNode.classList.add("hide") } ); } setInactive(filters) { filters.forEach(filter => { if (filter.type === "Tree") { this.setInactiveTree(filter.id, filter.values); } else if (filter.type === "Slider_Range") { this.setInactiveSlider(filter.id, filter.values); } else { this.setInactiveList(filter); } } ); } setInactiveList(filter) { let id = filter.id; let values = filter.values; let type = filter.type; if (type === 'range') return; let enabled_options = {}; values.forEach(value => { enabled_options[value.value] = 1; } ); document.querySelectorAll('.filter__container[data-id=' + id + '] .filter__container--items').forEach(option => { enabled_options[option.dataset.value] ? option.classList.remove("--disabled") : option.classList.add("--disabled"); } ); } toggleFilterValue(id, value) { const element = document.querySelector('.filter__container[data-id="' + id + '"] .filter__container--items[data-value="' + value + '"]'); if (element) element.classList.toggle('--active') } setFilterFromHash() { const selectedFilters = JSON.parse(decodeURI(window.location.hash.slice(1))); Object.keys(selectedFilters).forEach(id => { selectedFilters[id].forEach(value => { this.toggleFilterValue(id, value); } ); } ); if (Object.keys(selectedFilters).length) this.get(); } setState(inParams) { const params = new URLSearchParams(window.location.search); Object.keys(inParams).forEach(name => { inParams[name] ? params.set(name, inParams[name]) : params.delete(name); } ); let newUrl = window.location.pathname; let search = params.toString(); if (search) { newUrl += "?" + params.toString(); } if (window.location.hash && window.location.hash !== "#{}") { newUrl += window.location.hash } ;window.history.replaceState(null, "", decodeURIComponent(newUrl)); if (typeof ga !== 'undefined') { ga('set', 'page', newUrl) ga('send', 'pageview') } } paginationEvents() { document.querySelectorAll('.pagination-page:not(--dots)').forEach(element => { element.addEventListener('click', event => { this.get((parseInt(element.textContent) - 1) * filterSettings.get('page_size')) this.setState({ "page": element.textContent }); this.updatePagination(parseInt(element.textContent)); window.scrollTo({ top: 0, behavior: "smooth" }); } ); } ); } updatePagination(active_page) { let number_of_pages = Math.ceil(filterSettings.get('total_count') / filterSettings.get('page_size')); if (active_page > number_of_pages) { active_page = number_of_pages; } let pagination = active_page == 1 ? '1' : '1'; if (active_page - 2 > 2) { pagination += '...'; } let number = active_page - 2 > 2 ? active_page - 2 : 2; let page_count = 1; let loops = active_page < 4 ? 4 : 5; while (number > 1 && number < number_of_pages && page_count <= loops) { if (number >= number_of_pages) break; pagination += active_page == number ? '' + number + '' : '' + number + ''; page_count += 1; number += 1; } if (active_page + 3 < number_of_pages) { pagination += '...'; } if (number_of_pages > 1) { pagination += active_page == number_of_pages ? '' + number_of_pages + '' : '' + number_of_pages + ''; } document.querySelectorAll('.page_navigation').forEach(element => { element.innerHTML = pagination; } ); this.paginationEvents(); } filter_brands(value) { if (!value) { document.querySelectorAll('.filter__container[data-id=brand] .filter__item').forEach(element => { element.classList.remove("--hidden"); } ); } else { document.querySelectorAll('.filter__container[data-id=brand] .filter__item').forEach(element => { element.classList.add("--hidden"); } ); document.querySelectorAll('.filter__container[data-id=brand] .filter__item[data-filter*="' + value.toLowerCase() + '"]').forEach(element => { element.classList.remove("--hidden"); } ); } } infinit_scroll() { if (this.moreButton.classList.contains('infinite')) { let count = parseInt(this.moreButton.dataset.count); count == 3 ? this.moreButton.classList.remove("infinite") : this.moreButton.setAttribute("data-count", count + 1); } else { this.moreButton.classList.add('infinite'); this.moreButton.setAttribute('data-count', 1); if (!this.moreButton.classList.contains('infinite_initiated')) { const btn = this.moreButton; window.onscroll = function() { if (btn) { const to_top = btn.offsetTop - window.scrollY; if (to_top <= 2000) { if (!btn.classList.contains('loading') && btn.classList.contains('infinite')) { btn.click(); btn.classList.add('loading'); } } } } ; this.moreButton.classList.add('infinite_initiated'); } } } } /***/ } ), /***/ "./content/default/views/product/product_page.js": /*!*******************************************************!*\ !*** ./content/default/views/product/product_page.js ***! \*******************************************************/ /***/ ( (__unused_webpack_module, __webpack_exports__, __webpack_require__) => { "use strict"; __webpack_require__.r(__webpack_exports__); /* harmony export */ __webpack_require__.d(__webpack_exports__, { /* harmony export */ "default": () => (/* binding */ ProductPage)/* harmony export */ }); /* harmony import */ var _variation_variation__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./variation/variation */ "./content/default/views/product/variation/variation.js"); /* harmony import */ var _bundle_product__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./bundle_product */ "./content/default/views/product/bundle_product.js"); /* harmony import */ var _zoom__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./zoom */ "./content/default/views/product/zoom.js"); /* harmony import */ var _zoom__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/ __webpack_require__.n(_zoom__WEBPACK_IMPORTED_MODULE_2__); class ProductPage { constructor(cart, buy_button_id="air-buy", qty_input_id="air-qty") { this.cart = cart this.buy_button_id = buy_button_id this.qty_input_id = qty_input_id this.alert_popup = undefined this.closeAlert = undefined if (window.shop_settings.request_type == "product") { this.init() } } reinit() { if (typeof (lipscore) !== "undefined") { lipscore.initWidgets() } this.init() document.dispatchEvent(new CustomEvent("product_cell_update")) } init(status) { this.buy_button = document.getElementById(this.buy_button_id) this.qty_input = document.getElementById(this.qty_input_id) document.dispatchEvent(new CustomEvent("product_page_viewed")) document.dispatchEvent(new CustomEvent("product_page_styleview")) if (window.variants) { this.variations = new _variation_variation__WEBPACK_IMPORTED_MODULE_0__["default"](window.variants,this.buy_button) } else if (window.bundle_fields) { this.bundle = new _bundle_product__WEBPACK_IMPORTED_MODULE_1__["default"](window.bundle_fields,this.buy_button) } if (this.buy_button) { this.buy_button.addEventListener("click", (e) => { this.add_cart(e, this.buy_button) } ) } // init simple buy buttons. const btns = document.getElementsByClassName("buy-btn") for (const btn of btns) { btn.addEventListener("click", (e) => this.add_cart(e, btn)) } this.initLipscore() this.tabProps = document.getElementById("tab-properties") if (this.tabProps) { this.tabProps.parentNode.addEventListener("click", () => { this.initTabProps() } ) } /* ScrollTo more info about size */ const readMoreSize = document.querySelector(".trueSizeLink") const readMoreScrollTo = document.querySelector(".about--list") if (readMoreSize) { readMoreSize.onclick = function() { scrollToMore() } } function scrollToMore() { window.scrollTo({ top: readMoreScrollTo.offsetTop, left: 0, behavior: "smooth", }) } /* ScrollTo more info about size */ const readMoreReview = document.querySelector(".buybox__rating") const readReviewScrollTo = document.querySelector("#reviewsAccordion") const triggerReview = document.querySelector("#reviewsAccordion > span") if (readMoreReview) { readMoreReview.onclick = function() { scrollToReview() } } function scrollToReview() { window.scrollTo({ top: readReviewScrollTo.offsetTop, left: 0, behavior: "smooth", }) if (readReviewScrollTo.classList.contains("active")) {} else { triggerReview.click() } } if (!this.zoomInit) { this.initZoom() } this.initTooltip() // Handle add to cart for old gift card page. this.handleGiftcards() } add_cart(e, elem) { e.stopPropagation() if (elem.classList.contains("alertable")) { this.show_alert_popup() return } const product_id = elem.dataset.id const qty = this.qty_input.value || 1 let extra_data = {} if (elem.dataset.type === "bundle") { const fields = this.bundle.fields let fields_data = [] for (const f of fields) { fields_data.push({ field_id: f.dataset.id, bundle_id: f.dataset.value }) } extra_data["bundle_fields"] = fields_data } elem.dispatchEvent(new CustomEvent("addToCart")) if (!product_id) { return } this.cart.add_item(product_id, qty, extra_data) } async show_alert_popup() { if (this.buy_button.classList.contains("disabled") || this.buy_button.classList.contains("alert-disabled")) { return } /* hide bevaka */ const product_id = this.buy_button.dataset.id const stock_id = this.buy_button.dataset.stock_id const response = await fetch("/shop?funk=get_alert_popup&product_id=" + product_id + "&stock_id=" + stock_id) const result = await response.json() if (result.status == 200) { const data = result.data let newsletter_html = "" if (data.newsletter) { newsletter_html = `
    ${data.newsletter_phrase}
    ` } let html = `
    ${data.heading}
    ${data.phrase}
    ${newsletter_html}
    ` if (!this.alert_popup) { this.alert_popup = document.createElement("div") this.buy_button.after(this.alert_popup) } this.alert_popup.innerHTML = html const closeAlert = document.getElementById("close-alert") const alerPopup = document.getElementById("alert-popup") if (closeAlert) { closeAlert.addEventListener("click", function() { alerPopup.parentNode.removeChild(alerPopup) }) } document.getElementById("alert-save").addEventListener("click", (e) => { this.save_alert() } ) } } async save_alert() { this.buy_button.classList.add("alert-disabled") const product_id = this.buy_button.dataset.id const email = document.getElementById("alert-email").value const newsletter = document.getElementById("alert-newsletter").checked if (product_id && email) { const data = new URLSearchParams() data.append("funk", "save_alert") data.append("product_id", product_id) data.append("email", email) data.append("newsletter", newsletter) const response = await fetch("/shop", { method: "POST", body: data, }) const result = await response.json() if (result.status == 200) { this.alert_popup.remove() if (result.data.phrase) { const btnLabel = this.buy_button.getElementsByClassName("air-buy-label")[0] btnLabel.innerHTML = result.data.phrase } } } } initLipscore() { setTimeout(function() { const lipscoreWrapper = document.getElementById("lipscore-review-list") if (lipscoreWrapper && lipscoreWrapper.dataset["lsProductVotes"] == 0) { document.getElementById("lipscore-review-list").parentNode.parentNode.remove() } }, 400) } async initTabProps() { if (this.tabPropsLoaded) return this.tabPropsLoaded = true const response = await fetch("/cgi-bin/ibutik/API.fcgi?funk=get_tab_properties&artnr=" + window.product_id) const html = await response.text() this.tabProps.innerHTML = html } handleGiftcards() { const digital = document.getElementById("AIR_ibutik_laggtill_d") const irlGiftcard = document.getElementById("AIR_ibutik_laggtill_f") if (digital) { const digitalBtn = digital.querySelector("a") digitalBtn.addEventListener("click", (e) => { this.addToCartGiftcard(e, digital) } ) } if (irlGiftcard) { const irlGiftcardBtn = irlGiftcard.querySelector("a") irlGiftcardBtn.addEventListener("click", (e) => { this.addToCartGiftcard(e, irlGiftcard) } ) } } async addToCartGiftcard(e, form) { e.preventDefault() const response = await fetch("/shop", { method: "POST", body: new FormData(form), }) this.cart.show("add", { order: "update_time" }) } initZoom() { this.zoomInit = true this.zoomActive = false this.changeEvent = (e) => { let tooltipSpan = document.querySelector(".snapping--wrapper .tooltip-span") if (this.zoomActive) { tooltipSpan.classList.remove("notActive") this.removeZoom(e, this) } else { this.showZoom(e, this) tooltipSpan.classList.add("notActive") } } this.removeEvent = (e) => { this.removeZoom(e, this) } this.hoverEvent = (e) => { this.showZoomHover(e, this) } this.hoverRemoveEvent = (e) => { this.hideZoomHover(e, this) } this.imgWrapper = document.querySelector(".single--product__img") this.imgWrapper.addEventListener("mouseover", this.hoverEvent) this.imgWrapper.addEventListener("mouseout", this.hoverRemoveEvent) document.addEventListener("slider_clicked", this.changeEvent) document.addEventListener("slider_changed", this.removeEvent) } showZoomHover(e, _self) { // Preload superzoom on hover. if (!e.target.parentNode.classList.contains("superzoom-loaded")) { e.target.parentNode.classList.add("superzoom-loaded") if (e.target.parentNode.dataset.superzoom) { let img = document.createElement("img") img.src = e.target.parentNode.dataset.superzoom } } } initTooltip() { // let tooltipSpan = document.getElementById("tooltip-span") // let tooltipColor = document.getElementsByClassName("tooltip-color") // const imageWrapper = // document.querySelector(".snapping--wrapper") // const colorWrapper = document.querySelector(".row.variusColors") // let imageWrapper = document.querySelector('.single--product__img').parentNode; // this.showTooltip(imageWrapper, tooltipSpan) document.querySelectorAll(".tooltip-span").forEach( (tooltip) => { const parent = tooltip.parentNode this.showTooltip(parent, tooltip) } ) } hideZoomHover(e, _self) {} showZoom(e, _self) { // if (e.pointerType !== 'mouse') return; _self.zoomActive = true _self.zooms = [] _self.imgWrapper.removeEventListener("mouseover", _self.hoverEvent) let zoomWrapper = document.getElementById("zoomWrapper") let productDesc = document.querySelector(".productDesc") const width = productDesc.offsetWidth - 10 document.querySelectorAll(".productImg--wrapper img").forEach( (img) => { const element = img.parentNode let image = img.src if (element.dataset.superzoom) { image = element.dataset.superzoom } _self.zooms.push(new (_zoom__WEBPACK_IMPORTED_MODULE_2___default())(element,{ zoomContainer: zoomWrapper, zoomWidth: width, zoomImage: image, })) } ) if (e.detail) { const evt = e.detail.evt if (evt) { setTimeout(function() { let wrapper = evt.target.parentNode wrapper.dispatchEvent(new MouseEvent("mousemove",{ clientX: evt.clientX, clientY: evt.clientY, })) }, 10) } } } removeZoom(e, _self) { if (!_self.zoomActive) return _self.zoomActive = false let element = _self.imgWrapper _self.zooms.forEach( (zoom) => { zoom.kill() } ) element.removeEventListener("click", _self.removeEvent) element.addEventListener("click", _self.showEvent) _self.imgWrapper.addEventListener("mouseover", _self.hoverEvent) } showTooltip(elementWrapper, tooltip) { elementWrapper.onmousemove = function(e) { var x = e.clientX , y = e.clientY tooltip.style.top = y + 15 + "px" tooltip.style.left = x + 15 + "px" tooltip.classList.add("active") } elementWrapper.onmouseout = function(e) { tooltip.classList.remove("active") } } } /***/ } ), /***/ "./content/default/views/product/simple_slider.js": /*!********************************************************!*\ !*** ./content/default/views/product/simple_slider.js ***! \********************************************************/ /***/ ( (__unused_webpack_module, __webpack_exports__, __webpack_require__) => { "use strict"; __webpack_require__.r(__webpack_exports__); /* harmony export */ __webpack_require__.d(__webpack_exports__, { /* harmony export */ "default": () => (/* binding */ SimpleSlider)/* harmony export */ }); class SimpleSlider { constructor(slider) { this.slider = slider; this.slidesWrapper = slider.querySelector('.snapping'); this.slides = this.slidesWrapper.children; const parent = this.slider.parentElement; this.prev = slider.querySelector('.nav-prev'); this.next = slider.querySelector('.nav-next'); if (!this.prev) { if (parent.querySelector('.nav-prev')) { this.prev = parent.querySelector('.nav-prev'); } } if (!this.next) { if (parent.querySelector('.nav-next')) { this.next = parent.querySelector('.nav-next'); } } this.slidesLength = this.slides.length; if (!this.slidesLength) return; this.slideSize = this.slides[0].offsetWidth; this.index = 1; this.posX1 = 0; this.posX2 = 0; this.posInitial = 0; this.touchEndPosition = 0; this.touchEventTimer; this.hasAutoslide = false; this.initPagination(); if (/Android|webOS|iPhone|iPad|iPod|BlackBerry/i.test(navigator.userAgent)) {} else { this.initAutoslide(); } this.initEvents(); this.slider.classList.add('loaded'); } initEvents() { this.mouseUpEvent = (e) => { this.dragEnd(e, this); } ; this.mouseMoveEvent = (e) => { this.dragAction(e, this); } ; this.disablePagination = false; if (this.slidesWrapper.scrollWidth <= this.slidesWrapper.clientWidth) { this.disablePagination = true; } if (this.prev) { if (this.disablePagination) { this.prev.style.display = 'none'; } else { this.prev.addEventListener('click', () => { this.shiftSlide(this, -1) } ); } } if (this.next) { if (this.disablePagination) { this.next.style.display = 'none'; } else { this.next.addEventListener('click', () => { this.shiftSlide(this, 1) } ); } } this.slidesWrapper.addEventListener('mousedown', (e) => { if (e.buttons == 1 && !e.target.closest(".product__wishlist")) { this.dragStart(e, this); } } ); this.slidesWrapper.addEventListener('touchend', (e) => { this.touchEvent(this) } ); this.slidesWrapper.addEventListener('mousewheel', (e) => { this.touchEvent(this) } ); } initAutoslide() { if (this.slidesWrapper.classList.contains('autoslide')) { this.hasAutoslide = true; } if (this.hasAutoslide) { this.maxScroll = this.slidesWrapper.scrollWidth - this.slidesWrapper.clientWidth; this.autoslideTimer = setInterval(this.autoslideHandler, 50, this); this.slidesWrapper.addEventListener('mouseover', () => { this.slidesWrapper.classList.add('pause'); } ); this.slidesWrapper.addEventListener('mouseout', () => { this.slidesWrapper.classList.remove('pause'); } ); this.slidesWrapper.addEventListener('touchstart', () => { this.slidesWrapper.classList.add('pause'); } ); this.slidesWrapper.addEventListener('touchend', () => { this.slidesWrapper.classList.remove('pause'); } ); } } autoslideHandler(_self) { if (_self.slidesWrapper.classList.contains("sliding")) return; if (_self.slidesWrapper.classList.contains("pause")) return; _self.slidesWrapper.scrollLeft += 1; if (_self.slidesWrapper.scrollLeft >= _self.maxScroll) { clearInterval(_self.autoslideTimer); } } initPagination() { this.paginationWrapper = this.slider.getElementsByClassName('slider__pagination'); this.hasPagination = this.paginationWrapper.length ? true : false; if (this.hasPagination) { this.paginationWrapper = this.slider.getElementsByClassName('slider__pagination')[0]; this.paginationWrapper.firstElementChild.classList.add('active'); const pagination_dots = this.paginationWrapper.getElementsByClassName('slider__pagination--dot'); for (const dot of pagination_dots) { dot.addEventListener('click', (e) => this.paginationClick(e, this)); } } } paginationClick(e, _self) { const element = e.target; const parent = element.parentElement; _self.index = Array.from(parent.children).indexOf(element) + 1; _self.slidesWrapper.scrollLeft = _self.slideSize * (_self.index - 1); _self.updatePagination(); } touchEvent(_self) { _self.touchEndPosition = _self.slidesWrapper.scrollLeft; _self.touchEventTimer = setInterval(_self.touchEventHandler, 50, _self); } touchEventHandler(obj) { if (obj.touchEndPosition == obj.slidesWrapper.scrollLeft) { clearInterval(obj.touchEventTimer); obj.index = Math.round(obj.touchEndPosition / obj.slideSize) + 1; obj.updatePagination(); } else { obj.touchEndPosition = obj.slidesWrapper.scrollLeft; } } dragStart(e, _self) { _self.posInitial = _self.slidesWrapper.scrollLeft; _self.initialX = e.clientX; _self.posX1 = e.clientX; document.addEventListener('mouseup', _self.mouseUpEvent); document.addEventListener('mousemove', _self.mouseMoveEvent); } dragAction(e, _self) { _self.slidesWrapper.classList.add("sliding"); _self.posX2 = _self.posX1 - e.clientX; _self.posX1 = e.clientX; _self.slidesWrapper.scrollLeft = _self.slidesWrapper.scrollLeft + _self.posX2; } dragEnd(e, _self) { _self.index = Math.round(_self.slidesWrapper.scrollLeft / _self.slideSize) + 1; document.removeEventListener('mouseup', _self.mouseUpEvent); document.removeEventListener('mousemove', _self.mouseMoveEvent); _self.slidesWrapper.classList.remove("sliding"); if (_self.initialX == e.clientX) { document.dispatchEvent(new CustomEvent("slider_clicked",{ detail: { evt: e } })); } else { document.dispatchEvent(new CustomEvent("slider_changed",{ detail: { evt: e } })); } _self.updatePagination(); } shiftSlide(_self, dir) { _self.posInitial = _self.slidesWrapper.scrollLeft; if (dir == 1) { if (_self.index > _self.slidesLength || (_self.slidesWrapper.scrollWidth >= (_self.slidesWrapper.scrollLeft + _self.slidesWrapper.clientWidth - 1) && _self.slidesWrapper.scrollWidth <= (_self.slidesWrapper.scrollLeft + _self.slidesWrapper.clientWidth + 1))) { _self.slidesWrapper.scrollLeft = 0; _self.index = 1; } else { _self.slidesWrapper.scrollLeft = _self.posInitial + _self.slideSize; _self.index++; } } else if (dir == -1 && _self.index > 1) { _self.slidesWrapper.scrollLeft = _self.posInitial - _self.slideSize; _self.index--; } document.dispatchEvent(new CustomEvent("slider_changed")); this.updatePagination(); } updatePagination() { if (!this.hasPagination) { return; } ; this.paginationWrapper.querySelectorAll('.active').forEach(e => e.classList.remove("active")); this.paginationWrapper.querySelectorAll('.slider__pagination--dot:nth-child(' + this.index + ')')[0].classList.add('active'); } } /***/ } ), /***/ "./content/default/views/product/variation/variation.js": /*!**************************************************************!*\ !*** ./content/default/views/product/variation/variation.js ***! \**************************************************************/ /***/ ( (__unused_webpack_module, __webpack_exports__, __webpack_require__) => { "use strict"; __webpack_require__.r(__webpack_exports__); /* harmony export */ __webpack_require__.d(__webpack_exports__, { /* harmony export */ "default": () => (/* binding */ Variation)/* harmony export */ }); /* harmony import */ var _scripts_utils_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../../../scripts/utils.js */ "./content/default/scripts/utils.js"); class Variation { constructor(variantsData, buyButton) { this.product_id = variantsData.product_id; this.variantsData = variantsData.variants; this.fields = document.getElementById('variation-1'); this.poi_sizes = document.querySelectorAll('.poi.buybox__variant--item'); this.variants = document.getElementsByClassName('buybox__variant--item'); this.buyButton = buyButton; this.autoAdd = false; this.isInitialized = false; // Added to control re-initialization this.init(this.variants); } init(variants) { this.initEvents(); this.initPOI_toggle(); } initEvents() { const container = document.querySelector('.buybox__variant--items'); if (!container) return; container.addEventListener('click', (event) => { // Check if the clicked element is a .buybox__variant--item var target = event.target.closest('.buybox__variant--item'); if (!target) return; // Hide all overlay texts var overlays = container.querySelectorAll('.overlay-text'); overlays.forEach( (overlay) => { overlay.classList.add('hide'); } ); // Show the overlay text for the clicked item var overlayText = target.querySelector('.overlay-text'); if (overlayText && target.classList && !target.classList.contains('disabled')) { overlayText.classList.remove('hide'); } // Also handle the field update event this.updateFieldEvent(event); } ); this.buyButton.addEventListener('addToCart', e => { this.showCartError(e); } ); const labels = document.getElementsByClassName('buybox__variant--title'); for (const label of labels) { label.addEventListener('click', e => { this.toggleVariantWrapper(label); } ); } } toggleVariantWrapper(label) { const wrapper = label.parentNode; if (wrapper.classList.contains('open')) { wrapper.classList.remove('open'); } else { wrapper.classList.add('open'); label.classList.add('hide'); } } updateFieldEvent(e) { let button = e.target.closest('.buybox__variant--item'); if (!button || !button.dataset.id) return; const variantId = button.dataset.id; //document.querySelector('.product-id-info').innerHTML = variantId; // Hide all dd.ean_placeholder elements const placeholders = document.querySelectorAll('dd.ean_placeholder.property--listItem'); placeholders.forEach(placeholder => { placeholder.classList.add('hide'); }); const product_id_holders = document.querySelectorAll('.product-id-info'); // Update product ID holders and remove 'hide' class for matching elements product_id_holders.forEach(product_id_holder => { product_id_holder.innerHTML = variantId; // Find the matching
    element where data-id matches variantId const matchingElement = document.querySelector(`dd.ean_placeholder.property--listItem.hide[data-id="${variantId}"]`); if (matchingElement) { matchingElement.classList.remove('hide'); } }); const field = this.fields; //button.parentNode; Array.from(this.poi_sizes).forEach(elem => elem.classList.remove('active')); Array.from(field.children).forEach(child => child.classList.remove('active')); button.classList.toggle('active'); this.buyButton.classList.toggle("disabled", !button.classList.contains('active')); field.dataset.value = button.classList.contains('active') ? variantId : ''; this.updateLabel(field, button.classList.contains('active') ? variantId : ''); this.updateFields(); } updateLabel(field, variantId) { const labels = field.parentNode.querySelectorAll('.label'); // Assuming multiple labels labels.forEach(label => { const dataFor = label.getAttribute('data-for'); if (dataFor === variantId) { const variant = this.variantsData.find(v => v.id === variantId); if (variant) { label.textContent = variant.label || ''; } } } ); } updateFields() { let values = []; let allFieldsSelected = true; if (this.fields.dataset.value) { values.push(this.fields.dataset.value); } else { allFieldsSelected = false; } allFieldsSelected ? this.setVariant(values) : this.clearVariant(); } async setVariant(values) { for (const value of values) { const variant = this.variantsData.find(v => v.id === value); if (variant) { const response = await fetch(`/shop?funk=get_variant&product_id=${this.product_id}&variant_id=${variant.id}`); const result = await response.json(); if (result.status.code === 200) { const data = result.data; this.updateVariantInfo(variant, data); // Correctly call updateVariantInfo here } else { console.error('Failed to fetch variant data:', result.status.message); } } else { console.error('Variant not found for ID:', value); } } } initPOI_toggle() { const toggleTrigger = document.querySelector(".poi_toggle"); const variantContainers = document.querySelectorAll(".buybox__variant--items"); if (toggleTrigger) { toggleTrigger.addEventListener("click", () => { this.unselectVariants(); variantContainers.forEach(container => { Array.from(container.children).forEach(child => { if (!child.classList.contains("poi_toggle")) { child.classList.toggle("hide"); // Toggle visibility for each non-toggle child } } ); } ); // Determine the toggle text based on the visibility of the first item across all containers const someVisible = Array.from(variantContainers).some(container => container.querySelector('.poi.buybox__variant--item') && !container.querySelector('.poi.buybox__variant--item').classList.contains("hide")); toggleTrigger.textContent = someVisible ? "Visa endast nya" : "Visa endast Pre-owned"; } ); } } unselectVariants() { Array.from(this.variants).forEach(item => { item.classList.remove('active'); Array.from(item.getElementsByTagName('span')).forEach(span => { span.classList.add('hide'); } ); } ); const airBuyElement = this.buyButton; if (airBuyElement) { airBuyElement.classList.add('disabled'); airBuyElement.classList.remove('error'); airBuyElement.dataset.id = ''; } this.clearVariant(); this.clearFields(); this.buyButton.addEventListener('addToCart', e => { this.showCartError(e); } ); } updateVariantInfo(variant, data) { // Update buy button label and classes based on variant properties const btnLabel = this.buyButton.getElementsByClassName('air-buy-label')[0]; if (variant.buyable) { btnLabel.textContent = btnLabel.dataset.buyable; this.buyButton.classList.add('buyable'); this.buyButton.classList.remove('alertable'); } else if (variant.watchable) { btnLabel.textContent = btnLabel.dataset.alertable; this.buyButton.classList.add('alertable'); this.buyButton.classList.remove('buyable'); } // Set buy button data attributes for variant tracking this.buyButton.dataset.id = variant.id; this.buyButton.dataset.stock_id = variant.availability_id; this.buyButton.classList.remove('error'); // Update various elements across the page with variant-specific data this.updateVariantElements(variant.id, data); if (this.autoAdd) { document.querySelector("#air-buy").click(); this.autoAdd = false; } } updateVariantElements(variantId, data) { // Assume data contains the pricing and other variant-specific information const priceElement = document.querySelector('.price-info '); if (!priceElement) { return; } // Assuming formatPriceHtml is a function defined elsewhere that formats the price HTML priceElement.innerHTML = (0, _scripts_utils_js__WEBPACK_IMPORTED_MODULE_0__.formatPriceHtml)(data.price, data.price_regular, data.campaign, data.price_prefix); } clearVariant() { this.buyButton.dataset.id = ''; } clearFields() { // Iterate over each field and reset its dataset value if (this.fields.dataset.value) { this.fields.dataset.value = ''; // Reset the dataset value } } showCartError() { let hasActiveVariant = false; // First, check if any variant has the 'active' class for (const field of this.variants) { if (field.classList.contains('active')) { hasActiveVariant = true; break; } } // If no variant has the 'active' class, apply the 'error' class if (!hasActiveVariant) { for (const field of this.variants) { field.classList.add('error'); field.parentElement.classList.add('error'); } document.querySelector("#air-buy").classList.add("error"); this.errorEvent = () => this.hideErrorEvent(); document.addEventListener('click', this.errorEvent); } else { // If a variant is active, remove any existing error classes for (const field of this.variants) { field.classList.remove('error'); field.parentElement.classList.remove('error'); } document.querySelector("#air-buy").classList.remove("error"); } } hideErrorEvent() { for (const field of this.fields) { field.classList.remove('error'); field.parentElement.classList.remove('error'); } document.removeEventListener('click', this.errorEvent); } } /***/ } ), /***/ "./content/default/views/product/wishlist.js": /*!***************************************************!*\ !*** ./content/default/views/product/wishlist.js ***! \***************************************************/ /***/ ( (__unused_webpack_module, __webpack_exports__, __webpack_require__) => { "use strict"; __webpack_require__.r(__webpack_exports__); /* harmony export */ __webpack_require__.d(__webpack_exports__, { /* harmony export */ "default": () => (/* binding */ Wishlist)/* harmony export */ }); /* harmony import */ var _scripts_utils_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../../scripts/utils.js */ "./content/default/scripts/utils.js"); const storage_name = 'air_wishlist'; const expire_time = 60; // In minutes. let wishlist; class Wishlist { constructor(cart) { this.cart = cart; this.init(); this.init_events(); } init() { if (!(0, _scripts_utils_js__WEBPACK_IMPORTED_MODULE_0__.getCookie)('SESS')) return; if (!document.getElementsByClassName("header__wishlist").length) return; document.querySelectorAll('.Din_Sida_Onskelista_Wrapper .Knapp_Kop a').forEach(element => { element.addEventListener('click', (e) => { e.preventDefault(); let form = element.parentNode.parentNode.parentNode.parentNode.parentNode; let product_id = form.altnr.value; if (product_id) { this.cart.add_item(product_id, 1); } } ); } ); wishlist = this.get_storage(); if (wishlist) { this.render(); } else { this.get(); } } init_events() { window.liveEvent(".product__wishlist", "click", (event, element) => { this.handle_event(element, event); } ); window.liveEvent(".remove_single", "click", (event, element) => { this.handle_event(element, event); } ); document.addEventListener('after_filter', () => { this.init(); } ); document.addEventListener('product_cell_update', () => { this.init(); } ); } async get() { const response = await fetch('/shop?funk=get_wishlist'); const result = await response.json(); if (result.status.code == 200) { wishlist = result.data; this.save_storage(); this.render(); } } get_storage() { if (typeof (Storage) === 'undefined') return null; let str = window.localStorage.getItem(storage_name); if (str == null) return undefined; let data; try { data = JSON.parse(str); } catch (e) { return undefined; } if (data.expires < Date.now()) { return undefined; } return data; } save_storage() { if (typeof (Storage) === 'undefined') return null; wishlist.expires = Date.now() + expire_time * 60000; window.localStorage.setItem(storage_name, JSON.stringify(wishlist)); } handle_event(element, event) { event.preventDefault(); if (element.classList.contains('--filled') || element.classList.contains('remove_single')) { element.classList.remove("--filled"); this.remove_item(element.dataset.id); } else { element.classList.add("--filled"); this.add_item(element.dataset.id); } } async add_item(id, no_render=false) { const data = new URLSearchParams(); data.append('funk', 'add_wishlist_item'); data.append('id', id); const response = await fetch('/shop', { method: 'POST', body: data }); const result = await response.json(); if (result.status.code == 200) { wishlist = result.data.wishlist; this.save_storage(); if (!no_render) { this.save_storage(); this.render(); } } if (!no_render) { await this.remove_item(id, true); //get pixel for wishlist const data_2 = new URLSearchParams(); data_2.append('funk', 'Onskelista_Lagg_Till_Artikel_JSON'); data_2.append('Artnr', id); const response_2 = await fetch('/shop', { method: 'POST', body: data_2 }); const result_2 = await response_2.json(); if (result_2.status == 'OK') { const temporary_element = document.createElement('div'); temporary_element.innerHTML = result_2.pixels; (0, _scripts_utils_js__WEBPACK_IMPORTED_MODULE_0__.executeJs)(temporary_element); } } } async remove_item(id, no_render=false) { const data = new URLSearchParams(); data.append('funk', 'remove_wishlist_item'); data.append('id', id); const response = await fetch('/shop', { method: 'POST', body: data }); const result = await response.json(); if (result.status.code == 200) { wishlist = result.data.wishlist; if (!no_render) { this.save_storage(); this.render(); } } if (!no_render) { await this.add_item(id, true); //get pixel for wishlist const data_2 = new URLSearchParams(); data_2.append('funk', 'Onskelista_Radera_Artikel_JSON'); data_2.append('Artnr', id); const response_2 = await fetch('/shop', { method: 'POST', body: data_2 }); const result_2 = await response_2.json(); if (result_2.status == 'OK') { const temporary_element = document.createElement('div'); temporary_element.innerHTML = result_2.pixels; (0, _scripts_utils_js__WEBPACK_IMPORTED_MODULE_0__.executeJs)(temporary_element); } } } render() { document.querySelectorAll('.product__wishlist.--filled').forEach(element => { element.classList.remove("--filled"); } ); // Lights up stars for products in wishlist let i = 0; while (i < wishlist.length) { const elements = document.querySelectorAll('[data-id="' + wishlist[i].id + '"]'); elements.forEach(function(element) { element.classList.add('--filled'); }); i++; } // Lights up star in header var header_element = document.getElementsByClassName("header__wishlist"); if (!header_element) return; if (wishlist.length) { header_element[0].classList.add('--filled'); } else { header_element[0].classList.remove("--filled"); } } } /***/ } ), /***/ "./content/default/views/product/zoom.js": /*!***********************************************!*\ !*** ./content/default/views/product/zoom.js ***! \***********************************************/ /***/ (function(module) { (function(root, factory) { if (true && module.exports) { module.exports = factory(); } else { root.ImageZoom = factory(); } }(this, function() { /** * @param {Object} container DOM element, which contains an image to be zoomed (required) * @param {Object} options js-image-zoom options (required) * **width** (number) - width of the source image (optional) * **height** (number) - height of the source image (optional). * **zoomWidth** (number) - width of the zoomed image. Zoomed image height equals source image height (optional) * **img** (string) - url of the source image. Provided if container does not contain img element as a tag (optional) * **scale** (number) - zoom scale. if not provided, scale is calculated as natural image size / image size, provided in params (optional if zoomWidth param is provided) * **offset** (object) - {vertical: number, horizontal: number}. Zoomed image offset (optional) * **zoomContainer** (node) - DOM node reference where zoomedImage will be appended to (default to the container element of image) * **zoomStyle** (string) - custom style applied to the zoomed image (i.e. 'opacity: 0.1;background-color: white;') * **zoomPosition** (string) - position of zoomed image. It can be: `top`, `left`, `bottom`, `original` or the default `right`. * **zoomLensStyle** (string) custom style applied to to zoom lents (i.e. 'opacity: 0.1;background-color: white;') */ return function ImageZoom(container, opts) { "use strict"; var options = opts; if (!container) { return; } var data = { sourceImg: { element: null, width: 0, height: 0, naturalWidth: 0, naturalHeight: 0 }, img: { element: null, width: 0, height: 0, naturalWidth: 0, naturalHeight: 0 }, zoomedImgOffset: { vertical: 0, horizontal: 0 }, zoomedImg: { element: null, width: 0, height: 0 }, zoomLens: { element: null, width: 0, height: 0 } }; var div = document.createElement('div'); var lensDiv = document.createElement('div'); var scaleX; var scaleY; var offset; var zoomScaleX; var zoomScaleY; var zoomOffset; data.zoomedImgOffset = { vertical: options.offset && options.offset.vertical ? options.offset.vertical : 0, horizontal: options.offset && options.offset.horizontal ? options.offset.horizontal : 0 }; data.zoomPosition = options.zoomPosition || 'right'; data.zoomContainer = (options.zoomContainer) ? options.zoomContainer : container; function getOffset(el) { if (el) { var elRect = el.getBoundingClientRect(); return { left: elRect.left, top: elRect.top }; } return { left: 0, top: 0 }; } function leftLimit(min) { return options.width - min; } function topLimit(min) { return options.height - min; } function getValue(val, min, max) { if (val < min) { return min; } if (val > max) { return max; } return val; } function getPosition(v, min, max) { var value = getValue(v, min, max); return value - min; } function zoomLensLeft(left) { var leftMin = data.zoomLens.width / 2; return getPosition(left, leftMin, leftLimit(leftMin)); } function zoomLensTop(top) { var topMin = data.zoomLens.height / 2; return getPosition(top, topMin, topLimit(topMin)); } function setZoomedImgSize(options, data) { if (options.scale) { data.zoomedImg.element.style.width = options.width * options.scale + 'px'; data.zoomedImg.element.style.height = options.height * options.scale + 'px'; } else if (options.zoomWidth) { data.zoomedImg.element.style.width = options.zoomWidth + 'px'; data.zoomedImg.element.style.height = data.sourceImg.element.style.height; } else { data.zoomedImg.element.style.width = '100%'; data.zoomedImg.element.style.height = '100%'; } } function onSourceImgLoad() { // use height determined by browser if height is not set in options options.height = options.height || data.sourceImg.element.height; // data.sourceImg.element.style.height = options.height + 'px'; data.sourceImg.element.style.height = '100%'; // use width determined by browser if width is not set in options options.width = options.width || data.sourceImg.element.width; data.sourceImg.element.style.width = options.width + 'px'; setZoomedImgSize(options, data); data.sourceImg.naturalWidth = data.sourceImg.element.naturalWidth; data.sourceImg.naturalHeight = data.sourceImg.element.naturalHeight; data.zoomedImg.element.style.backgroundSize = data.img.element.naturalWidth + 'px ' + data.img.element.naturalHeight + 'px'; if (options.zoomStyle) { data.zoomedImg.element.style.cssText += options.zoomStyle; } if (options.zoomLensStyle) { data.zoomLens.element.style.cssText += options.zoomLensStyle; } else { data.zoomLens.element.style.background = 'white'; data.zoomLens.element.style.opacity = '0.4'; } zoomScaleX = data.img.element.naturalWidth / options.width; zoomScaleY = data.img.element.naturalHeight / options.height; zoomOffset = getOffset(data.img.element); scaleX = data.sourceImg.naturalWidth / options.width; scaleY = data.sourceImg.naturalHeight / options.height; offset = getOffset(data.sourceImg.element); // set zoomLens dimensions // if custom scale is set if (options.scale) { data.zoomLens.width = options.width / (data.sourceImg.naturalWidth / (options.width * options.scale)); data.zoomLens.height = options.height / (data.sourceImg.naturalHeight / (options.height * options.scale)); } // else if zoomWidth is set else if (options.zoomWidth) { data.zoomLens.width = options.zoomWidth / zoomScaleX; data.zoomLens.height = options.height / zoomScaleY; } // else read from the zoomedImg else { data.zoomedImg.element.style.display = 'block'; data.zoomLens.width = data.zoomedImg.element.clientWidth / scaleX; data.zoomLens.height = data.zoomedImg.element.clientHeight / scaleY; data.zoomedImg.element.style.display = 'none'; } data.zoomLens.element.style.position = 'absolute'; data.zoomLens.element.style.width = data.zoomLens.width + 'px'; data.zoomLens.element.style.height = data.zoomLens.height + 'px'; data.zoomLens.element.pointerEvents = 'none'; } function setup() { // create sourceImg element if (options.img) { var img = document.createElement('img'); img.src = options.img; data.sourceImg.element = container.appendChild(img); } else { data.sourceImg.element = container.children[0]; // if sourceImg is not an img (might be a picture element), try to find one if (data.sourceImg.element.nodeName !== "IMG") { data.sourceImg.element = data.sourceImg.element.querySelector('img'); } } // if (options.zoomImage) { let img = document.createElement('img'); img.src = options.zoomImage; data.img.element = img; } else { data.img.element = data.sourceImg.element; } options = options || {}; container.style.position = 'relative'; // data.sourceImg.element.style.width = options.width ? options.width + 'px' : 'auto'; // data.sourceImg.element.style.height = options.height ? options.height + 'px' : 'auto'; data.zoomLens.element = container.appendChild(lensDiv); data.zoomLens.element.style.display = 'none'; data.zoomLens.element.classList.add('js-image-zoom__zoomed-area'); data.zoomedImg.element = data.zoomContainer.appendChild(div); data.zoomedImg.element.classList.add('js-image-zoom__zoomed-image'); data.zoomedImg.element.style.backgroundImage = "url('" + data.img.element.src + "')"; // data.zoomedImg.element.style.backgroundImage = "url('" + data.sourceImg.element.src + "')"; data.zoomedImg.element.style.backgroundRepeat = 'no-repeat'; data.zoomedImg.element.style.display = 'none'; data.zoomedImg.element.style.zIndex = '2'; data.zoomedImg.element.style.position = 'absolute'; data.zoomedImg.element.style.top = data.zoomedImgOffset.vertical + 'px'; data.zoomedImg.element.style.right = data.zoomedImgOffset.horizontal - (data.zoomedImgOffset.horizontal * 2) + 'px'; data.zoomedImg.element.style.transform = 'translateX(100%)'; // setup event listeners container.addEventListener('mousemove', events, false); container.addEventListener('mouseenter', events, false); container.addEventListener('mouseleave', events, false); data.zoomLens.element.addEventListener('mouseenter', events, false); data.zoomLens.element.addEventListener('mouseleave', events, false); window.addEventListener('scroll', events, false); return data; } function kill() { // remove event listeners container.removeEventListener('mousemove', events, false); container.removeEventListener('mouseenter', events, false); container.removeEventListener('mouseleave', events, false); data.zoomLens.element.removeEventListener('mouseenter', events, false); data.zoomLens.element.removeEventListener('mouseleave', events, false); window.removeEventListener('scroll', events, false); // remove dom nodes if (data.zoomLens && data.zoomedImg) { container.removeChild(data.zoomLens.element); data.zoomContainer.removeChild(data.zoomedImg.element); } if (options.img) { container.removeChild(data.sourceImg.element); } else { data.sourceImg.element.style.width = ''; data.sourceImg.element.style.height = ''; } return data; } var events = { handleEvent: function(event) { switch (event.type) { case 'mousemove': return this.handleMouseMove(event); case 'mouseenter': return this.handleMouseEnter(event); case 'mouseleave': return this.handleMouseLeave(event); case 'scroll': return this.handleScroll(event); } }, handleMouseMove: function(event) { var offsetX; var offsetY; var backgroundTop; var backgroundRight; var backgroundPosition; if (offset) { offsetX = zoomLensLeft(event.clientX - offset.left); offsetY = zoomLensTop(event.clientY - offset.top); backgroundTop = offsetX * zoomScaleX; backgroundRight = offsetY * zoomScaleY; backgroundPosition = '-' + backgroundTop + 'px ' + '-' + backgroundRight + 'px'; data.zoomedImg.element.style.backgroundPosition = backgroundPosition; data.zoomLens.element.style.cssText += 'top:' + offsetY + 'px;' + 'left:' + offsetX + 'px;display: block;'; } }, handleMouseEnter: function() { data.zoomedImg.element.style.display = 'block'; data.zoomLens.element.style.display = 'block'; }, handleMouseLeave: function() { data.zoomedImg.element.style.display = 'none'; data.zoomLens.element.style.display = 'none'; }, handleScroll: function() { offset = getOffset(data.sourceImg.element); } }; // Setup/Initialize library setup(); // if (data.sourceImg.element.complete) { if (data.img.element.complete) { onSourceImgLoad(); } else { data.img.element.onload = onSourceImgLoad; // data.sourceImg.element.onload = onSourceImgLoad; } return { setup: function() { setup(); }, kill: function() { kill(); }, _getInstanceInfo: function() { return { setup: setup, kill: kill, onSourceImgLoad: onSourceImgLoad, data: data, options: options } } } } })); /***/ } ), /***/ "./content/default/app.scss": /*!**********************************!*\ !*** ./content/default/app.scss ***! \**********************************/ /***/ ( (__unused_webpack_module, __webpack_exports__, __webpack_require__) => { "use strict"; __webpack_require__.r(__webpack_exports__); // extracted by mini-css-extract-plugin /***/ } ), /***/ "./node_modules/vanilla-lazyload/dist/lazyload.min.js": /*!************************************************************!*\ !*** ./node_modules/vanilla-lazyload/dist/lazyload.min.js ***! \************************************************************/ /***/ (function(module) { !function(n, t) { true ? module.exports = t() : 0 }(this, (function() { "use strict"; function n() { return n = Object.assign || function(n) { for (var t = 1; t < arguments.length; t++) { var e = arguments[t]; for (var i in e) Object.prototype.hasOwnProperty.call(e, i) && (n[i] = e[i]) } return n } , n.apply(this, arguments) } var t = "undefined" != typeof window , e = t && !("onscroll"in window) || "undefined" != typeof navigator && /(gle|ing|ro)bot|crawl|spider/i.test(navigator.userAgent) , i = t && "IntersectionObserver"in window , o = t && "classList"in document.createElement("p") , a = t && window.devicePixelRatio > 1 , r = { elements_selector: ".lazy", container: e || t ? document : null, threshold: 300, thresholds: null, data_src: "src", data_srcset: "srcset", data_sizes: "sizes", data_bg: "bg", data_bg_hidpi: "bg-hidpi", data_bg_multi: "bg-multi", data_bg_multi_hidpi: "bg-multi-hidpi", data_bg_set: "bg-set", data_poster: "poster", class_applied: "applied", class_loading: "loading", class_loaded: "loaded", class_error: "error", class_entered: "entered", class_exited: "exited", unobserve_completed: !0, unobserve_entered: !1, cancel_on_exit: !0, callback_enter: null, callback_exit: null, callback_applied: null, callback_loading: null, callback_loaded: null, callback_error: null, callback_finish: null, callback_cancel: null, use_native: !1, restore_on_error: !1 } , c = function(t) { return n({}, r, t) } , l = function(n, t) { var e, i = "LazyLoad::Initialized", o = new n(t); try { e = new CustomEvent(i,{ detail: { instance: o } }) } catch (n) { (e = document.createEvent("CustomEvent")).initCustomEvent(i, !1, !1, { instance: o }) } window.dispatchEvent(e) } , u = "src" , s = "srcset" , d = "sizes" , f = "poster" , _ = "llOriginalAttrs" , g = "data" , v = "loading" , b = "loaded" , m = "applied" , p = "error" , h = "native" , E = "data-" , I = "ll-status" , y = function(n, t) { return n.getAttribute(E + t) } , k = function(n) { return y(n, I) } , w = function(n, t) { return function(n, t, e) { var i = "data-ll-status"; null !== e ? n.setAttribute(i, e) : n.removeAttribute(i) }(n, 0, t) } , A = function(n) { return w(n, null) } , L = function(n) { return null === k(n) } , O = function(n) { return k(n) === h } , x = [v, b, m, p] , C = function(n, t, e, i) { n && (void 0 === i ? void 0 === e ? n(t) : n(t, e) : n(t, e, i)) } , N = function(n, t) { o ? n.classList.add(t) : n.className += (n.className ? " " : "") + t } , M = function(n, t) { o ? n.classList.remove(t) : n.className = n.className.replace(new RegExp("(^|\\s+)" + t + "(\\s+|$)"), " ").replace(/^\s+/, "").replace(/\s+$/, "") } , z = function(n) { return n.llTempImage } , T = function(n, t) { if (t) { var e = t._observer; e && e.unobserve(n) } } , R = function(n, t) { n && (n.loadingCount += t) } , G = function(n, t) { n && (n.toLoadCount = t) } , j = function(n) { for (var t, e = [], i = 0; t = n.children[i]; i += 1) "SOURCE" === t.tagName && e.push(t); return e } , D = function(n, t) { var e = n.parentNode; e && "PICTURE" === e.tagName && j(e).forEach(t) } , H = function(n, t) { j(n).forEach(t) } , V = [u] , F = [u, f] , B = [u, s, d] , J = [g] , P = function(n) { return !!n[_] } , S = function(n) { return n[_] } , U = function(n) { return delete n[_] } , $ = function(n, t) { if (!P(n)) { var e = {}; t.forEach((function(t) { e[t] = n.getAttribute(t) } )), n[_] = e } } , q = function(n, t) { if (P(n)) { var e = S(n); t.forEach((function(t) { !function(n, t, e) { e ? n.setAttribute(t, e) : n.removeAttribute(t) }(n, t, e[t]) } )) } } , K = function(n, t, e) { N(n, t.class_applied), w(n, m), e && (t.unobserve_completed && T(n, t), C(t.callback_applied, n, e)) } , Q = function(n, t, e) { N(n, t.class_loading), w(n, v), e && (R(e, 1), C(t.callback_loading, n, e)) } , W = function(n, t, e) { e && n.setAttribute(t, e) } , X = function(n, t) { W(n, d, y(n, t.data_sizes)), W(n, s, y(n, t.data_srcset)), W(n, u, y(n, t.data_src)) } , Y = { IMG: function(n, t) { D(n, (function(n) { $(n, B), X(n, t) } )), $(n, B), X(n, t) }, IFRAME: function(n, t) { $(n, V), W(n, u, y(n, t.data_src)) }, VIDEO: function(n, t) { H(n, (function(n) { $(n, V), W(n, u, y(n, t.data_src)) } )), $(n, F), W(n, f, y(n, t.data_poster)), W(n, u, y(n, t.data_src)), n.load() }, OBJECT: function(n, t) { $(n, J), W(n, g, y(n, t.data_src)) } } , Z = ["IMG", "IFRAME", "VIDEO", "OBJECT"] , nn = function(n, t) { !t || function(n) { return n.loadingCount > 0 }(t) || function(n) { return n.toLoadCount > 0 }(t) || C(n.callback_finish, t) } , tn = function(n, t, e) { n.addEventListener(t, e), n.llEvLisnrs[t] = e } , en = function(n, t, e) { n.removeEventListener(t, e) } , on = function(n) { return !!n.llEvLisnrs } , an = function(n) { if (on(n)) { var t = n.llEvLisnrs; for (var e in t) { var i = t[e]; en(n, e, i) } delete n.llEvLisnrs } } , rn = function(n, t, e) { !function(n) { delete n.llTempImage }(n), R(e, -1), function(n) { n && (n.toLoadCount -= 1) }(e), M(n, t.class_loading), t.unobserve_completed && T(n, e) } , cn = function(n, t, e) { var i = z(n) || n; on(i) || function(n, t, e) { on(n) || (n.llEvLisnrs = {}); var i = "VIDEO" === n.tagName ? "loadeddata" : "load"; tn(n, i, t), tn(n, "error", e) }(i, (function(o) { !function(n, t, e, i) { var o = O(t); rn(t, e, i), N(t, e.class_loaded), w(t, b), C(e.callback_loaded, t, i), o || nn(e, i) }(0, n, t, e), an(i) } ), (function(o) { !function(n, t, e, i) { var o = O(t); rn(t, e, i), N(t, e.class_error), w(t, p), C(e.callback_error, t, i), e.restore_on_error && q(t, B), o || nn(e, i) }(0, n, t, e), an(i) } )) } , ln = function(n, t, e) { !function(n) { return Z.indexOf(n.tagName) > -1 }(n) ? function(n, t, e) { !function(n) { n.llTempImage = document.createElement("IMG") }(n), cn(n, t, e), function(n) { P(n) || (n[_] = { backgroundImage: n.style.backgroundImage }) }(n), function(n, t, e) { var i = y(n, t.data_bg) , o = y(n, t.data_bg_hidpi) , r = a && o ? o : i; r && (n.style.backgroundImage = 'url("'.concat(r, '")'), z(n).setAttribute(u, r), Q(n, t, e)) }(n, t, e), function(n, t, e) { var i = y(n, t.data_bg_multi) , o = y(n, t.data_bg_multi_hidpi) , r = a && o ? o : i; r && (n.style.backgroundImage = r, K(n, t, e)) }(n, t, e), function(n, t, e) { var i = y(n, t.data_bg_set); if (i) { var o = i.split("|") , a = o.map((function(n) { return "image-set(".concat(n, ")") } )); n.style.backgroundImage = a.join(), "" === n.style.backgroundImage && (a = o.map((function(n) { return "-webkit-image-set(".concat(n, ")") } )), n.style.backgroundImage = a.join()), K(n, t, e) } }(n, t, e) }(n, t, e) : function(n, t, e) { cn(n, t, e), function(n, t, e) { var i = Y[n.tagName]; i && (i(n, t), Q(n, t, e)) }(n, t, e) }(n, t, e) } , un = function(n) { n.removeAttribute(u), n.removeAttribute(s), n.removeAttribute(d) } , sn = function(n) { D(n, (function(n) { q(n, B) } )), q(n, B) } , dn = { IMG: sn, IFRAME: function(n) { q(n, V) }, VIDEO: function(n) { H(n, (function(n) { q(n, V) } )), q(n, F), n.load() }, OBJECT: function(n) { q(n, J) } } , fn = function(n, t) { (function(n) { var t = dn[n.tagName]; t ? t(n) : function(n) { if (P(n)) { var t = S(n); n.style.backgroundImage = t.backgroundImage } }(n) } )(n), function(n, t) { L(n) || O(n) || (M(n, t.class_entered), M(n, t.class_exited), M(n, t.class_applied), M(n, t.class_loading), M(n, t.class_loaded), M(n, t.class_error)) }(n, t), A(n), U(n) } , _n = ["IMG", "IFRAME", "VIDEO"] , gn = function(n) { return n.use_native && "loading"in HTMLImageElement.prototype } , vn = function(n, t, e) { n.forEach((function(n) { return function(n) { return n.isIntersecting || n.intersectionRatio > 0 }(n) ? function(n, t, e, i) { var o = function(n) { return x.indexOf(k(n)) >= 0 }(n); w(n, "entered"), N(n, e.class_entered), M(n, e.class_exited), function(n, t, e) { t.unobserve_entered && T(n, e) }(n, e, i), C(e.callback_enter, n, t, i), o || ln(n, e, i) }(n.target, n, t, e) : function(n, t, e, i) { L(n) || (N(n, e.class_exited), function(n, t, e, i) { e.cancel_on_exit && function(n) { return k(n) === v }(n) && "IMG" === n.tagName && (an(n), function(n) { D(n, (function(n) { un(n) } )), un(n) }(n), sn(n), M(n, e.class_loading), R(i, -1), A(n), C(e.callback_cancel, n, t, i)) }(n, t, e, i), C(e.callback_exit, n, t, i)) }(n.target, n, t, e) } )) } , bn = function(n) { return Array.prototype.slice.call(n) } , mn = function(n) { return n.container.querySelectorAll(n.elements_selector) } , pn = function(n) { return function(n) { return k(n) === p }(n) } , hn = function(n, t) { return function(n) { return bn(n).filter(L) }(n || mn(t)) } , En = function(n, e) { var o = c(n); this._settings = o, this.loadingCount = 0, function(n, t) { i && !gn(n) && (t._observer = new IntersectionObserver((function(e) { vn(e, n, t) } ),function(n) { return { root: n.container === document ? null : n.container, rootMargin: n.thresholds || n.threshold + "px" } }(n))) }(o, this), function(n, e) { t && (e._onlineHandler = function() { !function(n, t) { var e; (e = mn(n), bn(e).filter(pn)).forEach((function(t) { M(t, n.class_error), A(t) } )), t.update() }(n, e) } , window.addEventListener("online", e._onlineHandler)) }(o, this), this.update(e) }; return En.prototype = { update: function(n) { var t, o, a = this._settings, r = hn(n, a); G(this, r.length), !e && i ? gn(a) ? function(n, t, e) { n.forEach((function(n) { -1 !== _n.indexOf(n.tagName) && function(n, t, e) { n.setAttribute("loading", "lazy"), cn(n, t, e), function(n, t) { var e = Y[n.tagName]; e && e(n, t) }(n, t), w(n, h) }(n, t, e) } )), G(e, 0) }(r, a, this) : (o = r, function(n) { n.disconnect() }(t = this._observer), function(n, t) { t.forEach((function(t) { n.observe(t) } )) }(t, o)) : this.loadAll(r) }, destroy: function() { this._observer && this._observer.disconnect(), t && window.removeEventListener("online", this._onlineHandler), mn(this._settings).forEach((function(n) { U(n) } )), delete this._observer, delete this._settings, delete this._onlineHandler, delete this.loadingCount, delete this.toLoadCount }, loadAll: function(n) { var t = this , e = this._settings; hn(n, e).forEach((function(n) { T(n, t), ln(n, e, t) } )) }, restoreAll: function() { var n = this._settings; mn(n).forEach((function(t) { fn(t, n) } )) } }, En.load = function(n, t) { var e = c(t); ln(n, e) } , En.resetStatus = function(n) { A(n) } , t && function(n, t) { if (t) if (t.length) for (var e, i = 0; e = t[i]; i += 1) l(n, e); else l(n, t) }(En, window.lazyLoadOptions), En } )); /***/ } ) /******/ }); /************************************************************************/ /******/ // The module cache /******/ var __webpack_module_cache__ = {}; /******/ /******/ // The require function /******/ function __webpack_require__(moduleId) { /******/ // Check if module is in cache /******/ var cachedModule = __webpack_module_cache__[moduleId]; /******/ if (cachedModule !== undefined) { /******/ return cachedModule.exports; /******/ } /******/ // Create a new module (and put it into the cache) /******/ var module = __webpack_module_cache__[moduleId] = { /******/ // no module.id needed /******/ // no module.loaded needed /******/ exports: {}/******/ }; /******/ /******/ // Execute the module function /******/ __webpack_modules__[moduleId].call(module.exports, module, module.exports, __webpack_require__); /******/ /******/ // Return the exports of the module /******/ return module.exports; /******/ } /******/ /************************************************************************/ /******/ /* webpack/runtime/compat get default export */ /******/ ( () => { /******/ // getDefaultExport function for compatibility with non-harmony modules /******/ __webpack_require__.n = (module) => { /******/ var getter = module && module.__esModule ? /******/ () => (module['default']) : /******/ () => (module); /******/ __webpack_require__.d(getter, { a: getter }); /******/ return getter; /******/ } ; /******/ } )(); /******/ /******/ /* webpack/runtime/define property getters */ /******/ ( () => { /******/ // define getter functions for harmony exports /******/ __webpack_require__.d = (exports, definition) => { /******/ for (var key in definition) { /******/ if (__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) { /******/ Object.defineProperty(exports, key, { enumerable: true, get: definition[key] }); /******/ } /******/ } /******/ } ; /******/ } )(); /******/ /******/ /* webpack/runtime/hasOwnProperty shorthand */ /******/ ( () => { /******/ __webpack_require__.o = (obj, prop) => (Object.prototype.hasOwnProperty.call(obj, prop)) /******/ } )(); /******/ /******/ /* webpack/runtime/make namespace object */ /******/ ( () => { /******/ // define __esModule on exports /******/ __webpack_require__.r = (exports) => { /******/ if (typeof Symbol !== 'undefined' && Symbol.toStringTag) { /******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' }); /******/ } /******/ Object.defineProperty(exports, '__esModule', { value: true }); /******/ } ; /******/ } )(); /******/ /************************************************************************/ var __webpack_exports__ = {}; // This entry need to be wrapped in an IIFE because it need to be in strict mode. ( () => { "use strict"; /*!************************!*\ !*** ./content/app.js ***! \************************/ __webpack_require__.r(__webpack_exports__); /* harmony import */ var _default_views_product_ajaxify__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./default/views/product/ajaxify */ "./content/default/views/product/ajaxify.js"); /* harmony import */ var _default_components_organisms_accordion__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./default/components/organisms/accordion */ "./content/default/components/organisms/accordion.js"); /* harmony import */ var _default_components_organisms_header_header__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./default/components/organisms/header/header */ "./content/default/components/organisms/header/header.js"); /* harmony import */ var _default_components_molecules_cart_cart__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./default/components/molecules/cart/cart */ "./content/default/components/molecules/cart/cart.js"); /* harmony import */ var _default_abstracts_grid_grid__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./default/abstracts/grid/grid */ "./content/default/abstracts/grid/grid.js"); /* harmony import */ var _default_components_molecules_login_login__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ./default/components/molecules/login/login */ "./content/default/components/molecules/login/login.js"); /* harmony import */ var _default_components_atoms_Navigation_main_navigation__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ./default/components/atoms/Navigation/main-navigation */ "./content/default/components/atoms/Navigation/main-navigation.js"); /* harmony import */ var _default_blocks_search_search__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(/*! ./default/blocks/search/search */ "./content/default/blocks/search/search.js"); /* harmony import */ var _default_blocks_country_picker_country_picker__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(/*! ./default/blocks/country-picker/country-picker */ "./content/default/blocks/country-picker/country-picker.js"); /* harmony import */ var _default_components_molecules_toplist_toplist__WEBPACK_IMPORTED_MODULE_9__ = __webpack_require__(/*! ./default/components/molecules/toplist/toplist */ "./content/default/components/molecules/toplist/toplist.js"); /* harmony import */ var _default_components_ace_Ace__WEBPACK_IMPORTED_MODULE_10__ = __webpack_require__(/*! ./default/components/ace/Ace */ "./content/default/components/ace/Ace.js"); /* harmony import */ var _default_views_product_product_page__WEBPACK_IMPORTED_MODULE_11__ = __webpack_require__(/*! ./default/views/product/product_page */ "./content/default/views/product/product_page.js"); /* harmony import */ var _default_blocks_newsletters_newsletter__WEBPACK_IMPORTED_MODULE_12__ = __webpack_require__(/*! ./default/blocks/newsletters/newsletter */ "./content/default/blocks/newsletters/newsletter.js"); /* harmony import */ var _default_views_product_filter__WEBPACK_IMPORTED_MODULE_13__ = __webpack_require__(/*! ./default/views/product/filter */ "./content/default/views/product/filter.js"); /* harmony import */ var _default_components_style_advisor_styleadvisor__WEBPACK_IMPORTED_MODULE_14__ = __webpack_require__(/*! ./default/components/style_advisor/styleadvisor */ "./content/default/components/style_advisor/styleadvisor.js"); /* harmony import */ var _default_views_brand_brandsearch__WEBPACK_IMPORTED_MODULE_15__ = __webpack_require__(/*! ./default/views/brand/brandsearch */ "./content/default/views/brand/brandsearch.js"); /* harmony import */ var _default_views_product_wishlist__WEBPACK_IMPORTED_MODULE_16__ = __webpack_require__(/*! ./default/views/product/wishlist */ "./content/default/views/product/wishlist.js"); /* harmony import */ var _default_views_mypages_reservation__WEBPACK_IMPORTED_MODULE_17__ = __webpack_require__(/*! ./default/views/mypages/reservation */ "./content/default/views/mypages/reservation.js"); /* harmony import */ var vanilla_lazyload__WEBPACK_IMPORTED_MODULE_18__ = __webpack_require__(/*! vanilla-lazyload */ "./node_modules/vanilla-lazyload/dist/lazyload.min.js"); /* harmony import */ var vanilla_lazyload__WEBPACK_IMPORTED_MODULE_18___default = /*#__PURE__*/ __webpack_require__.n(vanilla_lazyload__WEBPACK_IMPORTED_MODULE_18__); /* harmony import */ var _default_components_mystyle__WEBPACK_IMPORTED_MODULE_19__ = __webpack_require__(/*! ./default/components/mystyle */ "./content/default/components/mystyle.js"); /* harmony import */ var _default_views_product_simple_slider__WEBPACK_IMPORTED_MODULE_20__ = __webpack_require__(/*! ./default/views/product/simple_slider */ "./content/default/views/product/simple_slider.js"); /* harmony import */ var _default_blocks_productlists_recentlyviewed_js__WEBPACK_IMPORTED_MODULE_21__ = __webpack_require__(/*! ./default/blocks/productlists/recentlyviewed.js */ "./content/default/blocks/productlists/recentlyviewed.js"); /* harmony import */ var _default_blocks_productlists_styleview_js__WEBPACK_IMPORTED_MODULE_22__ = __webpack_require__(/*! ./default/blocks/productlists/styleview.js */ "./content/default/blocks/productlists/styleview.js"); /* harmony import */ var _default_views_checkout_checkout__WEBPACK_IMPORTED_MODULE_23__ = __webpack_require__(/*! ./default/views/checkout/checkout */ "./content/default/views/checkout/checkout.js"); /* harmony import */ var _default_components_size_and_fit_sizeAndFit__WEBPACK_IMPORTED_MODULE_24__ = __webpack_require__(/*! ./default/components/size_and_fit/sizeAndFit */ "./content/default/components/size_and_fit/sizeAndFit.js"); /* harmony import */ var _default_app_scss__WEBPACK_IMPORTED_MODULE_25__ = __webpack_require__(/*! ./default/app.scss */ "./content/default/app.scss"); // handle scss class App { constructor() { this.liveEvent(); this.init(); this.header = new _default_components_organisms_header_header__WEBPACK_IMPORTED_MODULE_2__["default"](); this.checkout = new _default_views_checkout_checkout__WEBPACK_IMPORTED_MODULE_23__["default"](); this.accordion = new _default_components_organisms_accordion__WEBPACK_IMPORTED_MODULE_1__["default"](); this.cart = new _default_components_molecules_cart_cart__WEBPACK_IMPORTED_MODULE_3__["default"](); this.login = new _default_components_molecules_login_login__WEBPACK_IMPORTED_MODULE_5__["default"](); this.grid = new _default_abstracts_grid_grid__WEBPACK_IMPORTED_MODULE_4__["default"](); this.nav = new _default_components_atoms_Navigation_main_navigation__WEBPACK_IMPORTED_MODULE_6__["default"](); this.search = new _default_blocks_search_search__WEBPACK_IMPORTED_MODULE_7__["default"](); this.toplist = new _default_components_molecules_toplist_toplist__WEBPACK_IMPORTED_MODULE_9__["default"](); this.countryPicker = new _default_blocks_country_picker_country_picker__WEBPACK_IMPORTED_MODULE_8__["default"](); this.recently_viewed = new _default_blocks_productlists_recentlyviewed_js__WEBPACK_IMPORTED_MODULE_21__["default"](); this.styleview = new _default_blocks_productlists_styleview_js__WEBPACK_IMPORTED_MODULE_22__["default"](); this.product_page = new _default_views_product_product_page__WEBPACK_IMPORTED_MODULE_11__["default"](this.cart); this.wishlist = new _default_views_product_wishlist__WEBPACK_IMPORTED_MODULE_16__["default"](this.cart); this.reservation = new _default_views_mypages_reservation__WEBPACK_IMPORTED_MODULE_17__["default"](this.cart); this.filter = new _default_views_product_filter__WEBPACK_IMPORTED_MODULE_13__["default"](); this.ajaxify = new _default_views_product_ajaxify__WEBPACK_IMPORTED_MODULE_0__["default"](this.product_page,this.nav,this.filter); this.style_advisor = new _default_components_style_advisor_styleadvisor__WEBPACK_IMPORTED_MODULE_14__["default"](); this.brand_search = new _default_views_brand_brandsearch__WEBPACK_IMPORTED_MODULE_15__["default"](); this.ace = new _default_components_ace_Ace__WEBPACK_IMPORTED_MODULE_10__["default"](); this.mystyle = new _default_components_mystyle__WEBPACK_IMPORTED_MODULE_19__["default"](); this.newsletter = new _default_blocks_newsletters_newsletter__WEBPACK_IMPORTED_MODULE_12__["default"](); this.size_and_fit = new _default_components_size_and_fit_sizeAndFit__WEBPACK_IMPORTED_MODULE_24__["default"](); const smoothScrollToAnchor = (anchor) => { const {top} = document.querySelector(anchor).getBoundingClientRect(); const startPosition = window.pageYOffset; const distance = top - startPosition; const duration = 1000; let start = null; const step = (timestamp) => { if (!start) start = timestamp; const progress = timestamp - start; window.scrollTo(0, easeInOutCubic(progress, startPosition, distance, duration)); if (progress < duration) window.requestAnimationFrame(step); } ; window.requestAnimationFrame(step); } ; const easeInOutCubic = (t, b, c, d) => { t /= d / 2; return t < 1 ? (c / 2) * t * t * t + b : (c / 2) * ((t -= 2) * t * t + 2) + b; } ; window.liveEvent('.smoothAnchor', 'click', (event, element) => { event.preventDefault(); const target = element.dataset.scrolltarget; smoothScrollToAnchor(target); } ); function showTooltip(elementWrapper, tooltip) { elementWrapper.onmousemove = function(e) { var x = e.clientX , y = e.clientY; tooltip.style.top = y + 15 + 'px'; if (tooltip.classList.contains('position-right')) { tooltip.style.left = x - 120 + 'px'; } else { tooltip.style.left = x + 15 + 'px'; } if (/Android|webOS|iPhone|iPad|iPod|BlackBerry/i.test(navigator.userAgent)) { tooltip.classList.add('active'); setTimeout( () => { tooltip.classList.remove('active'); } , 3000); } else { tooltip.classList.add('active'); } } ; elementWrapper.onmouseout = function(e) { tooltip.classList.remove('active'); } ; } document.querySelectorAll('.tooltip-span').forEach( (tooltip) => { const parent = tooltip.parentNode; showTooltip(parent, tooltip); } ); const backdrop = document.querySelector('.backdrop'); // Preowned info toggle let preownedInfo = document.querySelector('#testJJ'); let preownedInfoBtn = document.querySelector('.modal a'); if (preownedInfoBtn) { preownedInfoBtn.addEventListener('click', function() { preownedInfo.classList.add('active'); backdrop.classList.add('active'); }); } let video = document.querySelector('video'); let videoElements = document.querySelectorAll('video, .videoInfoWrapper'); let videoWrapper = document.querySelector('.video'); if (videoElements) { videoElements.forEach( (element) => { element.addEventListener('click', function() { if (video.paused) { video.play(); } else { video.pause(); } videoWrapper.classList.toggle('playing'); videoWrapper.classList.add('started'); }); } ); } /* Fredrik special för egenskaper */ var products = document.querySelectorAll('.product--group .big img:not(.product__img--hover)'); products.forEach(myFunction); function myFunction(item, index, arr) { item.src = item.src.replace('.jpg', '_2.jpg').replace('artiklar/', 'artiklar/zoom/'); } const target = document.querySelector('.menu__categories'); const close = document.querySelectorAll('.close'); if (target) { target.addEventListener('mouseover', mOver, false); target.addEventListener('mouseout', mOut, false); } function mOver(event) { if (event.target.closest('.has__children, .brandsLink')) { document.body.classList.add('activeNav'); backdrop.classList.add('active'); } } function mOut() { const clicked = document.querySelector('.reload'); if (clicked) { clicked.classList.remove('reload'); } backdrop.classList.remove('active'); document.body.classList.remove('activeNav'); } const kundradgivning = document.querySelector('.kundradgivning'); if (kundradgivning) { window.liveEvent('.header__customerservice', 'click', (event, element) => { kundradgivning.classList.add('active'); backdrop.classList.add('active'); document.body.classList.add('fullbackdrop'); } ); const kundradgivningClose = document.querySelector('.kundradgivning .close'); if (kundradgivningClose) { kundradgivningClose.addEventListener('click', () => { kundradgivning.classList.remove('active'); backdrop.classList.remove('active'); document.body.classList.remove('fullbackdrop'); } ); } } const modalSlideOut = document.querySelector('#modal_area'); if (modalSlideOut) { window.liveEvent('.modalTrigger', 'click', (event, element) => { // Get the data-header and data-content attributes from the clicked element const headerText = element.getAttribute('data-header'); const contentText = element.getAttribute('data-content'); // Find the modal header and content elements const modalHeader = modalSlideOut.querySelector('.modal__header h2'); const modalContent = modalSlideOut.querySelector('.modal__content'); // Update the modal header and content with the new text if (modalHeader) { modalHeader.textContent = headerText; } if (modalContent) { modalContent.innerHTML = contentText; } if (contentText && contentText.includes('lipscore')) { lipscore.initWidgets(); } // Add the active class to the modal and backdrop modalSlideOut.classList.add('active'); if (backdrop) { backdrop.classList.add('active'); document.body.classList.add('fullbackdrop'); } } ); const modalSlideOutClose = document.querySelector('#modal_area .close'); if (modalSlideOutClose) { modalSlideOutClose.addEventListener('click', () => { modalSlideOut.classList.remove('active'); backdrop.classList.remove('active'); document.body.classList.remove('fullbackdrop'); } ); } } const sizeNFit = document.getElementById('sizeandfit'); const styleadvisor = document.getElementById('styleadvisor'); const login_form = document.getElementById('login-wrapper'); const cart = document.querySelector('#air-cart'); backdrop.addEventListener('click', function() { document.body.style.overflow = ''; cart.classList.remove('active'); document.body.classList.remove('cart-open'); document.body.classList.remove('fullbackdrop'); backdrop.classList.remove('active'); if (document.querySelector('.page--settings--wrapper')) { document.querySelector('.page--settings--wrapper').classList.remove('--active'); } backdrop.classList.remove('filter-open'); if (document.querySelector('#header .header__search #suggest-area.active')) { document.querySelector('#header .header__search #suggest-area.active').style.maxHeight = '0px'; } if (styleadvisor.classList.contains('active') && typeof _imbox !== 'undefined') { _imbox.push(['showLauncher']); } if (sizeNFit && sizeNFit.classList.contains('active')) { sessionStorage.clear(); sessionStorage.setItem('snf_step', '1'); sizeNFit.classList.remove('from-pdp'); sizeNFit.classList.remove('active'); document.body.classList.remove('sizeandfit-open'); } login_form.classList.remove('active'); kundradgivning.classList.remove('active'); styleadvisor.classList.remove('active'); document.body.classList.remove('styleadvisor'); document.getElementById('suggest-result').style.display = 'none'; document.getElementById('suggest-init').style.display = 'none'; if (sessionStorage) { this.test_completed = sessionStorage.getItem('test_completed'); if (this.test_completed && this.test_completed !== '') { location.reload(); sessionStorage.setItem('test_completed', ''); } } }); close.forEach( (element) => { element.addEventListener('click', function() { document.body.style.overflow = ''; backdrop.classList.remove('active'); if (cart) { cart.classList.remove('active'); } document.body.classList.remove('cart-open'); styleadvisor.classList.remove('active'); document.body.classList.remove('styleadvisor'); document.getElementById('suggest-result').style.display = 'none'; document.getElementById('suggest-init').style.display = 'none'; }); } ); } init() { this.lazyload(); // init sliders document.querySelectorAll('.snapping--wrapper').forEach(function(elem) { new _default_views_product_simple_slider__WEBPACK_IMPORTED_MODULE_20__["default"](elem); }); } lazyload() { window.lazyLoadInstance = new (vanilla_lazyload__WEBPACK_IMPORTED_MODULE_18___default())({ unobserve_entered: true, // <- Avoid executing the function multiple times callback_enter: this.executeLazyFunction // Assigning the function defined above }); window.lazyFunctions = {}; } executeLazyFunction(element) { var lazyFunctionName = element.getAttribute('data-lazy-function'); var lazyFunction = window.lazyFunctions[lazyFunctionName]; if (!lazyFunction) return; lazyFunction(element); } liveEvent() { window.liveEvent = (selector, event, handler) => { document.body.addEventListener(event, function(e) { var target = e.target; while (target != null) { var isMatch = target.matches(selector); if (isMatch) { handler(e, target); return; } target = target.parentElement; } }, true); } ; } } const app = new App(); } )(); /******/ } )(); //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"themes/hypefront/assets/app.js","mappings":";;;;;;;;;;;;;;;AACA;;AAEe;AACf;AACA;AACA;;AAEA;AACA;AACA,UAAU;AACV;AACA;;AAEA;AACA;;AAEA;;;;;;;;;;;;;;;ACjBe;AACf;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP,KAAK;AACL;AACA;AACA;;;;;;;;;;;;;;;;;ACfiD;;AAEjD;;AAEe;;AAEf;AACA;AACA;;AAEA;AACA;AACA;AACA,GAAG;;AAEH;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA,wDAAwD,IAAI;AAC5D;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,GAAG;;AAEH;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA,GAAG;;AAEH;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA,EAAE,4DAAS;;AAEX;AACA;AACA,GAAG;;AAEH;AACA;AACA,GAAG;AACH;AACA;;;;;;;;;;;;;;;;ACnGwE;;AAExE;AACA,+BAA+B;;AAEhB;;AAEf;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,cAAc;AACd;AACA;AACA,qDAAqD,iBAAiB;AACtE;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;;AAEA;AACA;;AAEA;;AAEA;;AAEA;;AAEA;AACA;AACA,IAAI;AACJ;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,qDAAqD,iBAAiB;AACtE;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA,SAAS,4EAAY;AACrB;AACA;AACA;AACA;AACA;;;;;;;;;;;;;;;;ACpG6D;;AAE9C;;AAEf;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA,QAAQ,oEAAY;AACpB;AACA;AACA;AACA;;;;;;;;;;;;;;;;AC9BA;AACA;AACA;AACA;;AAEe;AACf;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA,2EAA2E,kBAAkB;AAC7F,0EAA0E,cAAc;AACxF,iFAAiF,iBAAiB;AAClG;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;;AAEA;AACA,yFAAyF,oBAAoB,uBAAuB;AACpI;;AAEA;AACA;AACA,KAAK;AACL;;AAEA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA,MAAM;AACN;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,MAAM;AACN;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,KAAK;AACL;;AAEA;AACA,oCAAoC;AACpC;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA,oBAAoB,2BAA2B;AAC/C;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA,4BAA4B,gBAAgB;AAC5C,QAAQ;AACR;AACA,wBAAwB,2BAA2B;AACnD;AACA;AACA;AACA;AACA;AACA,iCAAiC,gBAAgB;;AAEjD;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;;;;;;;;;AC7Ne;;AAEf;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA,aAAa;AACb;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;;;;;;;;AC1Ce;;AAEf;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA,oBAAoB,oBAAoB;AACxC,mDAAmD,wBAAwB;AAC3E;;AAEA;AACA,oBAAoB,yBAAyB;AAC7C,wDAAwD,wBAAwB;AAChF;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA,kDAAkD,6BAA6B;AAC/E,KAAK;;AAEL;AACA,kDAAkD,6BAA6B;AAC/E,KAAK;AACL;;AAEA;AACA,oBAAoB,0BAA0B;AAC9C;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,kCAAkC,qBAAqB;AACvD;;AAEA;AACA,oBAAoB,0BAA0B;AAC9C;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;;;;;;;;AC3G+D;;AAE/D;AACA,wBAAwB;;AAET;;AAEf;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA,aAAa,4DAAS;AACtB;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA,UAAU;AACV;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA,UAAU;AACV;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,SAAS;;AAET;;AAEA;AACA;AACA;;AAEA;AACA,gCAAgC,uBAAuB;AACvD;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA,iBAAiB;AACjB;AACA,UAAU;AACV;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;;AAEA;AACA;AACA,UAAU;AACV;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA,SAAS;;AAET;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,SAAS;;AAET;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,UAAU;AACV;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,SAAS;;AAET;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;;AAEb;AACA;AACA,UAAU;AACV;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;;AAEA;;AAEA;;AAEA;AACA;AACA,UAAU;AACV;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,4DAA4D,sBAAsB;AAClF,qBAAqB,mBAAmB;AACxC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;;AAET;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;;AAEA,+CAA+C,OAAO;AACtD;AACA;AACA;AACA;AACA,cAAc;AACd,2CAA2C,OAAO;AAClD;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,2BAA2B,iBAAiB;AAC5C;AACA;AACA,wCAAwC,mBAAmB;AAC3D;AACA;AACA,gDAAgD,kBAAkB;AAClE,gDAAgD,qBAAqB,EAAE,WAAW,EAAE,qBAAqB;AACzG;AACA;AACA;AACA,0CAA0C,YAAY;AACtD;;AAEA;AACA,gBAAgB,4DAAS;AACzB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;;;;;;;;;;AC9Xe;AACf;AACA;AACA;AACA;AACA;AACA;AACA;AACA,sCAAsC;AACtC;AACA;;AAEA;AACA;AACA,mCAAmC;AACnC;;AAEA;AACA;;AAEA;AACA;AACA;AACA,gFAAgF,oBAAoB;AACpG,6FAA6F,qBAAqB,oBAAoB;AACtI,kFAAkF,oBAAoB,eAAe;AACrH;AACA;AACA,SAAS;AACT;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA,wCAAwC;AACxC,UAAU;AACV;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;;AAEA;;AAEA;AACA;AACA;AACA,SAAS;;AAET;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,cAAc;AACd;AACA;AACA;AACA,UAAU;AACV;AACA;AACA;;AAEA;AACA;AACA,yCAAyC;AACzC;AACA;AACA,+BAA+B,+BAA+B,QAAQ;AACtE;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,yCAAyC;AACzC;AACA;AACA,SAAS;;AAET;AACA;AACA;AACA;AACA;;;;;;;;;;;;;;;;;;ACxIA;;AAEe;AACf;AACA;;AAEA;AACA;AACA,MAAM;AACN;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;;;;;;;;;;;;;;;;ACjBe;;AAEf;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,GAAG;;AAEH;AACA;AACA;AACA,8DAA8D,6BAA6B;AAC3F;AACA;AACA;AACA,MAAM;AACN;AACA;AACA,GAAG;AACH;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG,EAAE;;AAEL;AACA;AACA,GAAG;;AAEH,6DAA6D,6BAA6B;;AAE1F;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA,GAAG;AACH;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;;AAEH;AACA;AACA;AACA;;;;;;;;;;;;;;;ACxFe;AACf;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,6BAA6B;AAC7B;AACA;AACA,qBAAqB;AACrB;AACA;AACA;AACA,aAAa;AACb;;AAEA;;AAEA;AACA;;;;;;;;;;;;;;;AC5Be;AACf;AACA;AACA;;AAEA;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA,QAAQ;AACR;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,QAAQ;AACR;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,QAAQ;AACR;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;;;;;;;;;;;;;;;;ACrEe;AACf;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,2CAA2C;;AAE3C;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA,IAAI;;AAEJ;AACA;AACA;AACA;AACA;AACA,IAAI;;AAEJ;AACA;AACA;AACA;AACA;AACA;AACA,IAAI;;;;AAIJ;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,IAAI;AACJ,GAAG;;AAEH;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,MAAM;AACN;AACA;AACA,IAAI;AACJ,GAAG;AACH;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA,OAAO;AACP;AACA;AACA,KAAK;AACL,IAAI;AACJ;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;;AAEA;AACA;AACA,MAAM;AACN;AACA,MAAM;AACN;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA,KAAK;AACL;AACA;;AAEA;AACA,GAAG;AACH;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA,IAAI;AACJ;AACA;AACA;AACA,IAAI;AACJ;AACA;AACA;AACA,IAAI;AACJ;AACA;AACA;AACA,IAAI;AACJ;AACA;AACA;;AAEA;AACA,IAAI;AACJ;AACA;AACA;AACA,IAAI;AACJ;AACA;AACA;AACA;AACA,IAAI;AACJ;AACA;AACA;AACA;AACA,IAAI;AACJ;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,GAAG;AACH;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA,0BAA0B,cAAc;AACxC;;AAEA,4CAA4C,KAAK,WAAW,KAAK,WAAW,OAAO,WAAW,OAAO,EAAE,MAAM;;AAE7G;AACA;AACA;;;;AAIA,2CAA2C,WAAW;AACtD;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA,MAAM;AACN;AACA,MAAM;AACN;AACA;AACA,MAAM;AACN;AACA,MAAM;AACN;AACA;AACA,MAAM;AACN;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA,QAAQ;AACR;AACA;AACA;AACA;AACA;AACA,IAAI;AACJ,GAAG;AACH;AACA;AACA,GAAG;AACH;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA,IAAI;AACJ,GAAG;AACH;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,GAAG;AACH;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;;AAEA,8BAA8B,EAE1B,CAAC;AACL,2BAA2B,SAAS;AACpC;AACA;AACA,6FAA6F,MAAM;AACnG;AACA;AACA;AACA;AACA,IAAI;;;AAGJ;AACA;AACA;AACA,oCAAoC,6BAA6B;AACjE;AACA,aAAa;AACb;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,QAAQ;AACR;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;;AAEL;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,mCAAmC;AACnC,MAAM;AACN;AACA;AACA,mCAAmC;AACnC,MAAM;AACN;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;;AAEA;AACA,IAAI;AACJ;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA,IAAI;AACJ,KAAK;AACL;AACA;AACA;;;;;;;;;;;;;;;;;AC/kB6D;;AAE7D;AACA;AACA;AACA;AACA;AACA;AACe;AACf;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,gBAAgB,oEAAY;AAC5B,WAAW;AACX;AACA;AACA,KAAK;;AAEL;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,cAAc,oEAAY;AAC1B;AACA;AACA,KAAK;;AAEL;AACA;AACA;;AAEA;AACA;AACA,OAAO;AACP;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,OAAO;;AAEP;AACA;AACA,KAAK;;AAEL;AACA;AACA,KAAK;;AAEL;AACA;AACA;AACA,KAAK;;AAEL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;;AAEL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,sCAAsC,yFAAyF;AAC/H;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,KAAK;;AAEL;AACA;AACA;AACA;AACA;AACA,QAAQ;AACR;AACA;AACA,QAAQ;;AAER;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,QAAQ;AACR;AACA;AACA,KAAK;;AAEL;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;;AAEL;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;;AAEL;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA,KAAK;;AAEL;AACA;AACA;AACA,KAAK;;AAEL;AACA;AACA;AACA,KAAK;;AAEL;AACA;AACA,iEAAiE,IAAI;AACrE;AACA;AACA;AACA;AACA,QAAQ;AACR;AACA;AACA,KAAK;AACL;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,MAAM;AACN;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,WAAW;;AAEX;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,0CAA0C,mEAAmE;AAC7G;AACA;AACA;AACA;AACA,0CAA0C,+HAA+H;AACzK;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,aAAa;AACb;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,MAAM;AACN;AACA;AACA;;AAEA;AACA;AACA,MAAM;AACN,qEAAqE;AACrE;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,KAAK;AACL;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;;AAEA;AACA;AACA;AACA,KAAK;;AAEL;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,MAAM;AACN;AACA;AACA;AACA;;AAEA;AACA;;AAEA;;AAEA;AACA;AACA;AACA,KAAK;;AAEL;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;;AAEH;AACA;AACA;AACA,kCAAkC,4FAA4F;AAC9H;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA,MAAM;AACN;AACA;;AAEA;AACA,2BAA2B,+EAA+E;AAC1G;AACA,GAAG;;AAEH;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA,GAAG;;AAEH;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,UAAU;AACV;AACA;AACA,OAAO;AACP;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;;AAEL;AACA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA,wBAAwB,4BAA4B;AACpD;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;;AAEA;AACA;AACA,KAAK;AACL;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA,oBAAoB,4BAA4B;AAChD;;AAEA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;;AAEA;;AAEA;AACA;AACA;AACA,SAAS;AACT,OAAO;;AAEP;AACA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA,OAAO;;AAEP;AACA;;AAEA;;AAEA;AACA;AACA,SAAS;;AAET;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,MAAM;AACN;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;;AAEL;AACA;;AAEA;AACA;AACA;AACA;AACA,oCAAoC,oHAAoH;AACxJ,MAAM;AACN;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;;;;;;;;;;;;;;;;;;;;ACz5BO;AACP;AACA;;AAEA;;AAEA;AACA;AACA,6EAA6E,gBAAgB,EAAE,aAAa,EAAE,cAAc,EAAE,gBAAgB;AAC9I,+EAA+E,gBAAgB,EAAE,aAAa,EAAE,MAAM,EAAE,gBAAgB;AACxI,MAAM;AACN,uEAAuE,gBAAgB,EAAE,aAAa,EAAE,MAAM,EAAE,gBAAgB;AAChI;AACA;;AAEA;AACA,+CAA+C,EAAE;AACjD;AACA;;AAEO;AACP;AACA,oBAAoB,oBAAoB;AACxC;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEO;AACP,4CAA4C;;AAE5C,oBAAoB,sBAAsB;AAC1C;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEO;AACP;;AAEA;AACA;AACA;AACA;AACA;;AAEO;AACP;AACA;AACA;;AAEO;AACP;;AAEA;;AAEA;;AAEA;;AAEA;AACA;AACA,MAAM;AACN;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;;;;;;;;;;;;;;;ACvGe;;AAEf;AACA;AACA;;AAEA;AACA,wEAAwE,oEAAoE;AAC5I,0EAA0E,wDAAwD;AAClI;AACA;AACA,GAAG;AACH;;AAEA;AACA;AACA;AACA;AACA;AACA,IAAI;;AAEJ;AACA;AACA,IAAI;AACJ;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;;AAET;AACA;AACA,IAAI;AACJ;AACA;AACA,IAAI;AACJ;AACA;AACA;AACA;AACA;AACA,IAAI;AACJ;AACA;;AAEA;AACA;AACA;AACA,GAAG;;AAEH;AACA;AACA,GAAG;;AAEH;AACA;AACA,GAAG;;AAEH;AACA;AACA,GAAG;AACH;;AAEA;AACA;;AAEA;AACA;;;;;;;;;;;;;;;ACtEe;AACf;AACA;;;;;;;;;;;;;;;ACFe;;AAEf;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,IAAI;AACJ,GAAG;AACH;AACA;;;;;;;;;;;;;;;;;;;ACpB6D;AACV;AACe;;AAEnD;AACf;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,MAAM;AACN;AACA;AACA;AACA,GAAG;;AAEH;;AAEA;AACA;;;AAGA;AACA;;AAEA;AACA;AACA;AACA,IAAI;AACJ,GAAG;;AAEH;AACA;AACA;AACA;AACA;AACA;AACA;AACA,IAAI;AACJ,GAAG;;AAEH;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL,IAAI;;AAEJ;AACA;AACA;AACA;AACA;AACA;AACA;AACA,oBAAoB;AACpB;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;;AAEH;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;;AAEH;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA,MAAM;AACN;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;;AAEH;AACA;AACA,GAAG;;AAEH;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL,KAAK;AACL;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA,IAAI;AACJ;AACA,IAAI;AACJ;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;;AAEA;;AAEA;AACA;AACA;AACA,iCAAiC;AACjC,IAAI;AACJ;AACA;AACA,IAAI;AACJ;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,GAAG;;AAEH;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA,KAAK;AACL,IAAI;AACJ;AACA;;AAEA;AACA;AACA;AACA,GAAG;AACH;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA;;AAEA;AACA;AACA,GAAG;;AAEH,EAAE,4DAAS;;AAEX;AACA;AACA;AACA;AACA,IAAI;AACJ;;AAEA;AACA;AACA,IAAI;AACJ,IAAI;AACJ;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;;AAEA;AACA;AACA;AACA,GAAG;;AAEH;AACA;AACA;AACA;;AAEA;AACA;AACA,GAAG;AACH;;AAEA;AACA;AACA;AACA;AACA;AACA,EAAE,4DAAS;AACX;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA,GAAG;AACH;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,OAAO,oEAAY;AACnB,GAAG;;AAEH;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,MAAM;AACN;AACA;AACA;AACA;AACA,IAAI;AACJ,GAAG;AACH;AACA;AACA;AACA;AACA;AACA;AACA;AACA,IAAI;AACJ;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;;;;;;;;;ACzfyD;;AAE1C;;AAEf;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,cAAc;AACd;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA,sBAAsB;AACtB;AACA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA,6BAA6B,kEAAe;AAC5C;AACA;AACA;;;;;;;;;;;;;;;;;AC/F+E;AAChE;;AAEf;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA,4BAA4B,6DAAU;AACtC;AACA;;AAEA;AACA;AACA;AACA,MAAM;AACN;AACA;AACA,IAAI;AACJ;;AAEA;AACA;AACA;AACA;AACA,KAAK;AACL;;AAEA;AACA;AACA;AACA,KAAK,8DAAU;AACf,MAAM;AACN;AACA;AACA,KAAK,iEAAa;AAClB;AACA,IAAI;AACJ,GAAG;;AAEH;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,QAAQ;AACR;AACA,MAAM;AACN,KAAK;AACL,IAAI;AACJ,GAAG;;;AAGH;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,IAAI;AACJ,GAAG;;AAEH;AACA;AACA,GAAG;;AAEH;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,MAAM;AACN,IAAI;AACJ,GAAG;;AAEH;AACA;AACA,GAAG;;AAEH;;AAEA;AACA,gDAAgD,oBAAoB,YAAY;AAChF,GAAG;;AAEH;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;AACA;AACA;AACA,IAAI;AACJ,GAAG;;AAEH;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA,KAAK;AACL;;AAEA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA,KAAK;;AAEL;AACA;AACA;AACA;AACA;AACA,KAAK;AACL,IAAI;AACJ,GAAG;;AAEH;AACA,gDAAgD,oCAAoC;AACpF,GAAG;;AAEH;AACA;;AAEA;AACA;AACA;AACA,IAAI;;AAEJ;;AAEA;AACA;AACA;AACA,IAAI;AACJ,GAAG;;AAEH;AACA;AACA,GAAG;AACH;;AAEA;AACA;;AAEA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;;AAEH;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA,GAAG;AACH;;AAEA;AACA;;AAEA;AACA;;AAEA;;AAEA;AACA;;AAEA;AACA,uCAAuC;AACvC;;AAEA;AACA;AACA;AACA;AACA,IAAI;AACJ;AACA,GAAG;;AAEH;AACA,iDAAiD;AACjD;AACA;;AAEA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,GAAG;;AAEH;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,IAAI;AACJ;AACA;AACA,IAAI;;AAEJ;;AAEA;AACA;;AAEA;AACA,oBAAoB,YAAY;AAChC;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,IAAI;AACJ,GAAG;;AAEH;AACA;;AAEA;AACA;AACA;AACA,GAAG;AACH;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA,IAAI;AACJ,GAAG;AACH;;AAEA;AACA,gDAAgD,6FAA6F,aAAa;AAC1J,GAAG;;AAEH;AACA;AACA;AACA,GAAG;AACH;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA,GAAG;;AAEH;AACA;AACA,GAAG;AACH;;AAEA;AACA;AACA;;AAEA;;AAEA;AACA;;AAEA;AACA;AACA;AACA,IAAI;AACJ,GAAG;;AAEH;AACA;;AAEA;AACA;;AAEA;AACA;AACA,GAAG;;AAEH;AACA;AACA;AACA;AACA;;AAEA,2DAA2D,KAAK;AAChE;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,oBAAoB,6BAA6B;AACjD;AACA,sBAAsB,4BAA4B;AAClD,IAAI;AACJ,GAAG;AACH;;AAEA;AACA;;AAEA,uCAAuC;;AAEvC;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA,GAAG;;AAEH;AACA;;AAEA;AACA;AACA;AACA;AACA,IAAI;AACJ;AACA;AACA;AACA;AACA,IAAI;;AAEJ;AACA;AACA,IAAI;;AAEJ;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;;;;;;;;;;;ACvhB6C;AACD;AACd;;AAEf;AACf;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA,4BAA4B,4DAAS;AACrC,MAAM;AACN,wBAAwB,uDAAa;AACrC;;AAEA;AACA;AACA;AACA,OAAO;AACP;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA;;AAEA;AACA;AACA;AACA,OAAO;AACP;;AAEA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA,QAAQ;AACR;AACA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;;AAEA;AACA,2BAA2B,oDAAoD;AAC/E;;AAEA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA,sBAAsB;AACtB;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,oCAAoC,aAAa;AACjD,oCAAoC,YAAY;AAChD;AACA,uEAAuE,iBAAiB,WAAW,WAAW;AAC9G;AACA;AACA;AACA;AACA;AACA;AACA,kBAAkB;AAClB;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;;AAEA;AACA;AACA;AACA,SAAS;AACT;;AAEA;AACA;AACA,OAAO;AACP;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,OAAO;;AAEP;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA,OAAO;AACP;AACA;AACA;;AAEA;AACA;AACA,OAAO;AACP;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA,KAAK;;AAEL,4BAA4B,sBAAsB;AAClD;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,QAAQ;AACR;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA,KAAK;AACL;;AAEA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA,YAAY,8CAAS;AACrB;AACA;AACA;AACA,SAAS;AACT;AACA,KAAK;;AAEL;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA,SAAS;AACT;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA,KAAK;;AAEL;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;;;;;;;;;;AC7be;;AAEf;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;;AAEA;AACA,+BAA+B;AAC/B,iCAAiC;;AAEjC;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA,KAAK;AACL,gDAAgD,2BAA2B;AAC3E;AACA;AACA;AACA;AACA;AACA,KAAK;AACL,gDAAgD,0BAA0B;AAC1E;AACA;;AAEA;AACA;AACA;AACA;AACA,GAAG;;AAEH,2DAA2D,uBAAuB;AAClF,6DAA6D,uBAAuB;AACpF;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA,4DAA4D,4CAA4C;AACxG,2DAA2D,+CAA+C;AAC1G,6DAA6D,4CAA4C;AACzG,2DAA2D,+CAA+C;AAC1G;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA,IAAI;AACJ;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;;AAEA;AACA,6DAA6D,SAAS,QAAQ;AAC9E,IAAI;AACJ,6DAA6D,SAAS,QAAQ;AAC9E;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA,IAAI;AACJ;AACA;AACA;;AAEA;;AAEA;AACA;;AAEA;AACA,6BAA6B;;AAE7B;AACA;AACA;;AAEA;AACA;AACA;;;;;;;;;;;;;;;;;ACzN0D;AAC3C;;AAEf;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,qCAAqC;;AAErC;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA,aAAa;;AAEb;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,SAAS;;AAET,4DAA4D,wBAAwB;AACpF;AACA;AACA;AACA,mDAAmD,mCAAmC;AACtF;AACA;;;AAGA;AACA;AACA;AACA;AACA,UAAU;AACV;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA,kCAAkC;AAClC;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA,oEAAoE;AACpE;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA,cAAc;AACd;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,kFAAkF,gBAAgB,cAAc,WAAW;AAC3H;AACA;AACA;AACA;AACA,4DAA4D;AAC5D,kBAAkB;AAClB;AACA;AACA,cAAc;AACd;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,4DAA4D;AAC5D;AACA,qBAAqB;AACrB,iBAAiB;AACjB;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb,SAAS;;AAET;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,4DAA4D,wBAAwB;AACpF;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,UAAU;AACV;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,gDAAgD;AAChD;AACA;AACA;;AAEA;AACA;AACA;AACA;;;AAGA;AACA;AACA;AACA;AACA,cAAc;AACd;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;;;;;;;;;AC9PiD;;AAEjD;AACA,wBAAwB;AACxB;;AAEe;;AAEf;AACA;AACA;AACA;AACA;;AAEA;AACA,OAAO,4DAAS;AAChB;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA,IAAI;AACJ,GAAG;;AAEH;;AAEA;AACA;AACA,IAAI;AACJ;AACA;AACA;;AAEA;AACA;AACA;AACA,GAAG;;AAEH;AACA;AACA,GAAG;;AAEH;AACA;AACA,GAAG;AACH;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;;AAEA;;AAEA;;AAEA;AACA;AACA,IAAI;AACJ;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;;AAEH;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;;AAEH;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,GAAG;;AAEH;AACA;AACA;AACA;AACA;AACA;AACA,IAAI;;AAEJ;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;;;ACjLA;AACA,QAAQ,KAA6B;AACrC;AACA,MAAM;AACN;AACA;AACA,CAAC;AACD;AACA,eAAe,QAAQ;AACvB,eAAe,QAAQ;AACvB;AACA;AACA;AACA;AACA;AACA,8BAA8B,qCAAqC;AACnE;AACA,6FAA6F,wBAAwB;AACrH;AACA,4FAA4F,wBAAwB;AACpH;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,wBAAwB;AACxB;AACA,oBAAoB;AACpB;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,cAAc;AACd;AACA;AACA,cAAc;AACd;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,cAAc;AACd;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,cAAc;AACd;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,cAAc;AACd;AACA;;;;AAIA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;;AAGA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,cAAc;AACd;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,kFAAkF,4BAA4B,eAAe;;AAE7H;AACA,aAAa;AACb;AACA;AACA;;AAEA,aAAa;AACb;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA,UAAU;AACV;AACA;AACA;;AAEA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,CAAC;;;;;;;;;;;;AC5VD;;;;;;;;;;;ACAA,eAAe,KAAoD,oBAAoB,CAAkH,CAAC,kBAAkB,aAAa,aAAa,oCAAoC,YAAY,mBAAmB,KAAK,mBAAmB,sEAAsE,SAAS,yBAAyB,6QAA6Q,wqBAAwqB,eAAe,WAAW,MAAM,iBAAiB,2CAA2C,IAAI,qBAAqB,QAAQ,YAAY,EAAE,SAAS,iEAAiE,WAAW,EAAE,wBAAwB,sKAAsK,2BAA2B,eAAe,cAAc,iBAAiB,uBAAuB,uBAAuB,kDAAkD,QAAQ,eAAe,iBAAiB,eAAe,mBAAmB,eAAe,gBAAgB,iCAAiC,gDAAgD,iBAAiB,yDAAyD,iBAAiB,uIAAuI,eAAe,qBAAqB,iBAAiB,MAAM,kBAAkB,mBAAmB,iBAAiB,uBAAuB,iBAAiB,qBAAqB,eAAe,mBAAmB,gBAAgB,qCAAqC,SAAS,iBAAiB,mBAAmB,0CAA0C,iBAAiB,gBAAgB,6CAA6C,aAAa,eAAe,YAAY,eAAe,mBAAmB,iBAAiB,UAAU,SAAS,uBAAuB,uBAAuB,WAAW,iBAAiB,SAAS,WAAW,uBAAuB,iBAAiB,2CAA2C,WAAW,IAAI,mBAAmB,yFAAyF,mBAAmB,kEAAkE,mBAAmB,uBAAuB,iBAAiB,0EAA0E,IAAI,kBAAkB,iBAAiB,cAAc,iBAAiB,sBAAsB,8BAA8B,qBAAqB,iBAAiB,8BAA8B,oEAAoE,sBAAsB,+BAA+B,sDAAsD,gBAAgB,wBAAwB,iBAAiB,uBAAuB,4BAA4B,oBAAoB,0CAA0C,oBAAoB,2BAA2B,gBAAgB,qBAAqB,gBAAgB,UAAU,mBAAmB,gBAAgB,WAAW,UAAU,qBAAqB,oBAAoB,aAAa,qBAAqB,wBAAwB,sBAAsB,uDAAuD,oBAAoB,cAAc,uBAAuB,uBAAuB,EAAE,8CAA8C,0BAA0B,gBAAgB,mBAAmB,WAAW,yEAAyE,gBAAgB,eAAe,mBAAmB,WAAW,kGAAkG,gBAAgB,GAAG,oBAAoB,aAAa,+BAA+B,oBAAoB,aAAa,4CAA4C,0BAA0B,aAAa,wCAAwC,EAAE,oBAAoB,uDAAuD,oFAAoF,wBAAwB,mEAAmE,wCAAwC,wBAAwB,yBAAyB,MAAM,wCAAwC,iCAAiC,GAAG,qFAAqF,yCAAyC,+CAA+C,QAAQ,wBAAwB,0BAA0B,mBAAmB,qBAAqB,QAAQ,QAAQ,gBAAgB,+DAA+D,gBAAgB,iBAAiB,OAAO,UAAU,KAAK,0BAA0B,OAAO,mBAAmB,iBAAiB,OAAO,mBAAmB,oBAAoB,QAAQ,kBAAkB,aAAa,oBAAoB,mBAAmB,SAAS,WAAW,2CAA2C,IAAI,mBAAmB,wIAAwI,gBAAgB,4CAA4C,4DAA4D,oBAAoB,uBAAuB,mBAAmB,+CAA+C,sBAAsB,kBAAkB,0BAA0B,IAAI,wEAAwE,4BAA4B,+CAA+C,mCAAmC,6CAA6C,8BAA8B,gBAAgB,2CAA2C,iBAAiB,MAAM,SAAS,wEAAwE,oCAAoC,iBAAiB,GAAG,gBAAgB,qCAAqC,gBAAgB,yDAAyD,gBAAgB,mBAAmB,gBAAgB,IAAI,kBAAkB,mBAAmB,uBAAuB,WAAW,kBAAkB,WAAW,mDAAmD,8DAA8D,UAAU,cAAc,OAAO,wFAAwF,MAAM,uBAAuB,gCAAgC,eAAe,MAAM,gDAAgD,wBAAwB,cAAc,MAAM,qDAAqD,yBAAyB,qBAAqB,mBAAmB,mCAAmC,6CAA6C,uBAAuB,4CAA4C,yDAAyD,mBAAmB,UAAU,aAAa,QAAQ,UAAU,4BAA4B,eAAe,iCAAiC,uBAAuB,aAAa,GAAG,uBAAuB,oBAAoB,gJAAgJ,KAAK,2HAA2H,qBAAqB,4BAA4B,6BAA6B,iBAAiB,GAAG,uBAAuB,qBAAqB,2BAA2B,QAAQ,IAAI,uBAAuB,WAAW,QAAQ,4BAA4B,KAAK,kBAAkB,+BAA+B,OAAO,YAAY,YAAY,+BAA+B;;;;;;;UCAzrR;UACA;;UAEA;UACA;UACA;UACA;UACA;UACA;UACA;UACA;UACA;UACA;UACA;UACA;UACA;;UAEA;UACA;;UAEA;UACA;UACA;;;;;WCtBA;WACA;WACA;WACA;WACA;WACA,iCAAiC,WAAW;WAC5C;WACA;;;;;WCPA;WACA;WACA;WACA;WACA,yCAAyC,wCAAwC;WACjF;WACA;WACA;;;;;WCPA;;;;;WCAA;WACA;WACA;WACA,uDAAuD,iBAAiB;WACxE;WACA,gDAAgD,aAAa;WAC7D;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;ACNsD;AACW;AACC;AACN;AACX;AACc;AACS;AACpB;AACuB;AACN;AACtB;AACgB;AACE;AACb;AACuB;AACf;AACJ;AACM;AACtB;AACW;AACc;AACY;AACV;AACV;AACa;;AAEtE;AAC4B;;AAE5B;AACA;AACA;AACA;;AAEA,oBAAoB,mFAAM;AAC1B,sBAAsB,yEAAQ;AAC9B,uBAAuB,+EAAS;AAChC,kBAAkB,+EAAI;AACtB,mBAAmB,iFAAK;AACxB,kBAAkB,oEAAI;AACtB,iBAAiB,4FAAG;AACpB,oBAAoB,qEAAM;AAC1B,qBAAqB,qFAAO;AAC5B,2BAA2B,qFAAa;AACxC,6BAA6B,uFAAc;AAC3C,uBAAuB,kFAAS;AAChC,0BAA0B,4EAAW;AACrC,sBAAsB,wEAAQ;AAC9B,yBAAyB,2EAAW;AACpC,oBAAoB,sEAAM;AAC1B,qBAAqB,sEAAO;AAC5B,2BAA2B,uFAAY;AACvC,0BAA0B,yEAAW;AACrC,iBAAiB,oEAAG;AACpB,qBAAqB,oEAAO;AAC5B,wBAAwB,+EAAU;AAClC,0BAA0B,oFAAU;;AAEpC;AACA,WAAW,MAAM;AACjB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,GAAG;;AAEH;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,MAAM;AACN;AACA;AACA;AACA;AACA;AACA;AACA,MAAM;AACN,MAAM;AACN;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,GAAG;;AAEH;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,IAAI;AACJ;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA,KAAK;AACL,IAAI;AACJ;;AAEA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,IAAI;;AAEJ;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,IAAI;;AAEJ;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,IAAI;AACJ,GAAG;AACH;;AAEA;AACA;;AAEA;AACA;AACA,OAAO,6EAAY;AACnB,GAAG;AACH;;AAEA;AACA,gCAAgC,0DAAQ;AACxC;AACA;AACA,GAAG;AACH;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;;AAEA","sources":["webpack://content/./content/default/abstracts/grid/grid.js","webpack://content/./content/default/blocks/country-picker/country-picker.js","webpack://content/./content/default/blocks/newsletters/newsletter.js","webpack://content/./content/default/blocks/productlists/recentlyviewed.js","webpack://content/./content/default/blocks/productlists/styleview.js","webpack://content/./content/default/blocks/search/search.js","webpack://content/./content/default/components/ace/Ace.js","webpack://content/./content/default/components/atoms/Navigation/main-navigation.js","webpack://content/./content/default/components/molecules/cart/cart.js","webpack://content/./content/default/components/molecules/login/login.js","webpack://content/./content/default/components/molecules/toplist/toplist.js","webpack://content/./content/default/components/mystyle.js","webpack://content/./content/default/components/organisms/accordion.js","webpack://content/./content/default/components/organisms/header/header.js","webpack://content/./content/default/components/size_and_fit/sizeAndFit.js","webpack://content/./content/default/components/style_advisor/styleadvisor.js","webpack://content/./content/default/scripts/utils.js","webpack://content/./content/default/views/brand/brandsearch.js","webpack://content/./content/default/views/checkout/checkout.js","webpack://content/./content/default/views/mypages/reservation.js","webpack://content/./content/default/views/product/ajaxify.js","webpack://content/./content/default/views/product/bundle_product.js","webpack://content/./content/default/views/product/filter.js","webpack://content/./content/default/views/product/product_page.js","webpack://content/./content/default/views/product/simple_slider.js","webpack://content/./content/default/views/product/variation/variation.js","webpack://content/./content/default/views/product/wishlist.js","webpack://content/./content/default/views/product/zoom.js","webpack://content/./content/default/app.scss?f26c","webpack://content/./node_modules/vanilla-lazyload/dist/lazyload.min.js","webpack://content/webpack/bootstrap","webpack://content/webpack/runtime/compat get default export","webpack://content/webpack/runtime/define property getters","webpack://content/webpack/runtime/hasOwnProperty shorthand","webpack://content/webpack/runtime/make namespace object","webpack://content/./content/app.js"],"sourcesContent":["\nlet grid;\n\nexport default class Grid {\n    \n    init() {\n        grid = this.get_storage();\n\n        if (grid) {\n            this.render();\n        } else {\n            this.get();\n        }\n\n        this.init_events();\n    }\n\n}","export default class CountryPicker {\n  constructor() {\n    this.init()\n  }\n\n  init() {\n    let countrypickers = document.querySelectorAll(\".country-picker\")\n    countrypickers.forEach((element) => {\n      element.addEventListener(\"click\", function () {\n        element.querySelector(\"svg\").classList.toggle(\"open\")\n        element.querySelector(\"ul\").classList.toggle(\"active\")\n      })\n    })\n  }\n  \n}\n","import {executeJs} from \"../../scripts/utils.js\";\n\nlet newsletter;\n\nexport default class Newsletter {\n\n\tconstructor() {\n\t\tthis.init_events();\n\t}\n\n\tinit_events() {\n\t\tdocument.querySelectorAll('.newsletter-form').forEach(form => {\n\t\t\tform.addEventListener('submit', event => this.handleEvent(form, event));\n\t\t});\n\n\t}\n\n\thandleEvent(form, event) {\n\t\tevent.preventDefault();\n\n\t\tlet email = form.querySelector(\".email\").value;\n\t\tlet country = form.querySelector(\".country\").value;\n\t\tlet interest_id = form.querySelector(\".interest_id\").value;\n\t\tform.classList.remove(\"--error\");\n\n\t\tif (/^\\b[A-ZÅÄÖåäö0-9._%+-]+@[A-ZÅÄÖåäö0-9.-]+\\.[A-Z]{2,4}\\b$/i.test(email)) {\n\t\t\tthis.add_to_newsletter(email, country, interest_id, form);\n\t\t}\n\t\telse\n\t\t{\n\t\t\tform.classList.add(\"--error\");\n\t\t}\n\t}\n\n\tasync add_to_newsletter(email, country, interest_id, form) {\n\t\tconst data = new URLSearchParams();\n\n\t\tdata.append('funk', 'add_to_newsletter');\n\t\tdata.append('email', email);\n\t\tdata.append('country', country);\n\t\tdata.append('interest_id', interest_id);\n\t\tdata.append('profile', \"1\");\n\n\t\tconst response = await fetch('/shop', {\n\t\t\tmethod: 'POST',\n\t\t\tbody: data\n\t\t});\n\n\t\tconst result = await response.json();\n\t\tif (result.status.code == 200) {\n\t\t\tnewsletter = result.data.newsletter;\n\t\t\tthis.pixels = result.data.pixels;\n\n\t\t\tthis.render();\n\t\t\tform.classList.remove(\"--error\");\n\t\t\tform.classList.add(\"--success\");\n\t\t}\n\t}\n\n\tasync delete_from_newsletter(element) {\n\t\tconst data = new URLSearchParams();\n\n\t\tdata.append('funk', 'delete_from_newsletter');\n\t\tdata.append('email', element.target.value);\n\n\t\tconst response = await fetch('/shop', {\n\t\t\tmethod: 'POST',\n\t\t\tbody: data\n\t\t});\n\n\t\tconst result = await response.json();\n\t\tif (result.status.code == 200) {\n\t\t\tnewsletter = result.data.newsletter;\n\t\t\tthis.pixels = result.data.pixels;\n\n\t\t\tthis.render();\n\t\t}\n\t}\n\n\trender() {\n\t\tlet page = \"/sv/info/nyhetsbrev-tack.html\";\n\t\t\n\t\tif (document.querySelector(\".webpage_url\")) {\n\t\t\tpage = document.querySelector(\".webpage_url\").value;\n\t\t}\n\n\t\tconst temporary_element = document.createElement('div');\n\t\ttemporary_element.innerHTML = this.pixels;\n\n\t\texecuteJs(temporary_element);\n\n\t\tdocument.querySelectorAll('.newsletter__input').forEach(element => {\n\t\t\telement.classList.add('--success');\n\t\t});\n\n\t\tsetTimeout(function () {\n\t\t\twindow.location.href = page;\n\t\t}, 200);\n\t}\n}","import SimpleSlider from \"../../../default/views/product/simple_slider\";\n\nconst storage_name = 'air_viewed';\nconst expire_time = 60*24*365; // In minutes.\n\nexport default class RecentlyViewed {\n\n\tconstructor() {\n\t\tthis.init();\n\t\tthis.init_events();\n\t}\n\n\tinit() {\n\t\tconst _this = this;\n\t\twindow.lazyFunctions.recentlyViewed = function(element) {\n\t\t\tconst data = _this.get(element);\n\t\t}\n\t}\n\n\tinit_events() {\n\t\tconst _this = this;\n\t\tdocument.addEventListener(\"product_page_viewed\", function () {\n\t\t\tconst id = window.product_id;\n\t\t\tif (!id) return;\n\n\t\t\tlet viewed = _this.get_storage();\n\t\t\tif (!viewed)\n\t\t\t{\n\t\t\t\tviewed = {items: []};\n\t\t\t}\n\t\t\telse if (viewed.items.includes(id)) {\n\t\t\t\tviewed.items = viewed.items.filter(function(e) { return e !== id })\n\t\t\t}\n\t\t\tviewed.items.unshift(id);\n\t\t\t\n\t\t\tviewed.items.length = 100;\n\t\t\t_this.save_storage(viewed.items);\n\t\t});\n\t}\n\n\tget_storage() {\n\t\tif (typeof (Storage) === 'undefined') return null;\n\n\t\tlet str = window.localStorage.getItem(storage_name);\n\n\t\tif (str == null) return undefined;\n\n\t\tlet data;\n\n\t\ttry {\n\t\t\tdata = JSON.parse(str);\n\t\t} catch (e) {\n\t\t\treturn undefined;\n\t\t}\n\t\tif (data.expires < Date.now()) {\n\t\t\treturn undefined;\n\t\t}\n\n\t\treturn data;\n\t}\n\n\tsave_storage(data) {\n\t\tif (typeof (Storage) === 'undefined') return null;\n\t\t\n\t\tlet air_viewed = {};\n\t\tair_viewed.items = data;\n\t\tair_viewed.expires = Date.now() + expire_time * 60000;\n\t\t \n\t\twindow.localStorage.setItem(storage_name, JSON.stringify(air_viewed));\n\t}\n\n\tasync get(element) {\n\t\tconst viewed = this.get_storage();\n\t\tif (viewed) {\n\t\t\tif (viewed.items <= 1) {\n\t\t\t\treturn;\n\t\t\t}\n\n\t\t\tconst id = window.product_id;\n\t\t\tif (id) {\n\t\t\t\tviewed.items = viewed.items.filter(function(e) { return e !== id })\n\t\t\t}\n\n\t\t\tconst recently_viewed = JSON.stringify(viewed.items).replace(/\\[|\\]|\\\"/g, \"\");\n\t\t\tconst response = await fetch('/shop?funk=get_recently_viewed&recently_viewed=' + recently_viewed + '&lazy=1');\n\t\t\tconst result = await response.json();\n\t\t\tif (result.status.code == 200) {\n\t\t\t\telement.innerHTML = result.data;\n\t\t\t\tdocument.dispatchEvent(new CustomEvent(\"product_cell_update\"));\n\t\t\t\tdocument.dispatchEvent(new CustomEvent(\"pdp_latestviewed_loaded\"));\n\t\t\t\twindow.lazyLoadInstance.update();\n\n\t\t\t\tconst slider = document.querySelector('.recently_viewed .snapping--wrapper');\n\n\t\t\t\tif (slider) {\n\t\t\t\t\tnew SimpleSlider(slider);\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n}","import SimpleSlider from \"../../views/product/simple_slider\";\n\nexport default class StyleView {\n\n\tconstructor() {\n\t\tthis.init();\n\t}\n\n\tinit() {\n\t\tconst _this = this;\n\t\twindow.lazyFunctions.styleView = function(element) {\n\t\t\tconst data = _this.get(element);\n\t\t}\n\t}\n\n\tasync get(element) {\n\t\tconst id = window.product_id;\n\t\tconst response = await fetch(\"/shop?funk=get_product_page_styleview&product_page_styleview=\" + id + \"&lazy=1\");\n\t\tconst result = await response.json();\n\t\tif (result.status.code == 200) {\n\t\t\telement.innerHTML = result.data;\n\t\t\tdocument.dispatchEvent(new CustomEvent(\"product_cell_update\"));\n\t\t\twindow.lazyLoadInstance.update();\n\n\t\t\tconst slider = document.querySelector('.styleview .snapping--wrapper');\n\n\t\t\tif (slider) {\n\t\t\t\tnew SimpleSlider(slider);\n\t\t\t}\n\t\t}\n\t}\n}","\nlet search;\nconst suggestResult = document.getElementById(\"suggest-result\")\nconst suggestInit = document.getElementById(\"suggest-init\")\nconst suggestArea = document.getElementById(\"suggest-area\")\n\nexport default class Search {\n  constructor() {\n    this.suggest_highlight = (typeof (window.suggest_highlight) !== \"undefined\" && window.suggest_highlight === \"1\") ? true : false;\n    this.full_search_url_fallback = \"/shop?funk=gor_sokning&term=\";\n    this.search_history_count = (typeof (window.search_history_count) !== \"undefined\") ? window.search_history_count : 10;\n\n    this.prev_chars = \"\";\n    this.prev_search_chars = \"\";\n    this.timeout_suggest;\n    this.timeout_suggest_ms = 100;\n    this.history_reload = false;\n    this.history_url = \"\";\n\n    this.init();\n  }\n\n  init() {\n    if (window.shop_settings.other.search_url)\n    {\n      this.full_search_url = window.shop_settings.other.search_url;\n    }\n    else\n    {\n      this.full_search_url = this.full_search_url_fallback;\n    }\n\n    if (document.getElementById(\"search-history\")) {\n      this.history_init();\n    }\n\n    this.init_events();\n  }\n\n  init_events() {\n    if (document.getElementById(\"search\")) {\n      document.getElementById(\"search\").addEventListener(\"keyup\", (e) => { this.suggest(e); });\n      document.getElementById(\"search\").addEventListener(\"focus\", () => { this.show(); });\n      document.getElementById(\"search-form\").addEventListener(\"submit\", (e) => { this.search(e); });\n    }\n\n    if (document.getElementById(\"search-wrapper\")) {\n      document.addEventListener(\"click\", (e) => {\n        var container = document.getElementById('search-wrapper');\n        if (!container.contains(e.target)) {\n          this.hide();\n        }\n      });\n    }\n\n    if (document.getElementById(\"search-history-clear\")) {\n      document.getElementById(\"search-history-clear\").addEventListener(\"click\", (e) => { e.preventDefault(); this.history_clear(); });\n    }\n\n    document.addEventListener(\"search-loaded\", (e) => {\n      this.history_save(e.detail.q, e.detail.hits);\n    });\n  }\n\n  search(e) {\n    e.preventDefault();\n\n    const chars = document.getElementById(\"search\").value;\n\n    if (chars.length > 0) {\n      window.location.href = this.full_search_url + chars;\n    }\n  }\n\n  nomatch() {\n    const noresult = document.querySelector(\".noHit\")\n\n    if (suggestResult.contains(noresult)) {\n      suggestArea.classList.add(\"no-results\")\n    }\n    else{\n      suggestArea.classList.remove(\"no-results\")\n    }\n  }\n\n  suggest() {\n    const chars = document.getElementById(\"search\").value;\n\n    if ((chars != '') && (chars.length > 1)) {\n      if (chars !== this.prev_chars) {\n        this.prev_chars = chars;\n        this.suggest_request(chars);\n        this.nomatch();\n      }\n      \n      document.querySelector(\".backdrop\").classList.add(\"active\")\n      document.querySelector(\"#header .header__search #suggest-area.active\").style.maxHeight = \"1000px\";\n      suggestResult.style.display = \"block\"\n      suggestInit.style.display = \"none\"\n\n    } else {\n      if (!chars.length) {\n        if (suggestResult) {\n          suggestResult.style.display = \"none\"\n        }\n        suggestInit.style.display = \"block\"\n        document.querySelector(\n          \"#header .header__search #suggest-area.active\"\n        ).style.maxHeight = \"0px\"\n        document.body.style.overflow = \"\"\n        document.querySelector(\".backdrop\").classList.remove(\"active\")\n        \n      }\n    }\n  }\n\n  async suggest_request(chars) {\n    const chars_encoded = encodeURIComponent(chars);\n\n    let response = await fetch(\"/shop?funk=autosuggest&q=\" + chars_encoded);\n    let html = await response.text();\n    suggestResult.innerHTML = html\n\n    if (this.suggest_highlight) {\n      this.highlight(chars);\n    }\n  }\n\n  show() {\n    if (document.getElementById(\"search\").value !== \"\") {\n      document.querySelector(\".backdrop\").classList.add(\"active\")\n      suggestArea.classList.add(\"active\")\n      document.querySelector(\n        \"#header .header__search #suggest-area.active\"\n      ).style.maxHeight = \"1000px\"\n      suggestInit.style.display = \"none\"\n      suggestResult.style.display = \"block\"\n\n      if (this.prev_chars === \"\") {\n        this.suggest();\n      }\n      \n    } else {\n      suggestInit.style.display = \"block\"\n    }\n\n    suggestArea.classList.add(\"active\")\n  }\n\n  hide() {\n    suggestArea.classList.remove(\"active\")\n  }\n\n  highlight(chars) {\n    chars = chars.trim();\n    var reg = new RegExp(this._escape_regexp(chars), 'gi');\n\n    document.querySelectorAll(\"#suggest-result .term\").forEach(function (elem) {\n      var t = elem.innerHTML;\n      t = t.replace(reg, \"<span class='suggest-hl'>$&</span>\");\n      elem.innerHTML = t;\n    });\n  }\n\n  _escape_regexp(string) {\n    return string.replace(/[.*+?^${}()|[\\]\\\\]/g, '\\\\$&');\n  }\n\n  history_init() {\n    if (typeof (Storage) === \"undefined\") return null;\n    const history_str = window.localStorage.getItem('search_history');\n    if (history_str == null || history_str === \"\") return null;\n\n    const search_history = JSON.parse(history_str);\n    let history_html = \"\";\n\n    for (let i = 0; i < search_history.length; i++) {\n      const value = search_history[i].value;\n      const url = this.full_search_url + encodeURIComponent(value);\n      const link = '<a class=\"search-link\" data-term=\"' + value + '\" href=\"' + url + '\">' + value + '</a>';\n      history_html += '<li class=\"search-history-li\">' + link + '</li>';\n    }\n\n    if (history_html) {\n      history_html = \"<div class='search-history-header'><span class='search-history-title'>\" + search_texts['history'] + \"</span><a href='#' id='search-history-clear'>\" + search_texts['clear'] + \"</a></div><ul>\" + history_html + \"</ul>\";\n    }\n\n    document.getElementById(\"search-history\").innerHTML = history_html;\n  }\n\n  history_save(query, hits) {\n    if (typeof (Storage) === \"undefined\") return null;\n\n    if (hits > 0) {\n      var search_history = JSON.parse(window.localStorage.getItem('search_history'));\n\n      if (search_history == null || search_history === \"\") {\n        search_history = [{ 'value': query }];\n      } else {\n        // remove if already exists.\n        for (var i = 0; i < search_history.length; i++) {\n          if (search_history[i].value === query) {\n            search_history.splice(i, 1);\n            i--;\n          }\n        }\n        search_history.unshift({ 'value': query });\n\n        if (search_history.length > search_history_count) {\n          search_history.length = search_history_count;\n        }\n      }\n\n      window.localStorage.setItem('search_history', JSON.stringify(search_history));\n    }\n  }\n\n  history_clear() {\n    if (typeof (Storage) === \"undefined\") return null;\n    window.localStorage.removeItem('search_history');\n    document.getElementById(\"search-history\").innerHTML = \"\";\n  }\n}\n","\nexport default class Ace {\n\n    constructor() {\n        this.init();\n    }\n\n    init() {\n        this.selectedCategoriesImg = document.getElementById('img-toggle');\n        this.init_events();\n    }\n\n    init_events() {\n        if (this.selectedCategoriesImg) {\n            const selectedCategories = document.querySelectorAll('.category-list--item');\n\n            selectedCategories.forEach(item => {\n                item.addEventListener('mouseenter', (e) => this.set_active_category(e.target));\n\n                if (item.classList.contains('open')) {\n                    this.selectedCategoriesOpen = item;\n                }\n            });\n        }\n    }\n\n    set_active_category(elem) {\n        if (!elem.classList.contains('open')) {\n            const img_tag = elem.getElementsByTagName('img');\n\n            if (img_tag.length) {\n                this.selectedCategoriesImg.src = img_tag[0].src;\n\n                if (this.selectedCategoriesOpen) {\n                    this.selectedCategoriesOpen.classList.remove('open');\n                }\n\n                elem.classList.add('open');\n                this.selectedCategoriesOpen = elem;\n            }\n        }\n    }\n}\n","export default class Nav {\n\n  constructor() {\n    this.init();\n  }\n\n  init() {\n\n    /* Toggle nav */\n    let menuBtn = document.querySelectorAll(\"#main--nav-icon\")\n    let menuBtnClose = document.querySelectorAll(\n      \".menu__categories--close\"\n    )\n    this.mainNav = document.querySelectorAll(\"#main--nav\")\n    this.scrollPosition = 0\n\n    if (window.matchMedia(\"screen and (min-width: 65rem)\").matches) return;\n\n    /* Show nav */\n    for (var i = 0; i < menuBtn.length; ++i) {\n      menuBtn[i].addEventListener(\"click\", () => { this.showMainNav(this) })\n    }\n\n    /* hide nav */\n    for (var i = 0; i < menuBtnClose.length; ++i) {\n      menuBtnClose[i].addEventListener(\"click\", () => { this.hideMainNav(this) })\n    }\n\n    if (/Android|webOS|iPhone|iPad|iPod|BlackBerry/i.test(navigator.userAgent)) {\n      document.querySelector(\"header\").addEventListener(\n        \"click\", (event) => {\n          if (!event.target.closest(\"#nav-wrapper, #main--nav-icon\")) {\n            this.hideMainNav(this)\n          }\n        },\n        false)\n    }\n\n    /* toggle level 1*/\n    const navItemsLink = document.querySelectorAll(\n      \".menu__categories > li.has__children > a\"\n    )\n    const navItemsBack = document.querySelectorAll(\n      \".menu__categories--back\"\n    )\n\n    this.ScrolltoTop = document.querySelector(\".menu__categories\")\n\n    navItemsLink.forEach((listItem) => {\n      listItem.classList.remove('navigate')\n      listItem.addEventListener(\"click\", (e) => { this.setActiveLink(e, this) })\n    })\n\n    navItemsBack.forEach((listItem) => {\n      listItem.addEventListener(\"click\", (e) => { this.setActiveBack(e, this) })\n    })\n  }\n\n  showMainNav(_self) {\n    for (let i = 0; i < _self.mainNav.length; ++i) {\n      /* add active classes */\n      _self.mainNav[i].classList.add(\"active\")\n      document.body.classList.add(\"modal_active\")\n    }\n    /* add scrollpostion */\n    _self.scrollPosition = window.pageYOffset\n    document.body.style.overflow = \"hidden\"\n    document.body.style.position = \"fixed\"\n    document.body.style.top = `-${_self.scrollPosition}px`\n  }\n\n  hideMainNav(_self) {\n    for (let i = 0; i < _self.mainNav.length; ++i) {\n      /* remove active classes */\n\n      _self.mainNav[i].classList.remove(\"active\")\n      document.body.classList.remove(\"modal_active\")\n    }\n    /* remove scrollpostion */\n    document.body.style.removeProperty(\"overflow\")\n    document.body.style.removeProperty(\"position\")\n    document.body.style.removeProperty(\"top\")\n    document.body.classList.remove(\"activeNav\")\n    document.querySelector(\".backdrop\").classList.remove('active')\n    // window.scrollTo(0, _self.scrollPosition)\n  }\n\n  setActiveLink(e, _self) {\n    const parent = e.target.parentNode\n    /* if children prevent link follow - level1 */\n    e.preventDefault()\n    /* show level - 1 if children */\n\n    e.target.parentNode.classList.toggle(\"open\")\n    e.target.parentNode.parentNode.classList.toggle(\"open\")\n    /* scroll menu to top on click */\n    _self.ScrolltoTop.scrollIntoView()\n  }\n\n  /* toggle back to level0 */\n  setActiveBack(e, _self) {\n    const parent = e.target.parentNode\n    e.target.parentNode.parentNode.classList.toggle(\"open\")\n    e.target.parentNode.parentNode.parentNode.classList.toggle(\"open\")\n    /* scroll menu to top on click */\n    _self.ScrolltoTop.scrollIntoView()\n  }\n}","import {executeJs, getCookie} from \"../../../scripts/utils.js\";\n\nconst storage_name = 'air_cart';\nconst expire_time = 60; // In minutes.\n\nexport default class Cart {\n\n    constructor(wrapper_id = 'air-cart-wrapper', content_id = 'air-cart', label_id = 'air-cart-label') {\n        this.wrapper_id = wrapper_id;\n        this.content_id = content_id;\n        this.label_id = label_id;\n        this.cartErrorHeading = '';\n        this.cartErrorText = '';\n\n        if (window.shop_texts) {\n            this.cartErrorHeading = window.shop_texts.text1\n            this.cartErrorText = window.shop_texts.text2\n        }\n\n        this.currency_prefix = window.shop_settings['currency_prefix'] || '';\n        this.currency_suffix = window.shop_settings['currency_suffix'] || '';\n        this.init();\n    }\n\n    init() {\n        if (!getCookie('SESS')) return;\n        if (!document.getElementById(this.wrapper_id)) return;\n\n        let getCart = false;\n\n        if (window.shop_settings) {\n            if (window.shop_settings.request === 'checkout_complete') {\n                getCart = true;\n                localStorage.removeItem(storage_name);\n            }\n        }\n\n        if (!getCart) {\n            this.cart = this.get_storage();\n        }\n\n        if (this.cart) {\n            this.render();\n        } else {\n            this.get();\n        }\n    }\n\n    \n\n    add_item_event(e) {\n        const elem = e.target;\n        const quantity_field = document.getElementById('cart-quantity');\n        const product_id = elem.dataset.id;\n        const quantity = quantity_field ? quantity_field.value : 1;\n\n        this.add_item(product_id, quantity, undefined);\n    }\n\n    remove_item_event(e) {\n        const elem = e.target;\n        const item_id = elem.parentElement.dataset.itemId;\n        this.remove_item(item_id);\n    }\n\n    inc_item_event(e) {\n        const elem = e.target;\n        const item_id = elem.parentElement.dataset.itemId;\n        this.inc_item(item_id);\n    }\n\n    sub_item_event(e) {\n        const elem = e.target;\n        const item_id = elem.parentElement.dataset.itemId;\n        this.sub_item(item_id);\n    }\n\n    _show() {\n        document.querySelector(\"body\").classList.add(\"cart-open\")\n        document.querySelector(\".backdrop\").classList.add(\"active\")\n        document.getElementById(this.content_id).classList.add(\"active\");\n    }\n\n    _hide() {\n        document.getElementById(this.content_id).classList.remove(\"active\")\n        document.querySelector(\".backdrop\").classList.remove(\"active\")\n        document.querySelector(\"body\").classList.remove(\"cart-open\")\n    }\n\n    _toggle() {\n        let elementClasslist = document.getElementById(this.content_id).classList;\n        console.log(\"hejhej\")\n\n        if (!elementClasslist.contains(\"active\")) {\n          this._show()\n        } else {\n          this._hide()\n        }\n    }\n\n    async get(action, opt) {\n        // let response = await fetch('/api/cart');\n        const response = await fetch('/shop?funk=get_cart');\n        const result = await response.json();\n\n        if (result.status.code == 200) {\n            this.cart = result.data;\n\n            this.save_storage();\n            this.render(action, opt);\n        }\n    }\n\n    async add_item(product_id, quantity, extra_data) {\n        const data = new URLSearchParams();\n        this.get()\n        data.append('funk', 'add_cart_item');\n        data.append('product_id', product_id);\n        data.append('quantity', quantity);\n\n        if (extra_data) {\n            // Hantera SET-artiklar.\n            if (extra_data.bundle_fields) {\n                data.append('bundle_fields', JSON.stringify(extra_data.bundle_fields));\n            }\n\n            // Hantera presentkort.\n            if (extra_data.giftcard_value_id) {\n                data.append('giftcard_value_id', extra_data.giftcard_value_id);\n            }\n        }\n\n        const response = await fetch('/shop', {\n            method: 'POST',\n            body: data\n        });\n\n        const result = await response.json();\n\n        if (result.status.code == 200) {\n            this.cart = result.data.cart;\n            this.pixels = result.data.pixels;\n\n            this.save_storage();\n            this.render('add', {product_id: product_id});\n            if (product_id) {                    \n                const data = new URLSearchParams();\n\n                data.append('funk', 'google_article_path');\n                data.append('artnr', product_id);\n                data.append('path', window.shop_settings['product_referrer']);\n\n                const response = fetch('/cgi-bin/ibutik/API.fcgi', {\n                    method: 'POST',\n                    body: data\n                });\n            }\n        } else {\n            this.show_error(result.status);\n        }\n    }\n\n    inc_item(item_id) {\n        const item = this._get_item_from_cart(item_id);\n\n        const new_quantity = item.quantity + 1;\n        this._update_item(item, new_quantity);\n    }\n\n    sub_item(item_id) {\n        const item = this._get_item_from_cart(item_id);\n\n        const new_quantity = item.quantity - 1;\n\n        if (new_quantity <= 0) {\n            this.remove_item(item_id);\n        } else {\n            this._update_item(item, new_quantity);\n        }\n    }\n\n    _get_item_from_cart(item_id) {\n        let matched_item;\n\n        this.cart.items.forEach((item, i) => {\n            if (item.id == item_id) {\n                matched_item = item;\n            }\n        });\n\n        return matched_item;\n    }\n\n    async _update_item(item, new_quantity) {\n        const data = new URLSearchParams();\n        this.get()\n        data.append('funk', 'update_cart_item');\n        data.append('id', item.id);\n        data.append('quantity', new_quantity);\n\n        const response = await fetch('/shop', {\n            method: 'POST',\n            body: data\n        });\n\n        const result = await response.json();\n\n        // Update cart model\n        if (result.status.code == 200) {\n            this.cart.total_cost += item.price * (new_quantity - item.quantity);\n            item.row_cost = item.price * new_quantity;\n            item.quantity = new_quantity;\n\n            this.save_storage();\n            this.render();\n        } else {\n            this.show_error(result.status);\n        }\n    }\n\n    async remove_item(item_id) {\n        const data = new URLSearchParams();\n        this.get()\n        data.append('funk', 'delete_cart_item');\n        data.append('id', item_id);\n\n        const response = await fetch('/shop', {\n            method: 'POST',\n            body: data\n        });\n\n        const result = await response.json();\n\n        // Update cart model\n        if (result.status.code == 200) {\n            this.cart.items.forEach((item, i) => {\n                if (item.id == item_id) {\n                    this.cart.total_cost -= item.row_cost;\n                    this.cart.items.splice(i, 1);\n                }\n            });\n\n            this.save_storage();\n            this.render();\n        } else {\n            this.show_error(result.status);\n        }\n    }\n\n    save_storage() {\n        if (typeof (Storage) === 'undefined') return null;\n\n        this.cart.expires = Date.now() + expire_time * 60000;\n        window.localStorage.setItem(storage_name, JSON.stringify(this.cart));\n    }\n\n    get_storage() {\n        if (typeof (Storage) === 'undefined') return null;\n\n        let str = window.localStorage.getItem(storage_name);\n\n        if (str == null) return undefined;\n\n        let data;\n\n        try {\n            data = JSON.parse(str);\n        } catch (e) {\n            return undefined;\n        }\n\n        if (data.expires < Date.now()) {\n            return undefined;\n        }\n\n        return data;\n    }\n\n    show_error(error) {\n        \n        const container = document.getElementById(this.content_id);\n    \n        let html = `\n        <div class=\"air-cart-row row pt-16\">\n            <div class=\"d-flex flex-column\">\n                <h3 id=\"air-cart-msg\" class=\"mb-16 mt-24\">${this.cartErrorHeading}</h3>\n                <p>${this.cartErrorText}</p>\n            </div>\n        </div>\n        `\n        container.innerHTML = html;\n        document.body.classList.add(\"cart-open\")\n        const backdropBlur = document.querySelector(\".backdrop\")\n        const airCartModule = document.querySelector(\"#air-cart-module\")\n        document.body.style.overflow = \"hidden\"\n        document.querySelector(\"#air-cart\").parentElement.classList.add(\"active\")\n        document.querySelector(\"#air-cart\").parentElement.classList.add(\"error\")\n        backdropBlur.classList.add(\"active\")\n    }\n\n    show(action, opt) {\n        this.get(action, opt);\n    }\n\n    render(action, opt) {\n        if (this.cart.total_count) {\n            document.getElementById(\"air-cart-label-text\").innerHTML =\n            this.cart.total_count\n        }\n\n        if (this.cart.total_count > 0) {\n            document.getElementById(this.label_id).classList.add(\"active\")\n        }\n\n        document.getElementById(this.label_id).addEventListener(\"click\", () => {\n            if (window.checkout_url)\n            {\n                window.location.href = window.checkout_url;\n            }\n            else\n            {\n                window.location.href = \"/shop?funk=bestall_steg1\"\n            }\n            \n        });\n\n        if (action === 'add') {\n            const container = document.getElementById(this.content_id);\n            const product_id = opt.product_id;\n            const items = this.cart.items;\n            document.querySelector(\"header\").classList.add(\"header__scrolled\")\n            document.querySelector(\"header\").classList.remove(\"header__notScrolled\")\n            document.querySelector(\"body\").classList.add(\"header__scrolled\")\n            document.querySelector(\"body\").classList.remove(\"header__notScrolled\")\n\n            let item;\n\n            if (opt.order == 'update_time') {\n                item = items[items.length-1];\n\n                for (let i = items.length - 1; i > 0; i--) {\n                    if (items[i-1].update_time > items[i].update_time) {\n                        item = items[i-1];\n                    }\n                }\n            } else {\n                for (let i = items.length; i > 0; i--) {\n                    if (items[i-1].product_id === product_id) {\n                        item = items[i-1];\n                        break;\n                    }\n                }\n            }\n\n            if (item) {\n                let html = `\n                <a href=\"${item.product.url}\" class=\"air-cart-row row pt-16\">\n                    <div class=\"d-flex cartProduct\">\n                        <div class=\"col-xs-4 pl-0 pb-16\">\n                            <img src=\"${item.product.image}\">\n                        </div>\n                        <div class=\"col-xs-8\">\n                            <div class=\"py-4\">${item.product.name}</div>\n                            <div class=\"py-4\">${this.currency_prefix}${item.price}${this.currency_suffix}</div>\n                        </div>\n                    </div>\n                </a>\n                <div class=\"atm-pixels\">${this.pixels}</div>\n                `\n\n                container.innerHTML = html;\n                executeJs(container);\n                document.body.style.overflow = \"hidden\"\n                document.body.classList.add(\"cart-open\")\n                const backdropBlur = document.querySelector(\".backdrop\")\n                const airCartModule = document.querySelector(\"#air-cart-module\")\n                document.querySelector(\"#air-cart\").parentElement.classList.add(\"active\")\n                backdropBlur.classList.add(\"active\")\n            }\n        }\n    }\n\n}\n","export default class Login {\n    constructor(icon_id = 'login-icon', form_id = 'login-form', popup_id = '#login-wrapper', error_id = 'login-error', login_success_id = 'login-wrapper-content-success') {\n        this.icon_id = icon_id;\n        this.form_id = form_id;\n        this.popup_id = popup_id;\n        this.error_id = error_id;\n        this.login_success_id = login_success_id;\n        this.from_checklogin = false;\n        this.isImboxHandling = false; // Flag to prevent loop\n        this.init();\n    }\n\n    init() {\n        this.init_events();\n        this.setupImboxListener(); // Set up the _imbox listener\n    }\n\n    init_events() {\n        if (!document.getElementById(this.icon_id)) return;\n\n        if (window.checklogin) {\n            this.init_checklogin();\n        } \n        document.getElementById(this.icon_id).addEventListener('click', () => { this.show_login(); });\n        document.querySelector(this.popup_id + ' .close').addEventListener('click', (e) => { e.stopPropagation(); this.hide_login(); });\n        document.getElementById(this.form_id).addEventListener('submit', (e) => { e.preventDefault(); this.login(); });\n        document.querySelector('.login-success-button').addEventListener('click', () => {\n            this.handleRedirection();\n        });\n    }\n\n    init_checklogin() {  \n        this.from_checklogin = true;\n\n        let text = window.checklogin_text || '';\n        let email = window.checklogin_email || '';\n\n        if (text) {\n            let h3 = document.querySelector('#login-wrapper h3');\n            if (h3) {\n                h3.innerHTML = text;\n            }\n            let ulElements = document.querySelectorAll('#login-wrapper-content ul');\n            ulElements.forEach(ul => ul.remove());\n        }\n\n        if (email) {\n            document.querySelector('#login-wrapper input[name=\"user\"]').value = email;\n        }\n\n        this.show_login();\n    }\n\n    handleRedirection() {\n        if (window.location.href.includes('funk=logout')) {\n            window.location.href = '/'; // Redirect to homepage\n        } else {\n            location.reload();\n        }\n    }\n\n    show_login() {\n        const login_form = document.querySelector(this.popup_id);\n        const backdrop = document.querySelector('.backdrop');\n        // Ensure _imbox is hidden when show_login is called\n        this.hideImbox();\n        login_form.classList.add('active');\n        backdrop.classList.add('active');\n        document.body.classList.add('fullbackdrop');\n    }\n\n    hide_login() {\n        const login_form = document.querySelector(this.popup_id);\n        \n        login_form.classList.remove('active');\n        document.body.classList.remove('fullbackdrop');\n    }\n\n    async login() {\n        const form = document.getElementById(this.form_id);\n\n        if (!form.user.value && !form.pass.value) return;\n\n        const data = new URLSearchParams(new FormData(form));\n\n        const response = await fetch('/shop', {\n            method: 'POST',\n            body: data\n        });\n\n        const result = await response.json();\n\n        if (result.status.code == 200) {\n            if (typeof (Storage) !== 'undefined') {\n                window.localStorage.removeItem('air_wishlist');\n                window.localStorage.removeItem('air_cart');\n            }\n\n            if (this.from_checklogin) {\n                this.handleRedirection();\n            } else {\n                document.getElementById(this.form_id).classList.add('hide');\n                document.getElementById(this.login_success_id).classList.remove('hide');\n            }\n        } else {\n            document.getElementById(this.error_id).innerHTML = result.status.msg;\n        }\n    }\n\n    hideImbox() {\n        if (typeof(_imbox) !== \"undefined\") {\n            this.isImboxHandling = true; // Disable the callback\n            _imbox.push(['hideLauncher']);\n            _imbox.push(['hideWidget']);\n            setTimeout(() => { this.isImboxHandling = false; }, 100); // Re-enable the callback after a delay\n        }\n    }\n\n    setupImboxListener() {\n        const debounce = (func, wait) => {\n            let timeout;\n            return (...args) => {\n                clearTimeout(timeout);\n                timeout = setTimeout(() => func.apply(this, args), wait);\n            };\n        };\n\n        const onToggleCallback = debounce(() => {\n            if (!this.isImboxHandling) { // Only execute if not handling _imbox manually\n                this.hideImbox();\n            }\n        }, 100);\n\n        if (typeof(_imbox) !== \"undefined\") {\n            _imbox.push([\"onToggle\", onToggleCallback]);\n        }\n    }\n}\n\n","\nlet toplist;\n\nexport default class Toplist {\n  init() {\n    toplist = this.get_storage()\n\n    if (toplist) {\n      this.render()\n    } else {\n      this.get()\n    }\n\n    this.init_events();\n  }\n\n  init_events() {\n  }\n}\n","\nexport default class MyStyle {\n\n\tconstructor() {\n\t\tthis.init_events();\n\t}\n\n\tinit_events() {\n\t\t\n\t\twindow.liveEvent(\".myStyle__switch input\", \"change\", (event, element) => { \n\t\t\tthis.toggleMyStyle(element)\n\t\t});\n\n\t\tdocument.addEventListener(\"sort_changed\", function (e) {\n\t\t\tif (e.detail) {\n\t\t\t\tif (e.detail.sort !== \"most_popular-asc\") {\n\t\t\t\t\tdocument.cookie = \"bloomreach_sort_active=\" + false + \"; max-age=\" + 30*24*60*60 + \"; path=/\";\n\t\t\t\t\t\n\t\t\t\t\tdocument.querySelectorAll('.myStyle__switch input').forEach(checkbox => {\n\t\t\t\t\t\tcheckbox.checked = false;\n\t\t\t\t\t});\n\t\t\t\t}\n\t\t\t}\n\t\t});\n\t}\n\n\ttoggleMyStyle(element) {\n\n\t\tlet checked = element.checked;\n\t\tlet type = element.dataset.type;\n\t\texponea.track('site_click', {\n\t\t\t'action': checked,\n\t\t\t'type': 'my_style',\n\t\t\t'parameter': 'toggle'\n\t\t}); \n\n\t\tdocument.querySelectorAll('.myStyle__switch input').forEach(checkbox => {\n\t\t\tcheckbox.checked = checked;\n\t\t});\n\n\t\tdocument.cookie = \"bloomreach_sort_active=\" + checked + \"; max-age=\" + 30*24*60*60 + \"; path=/\";\n\n\t\tif (type == \"group\") {\n\t\t\tif (checked) {\n\t\t\t\tthis.setPopularSort();\n\t\t\t}\n\t\t\tdocument.dispatchEvent(new Event(\"refresh_filter\"));\n\t\t}\n\t\telse if (type == \"widget\")\n\t\t{\n\t\t\tlet group_id = element.dataset.group_id;\n\t\t\tlet limit = element.dataset.limit;\n\t\t\tlet sort = element.dataset.sort;\n\t\t\tthis.get(group_id, limit, sort);\n\t\t}\n\t}\n\n\tsetPopularSort() {\n\t\tdocument.querySelectorAll('#sort-order-ul li').forEach(sort_li => {\n\t\t\tif (sort_li.dataset.value == \"most_popular-asc\") {\n\t\t\t\tsort_li.classList.add(\"--active\");\n\t\t\t\tdocument.querySelectorAll('.active_sort_label').forEach(label => {\n\t\t\t\t\tlabel.innerHTML = sort_li.innerHTML;\n\t\t\t\t});\n\t\t\t}\n\t\t\telse {\n\t\t\t\tsort_li.classList.remove(\"--active\");\n\t\t\t}\n\t\t});\n\t}\n\n\tasync get(group_id, limit, sort) {\n\t\tconst data = new URLSearchParams();\n\t\tdata.append('funk', 'get_filter');\t\n\t\tdata.append('json', 1);\n\t\tdata.append('id', group_id);\n\t\tdata.append('limit', limit);\n\t\tdata.append('sort', sort);\n\t\tdata.append('type', \"product_group\");\n\t\n\t\tconst response = await fetch('/shop', {\n\t\t\tmethod: 'POST',\n\t\t\tbody: data\n\t\t});\n\n\t\tconst result = await response.json();\n\t\tif (result.request_data) {}\n\t}\n}","export default class accordion {\n    constructor() {\n      this.init()\n    }\n    init() {\n        function initAcc(elem, option){\n\n            document.addEventListener('click', function (e) {\n                if (!e.target.matches(elem+' .accordion__item--btn')) return;\n                else{\n                    if(!e.target.parentElement.classList.contains('active')){\n                        if(option==true){\n                            var elementList = document.querySelectorAll(elem +' .accordion__item');\n                            Array.prototype.forEach.call(elementList, function (e) {\n                               // e.classList.remove('active');\n                            });\n                        }    \n                        e.target.parentElement.classList.add('active');\n                    }else{\n                        e.target.parentElement.classList.remove('active');\n                    }\n                }\n            });\n        }\n\n        initAcc('.accordion', true);\n\n    }\n}","export default class Header {\n  constructor() {\n    this.init()\n  }\n\n  init() {\n\n    const ElementLegend = {}\n\n    function GetElement(selector, refresh) {\n      try {\n        if (refresh) return document.querySelector(selector)\n\n        if (!(selector in ElementLegend)) {\n          ElementLegend[selector] = document.querySelector(selector)\n        }\n\n        return ElementLegend[selector]\n      } catch (err) {\n        console.log(err)\n\n        return null\n      }\n    }\n\n    var scrollPos = window.scrollY\n    window.addEventListener(\"scroll\", function () {\n      if (!GetElement(\"header\")) return\n      else if (window.scrollY < 130) {\n        scrollPos = window.scrollY\n        GetElement(\"body\").classList.remove(\"header__scrolled\")\n        GetElement(\"header\").classList.remove(\"header__scrolled\")\n        GetElement(\"header\").classList.remove(\"header__notScrolled\")\n        GetElement(\"header\").classList.add(\"top\")\n      } else if (window.scrollY > scrollPos + 100) {\n        scrollPos = window.scrollY\n        GetElement(\"header\").classList.remove(\"top\")\n        GetElement(\"header\").classList.remove(\"header__scrolled\")\n        GetElement(\"body\").classList.remove(\"header__scrolled\")\n        GetElement(\"body\").classList.add(\"header__notScrolled\")\n        GetElement(\"header\").classList.add(\"header__notScrolled\")\n        document.body.style.overflow = \"\"\n        document.querySelector(\".backdrop\").classList.remove(\"active\")\n        if (\n          document.querySelector(\"#header .header__search #suggest-area.active\")\n        ) {\n          document.querySelector(\n            \"#header .header__search #suggest-area.active\"\n          ).style.maxHeight = \"0px\"\n        }\n        if (document.getElementById(\"suggest-result\")) {\n          document.getElementById(\"suggest-result\").style.display = \"none\"\n        }\n        if (document.getElementById(\"suggest-init\")) {\n          document.getElementById(\"suggest-init\").style.display = \"none\"\n        }\n        document.querySelector(\".backdrop\").classList.remove(\"active\")\n        if (document.querySelector(\"#search\")) {\n          document.querySelector(\"#search\").blur()\n        }\n      } else if (window.scrollY < scrollPos - 100) {\n        scrollPos = window.scrollY\n        GetElement(\"header\").classList.remove(\"header__notScrolled\")\n        GetElement(\"body\").classList.remove(\"header__notScrolled\")\n        GetElement(\"header\").classList.add(\"header__scrolled\")\n        GetElement(\"body\").classList.add(\"header__scrolled\")\n      }\n    })\n  }\n}\n","export default class SizeAndFit {\n\tconstructor() {\n\t\tthis.init_events();\n\t\twindow.addEventListener('pdp_ajax_loaded', () => {\n\t\t\tthis.init_events(); \n\t\t});\n\t}\n\t\n\tinit_events() {\n\t\tconst snfPDP = document.querySelector('.buybox .sizeAndFitTrigger');\n\t\tconst sizeAndFit = document.getElementById('sizeandfit2');\n\n\t\tif (sizeAndFit) {\n\t\t\tif (snfPDP) {\n\n\t\t\t\tSizeAndFit.showGeneratedSize();\n\t\t\t}\n\t\t\tthis.activeFit();\n\t\t\tthis.activeStep();\n\t\t\tthis.snfBtn();\n\t\t\tthis.bodyTypeHandler();\n\t\t\tthis.rangeSlider();\n\n\t\t\tconst backdropBlur = document.querySelector('.backdrop');\n\t\t\tconst sizeNFit = document.getElementById('sizeandfit');\n\t\t\tconst sizeNFitStep = sessionStorage.getItem('snf_step');\n\n// Assuming window.sizeNFitInitialized is not defined anywhere else in your code.\nif (typeof window.sizeNFitInitialized === 'undefined') {\n    window.sizeNFitInitialized = false;\n}\n\n\t\t\twindow.liveEvent('.sizeAndFitTrigger', 'click', () => {\n\t\t\t\tif (sizeNFitStep == '1' && !window.sizeNFitInitialized) {\n        trackExponeaStart();\n        _imbox.push(['hideLauncher']);\n        window.sizeNFitInitialized = true; // Set the flag to true after the first initialization\n\n    }\n\t\t\t\t\n\t\t\t\tconst productPage = document.querySelector('.single-product');\n\t\t\t\tconst sizeAndFit = document.getElementById('sizeandfit');\n\t\t\t\tdocument.body.classList.add(\"sizeandfit-open\");\n\t\t\t\tdocument.body.style.overflow = '';\n\t\t\t\tif (productPage) {\n\t\t\t\t\tconst images = document.querySelectorAll('.productImg--wrapper img');\n\t\t\t\t\tconst productArtNr = document.querySelector('.product-id-info');\n\t\t\t\t\tsizeAndFit.classList.add('from-pdp');\n\n\t\t\t\t\tconst imageSource = images[0].getAttribute('src');\n\t\t\t\t\tsessionStorage.setItem('snf_image', imageSource);\n\t\t\t\t\tsessionStorage.setItem('snf_artnr', productArtNr.textContent);\n\n\t\t\t\t}\n\n\t\t\t\tbackdropBlur.classList.add('active');\n\t\t\t\tsizeNFit.classList.add('active');\n\t\t\t\tthis.activeStep();\n\n\t\t\t\tif (sizeNFitStep > '1') {\n\t\t\t\t\tthis.snfBackBtn();\n\t\t\t\t}\n\t\t\t});\n\n\t\t\twindow.liveEvent('.sizeandfit__header svg', 'click', () => {\n\t\t\t\tbackdropBlur.classList.remove('active');\n\t\t\t\tdocument.body.classList.remove(\"sizeandfit-open\");\n\t\t\t\tsizeNFit.classList.remove('active');\nwindow.sizeNFitInitialized = false;\n\t\t\t});\n\n\t\t\twindow.liveEvent('.sizeandfit__close', 'click', () => {\n\t\t\t\tbackdropBlur.classList.remove('active');\n\t\t\t\tsizeNFit.classList.remove('active');\n\t\t\t\tdocument.body.classList.remove(\"sizeandfit-open\");\n\t\t\t\tsessionStorage.setItem('snf_step', '1');\nwindow.sizeNFitInitialized = false;\n\t\t\t});\n\n\n\n\t\t\tif (!sizeNFitStep) {\n\t\t\t\tsessionStorage.setItem('snf_step', '1');\n\t\t\t}\n\t\t}\n\t}\n\n\trangeSlider() {\n\t\tconst rangeLabels = document.querySelectorAll('.range__label');\n\t\tconst slider = document.getElementById('snf_slider');\n\n\t\trangeLabels.forEach((label) => {\n\t\t\tlabel.addEventListener('click', (event) => {\n\t\t\t\tconst value = event.target.getAttribute('data-value');\n\t\t\t\tslider.value = value;\n\t\t\t\t// Trigger the change event manually to update the slider's value\n\t\t\t\tslider.dispatchEvent(new Event('change'));\n\t\t\t});\n\t\t});\n\n\t\t// Listen for changes in the slider's value\n\t\tslider.addEventListener('change', (event) => {\n\t\t\tconst value = event.target.value;\n\t\t\t// Add or remove 'active' class based on the slider's value\n\t\t\trangeLabels.forEach((label) => {\n\t\t\t\tconst labelValue = label.getAttribute('data-value');\n\t\t\t\tif (labelValue === value) {\n\t\t\t\t\tlabel.classList.add('active');\n\t\t\t\t} else {\n\t\t\t\t\tlabel.classList.remove('active');\n\t\t\t\t}\n\t\t\t});\n\t\t});\n\t}\n\n\tactiveFit() {\n\t\tconst sliderLabels = document.querySelectorAll('.range__label');\n\t\tconst slider = document.getElementById('snf_slider');\n\t\tif (slider) {\n\t\t\tslider.addEventListener('input', () => {\n\t\t\t\tconst sliderValue = slider.value;\n\n\t\t\t\tsliderLabels.forEach((label) => {\n\t\t\t\t\tconst labelValue = label.getAttribute('data-value');\n\n\t\t\t\t\tif (labelValue === sliderValue) {\n\t\t\t\t\t\tlabel.classList.add('active');\n\t\t\t\t\t} else {\n\t\t\t\t\t\tlabel.classList.remove('active');\n\t\t\t\t\t}\n\t\t\t\t});\n\t\t\t});\n\t\t}\n\t}\n\n\tsnfBtn() {\n\t\tconst snfContinue = document.querySelector('.sizeandfit__continue');\n\n\t\tsnfContinue.addEventListener('click', () => {\n\t\t\tlet step = sessionStorage.getItem('snf_step');\n\t\t\tconst typesActive = document.querySelector('.sizeandfit__types');\n\t\t\tconst closeBtn = document.querySelector('.sizeandfit__header svg');\n\t\t\tconst clickEvent = new Event('click');\n\n\t\t\tif (step === '1') {\n\t\t\t\tconst snfHeight = document.getElementById('snf-height');\n\t\t\t\tconst snfWeight = document.getElementById('snf-weight');\n\t\t\t\tconst height = snfHeight.value;\n\t\t\t\tconst weight = snfWeight.value;\n\t\t\t\t// Check if both height and weight have values\n\t\t\t\tif (height === '' || weight === '') {\n\t\t\t\t\t// Show an error message if either height or weight is missing\n\t\t\t\t\tdocument.getElementById('step_1_error_message').classList.remove('hide');\n\t\t\t\t\treturn; // Stop the function from proceeding\n\t\t\t\t}\n\t\t\t\telse{\n\t\t\t\t\tdocument.getElementById('step_1_error_message').classList.add('hide');\n\t\t\t\t}\n\t\t\t\tstep = parseInt(step) + 1;\n\t\t\t\tstep = step.toString();\n\t\t\t\tlocalStorage.setItem('snf_height', height);\n\t\t\t\tlocalStorage.setItem('snf_weight', weight);\n\t\t\t\tsessionStorage.setItem('snf_step', step);\n\t\t\t\tsessionStorage.setItem('snf_height', height);\n\t\t\t\tsessionStorage.setItem('snf_weight', weight);\n\n\t\t\t\tthis.activeStep();\n\t\t\t} else if (step === '2' && typesActive) {\n\t\t\t\tstep = parseInt(step) + 1;\n\t\t\t\tstep = step.toString();\n\t\t\t\tsessionStorage.setItem('snf_step', step);\n\t\t\t\tthis.activeStep();\n\t\t\t} else if ((step === '3' && typesActive) || (step === '2' && !typesActive)) {\n\t\t\t\tconst snfFit = document.getElementById('snf_slider');\n\t\t\t\tconst fit = snfFit.value;\n\t\t\t\tlet formValue = '';\n\n\t\t\t\tif (fit === '1') {\n\t\t\t\t\tformValue = 'tight';\n\t\t\t\t} else if (fit === '2') {\n\t\t\t\t\tformValue = 'normal';\n\t\t\t\t} else if (fit === '3') {\n\t\t\t\t\tformValue = 'spacious';\n\t\t\t\t}\n\n\t\t\t\tstep = parseInt(step) + 1;\n\t\t\t\tstep = step.toString();\n\t\t\t\tsessionStorage.setItem('snf_step', step);\n\t\t\t\tsessionStorage.setItem('snf_form', formValue);\n\n\t\t\t\tthis.activeStep();\n\t\t\t} else if ((step === '4' && typesActive) || (step === '3' && !typesActive)) {\n\t\t\t\tcloseBtn.dispatchEvent(clickEvent);\n\t\t\t}\n\n\t\t\tthis.snfBackBtn();\n\t\t});\n\t}\n\n\tactiveStep() {\n\t\tconst step = sessionStorage.getItem('snf_step');\n\t\tconst continueButton = document.querySelector('.sizeandfit__continue');\n\t\tconst fromPDP = document.querySelector('.sizeandfit.from-pdp');\n\t\tconst snfHeader = document.querySelector('.sizeandfit__header');\n\n\t\tconst elements = [\n\t\t\tdocument.querySelector('.sizeandfit__metrics'),\n\t\t\tdocument.querySelector('.sizeandfit__fits'),\n\t\t\tdocument.querySelector('.sizeandfit__results-fromPDP'),\n\t\t\tdocument.querySelector('.sizeandfit__back'),\n\t\t\tdocument.querySelector('.sizeandfit__header h2'),\n\t\t\tdocument.querySelector('.sizeandfit__steps p'),\n\t\t\tdocument.querySelector('.sizeandfit__continue'),\n\t\t\tdocument.querySelector('.sizeandfit__results'),\n\t\t\tdocument.querySelector('.sizeandfit__finish'),\n\t\t\tdocument.querySelector('.sizeandfit__resultsfail'),\n\t\t\tdocument.querySelector('.sizeandfit__close')\n\t\t];\n\n\t\tconst typesActive = document.querySelector('.sizeandfit__types');\n\n\t\tif (typesActive) {\n\t\t\telements.splice(1, 0, typesActive);\n\t\t}\n\n\t\telements.forEach((element) => element.classList.add('hide'));\n\n\t\tif (step === '1' && typesActive) {\n\t\t\t[elements[0], elements[5], elements[6], elements[7]].forEach((element) => element.classList.remove('hide'));\n\t\t\telements[6].textContent = step;\n\t\t\tsnfHeader.className = snfHeader.className.replace(/\\bstep\\d\\b/g, 'step1');\n\t\t} else if (step === '2' && typesActive) {\n\t\t\t[elements[1], elements[4], elements[6], elements[7]].forEach((element) => element.classList.remove('hide'));\n\t\t\telements[6].textContent = step;\n\t\t\tsnfHeader.className = snfHeader.className.replace(/\\bstep\\d\\b/g, 'step2');\n\t\t} else if (step === '3' && typesActive) {\n\t\t\t[elements[2], elements[4], elements[6], elements[7]].forEach((element) => element.classList.remove('hide'));\n\t\t\telements[6].textContent = step;\n\t\t\tsnfHeader.className = snfHeader.className.replace(/\\bstep\\d\\b/g, 'step3');\n\t\t} else if (step === '4' && typesActive && fromPDP) {\n\t\t\tthis.fetchSize([elements[3], elements[4], elements[6]]);\n\t\t\telements[6].textContent = step;\n\t\t\tsnfHeader.className = snfHeader.className.replace(/\\bstep\\d\\b/g, 'step4');\n\t\t} else if (step === '4' && typesActive && !fromPDP) {\n\t\t\tthis.fetchSize([elements[9], elements[4], elements[6], elements[8], elements[7]]);\n\t\t\telements[6].textContent = step;\n\t\t\tsnfHeader.className = snfHeader.className.replace(/\\bstep\\d\\b/g, 'step4');\n\n\t\t\t// Logic for inactive bodytypes below\n\t\t} else if (step === '1' && !typesActive) {\n\t\t\t[elements[0], elements[4], elements[5], elements[6]].forEach((element) => element.classList.remove('hide'));\n\t\t\telements[5].textContent = step;\n\t\t\tsnfHeader.className = snfHeader.className.replace(/\\bstep\\d\\b/g, 'step1');\n\t\t} else if (step === '2' && !typesActive) {\n\t\t\t[elements[1], elements[3], elements[5], elements[6]].forEach((element) => element.classList.remove('hide'));\n\t\t\tcontinueButton.classList.remove('hide');\n\t\t\telements[5].textContent = step;\n\t\t\tsnfHeader.className = snfHeader.className.replace(/\\bstep\\d\\b/g, 'step2');\n\t\t} else if (step === '3' && !typesActive && fromPDP) {\n\t\t\t[elements[5]].forEach((element) => element.classList.remove('hide'));\n\t\t\telements[5].textContent = step;\n\t\t\tthis.fetchSize([elements[2], elements[3]]);\n\t\t\tsnfHeader.className = snfHeader.className.replace(/\\bstep\\d\\b/g, 'step4');\n\t\t} else if (step === '3' && !typesActive && !fromPDP) {\n\t\t\t[elements[5]].forEach((element) => element.classList.remove('hide'));\n\t\t\telements[5].textContent = step;\n\t\t\tthis.fetchSize([elements[7], elements[3]]);\n\t\t\tsnfHeader.classList.replace('step2', 'step4');\n\t\t}\n\t}\n\n\tsnfBackBtn() {\n\t\tconst backBtn = document.querySelector('.sizeandfit__back');\n\t\tconst step = sessionStorage.getItem('snf_step');\n\t\tconst stepBackValue = parseInt(step) - 1;\n\t\tconst stepBackString = stepBackValue.toString();\n\n\t\tbackBtn.addEventListener('click', () => {\n\t\t\tsessionStorage.setItem('snf_step', stepBackString);\n\t\t\tthis.activeStep();\n\t\t\tthis.snfBackBtn();\n\t\t});\n\t}\n\n\tfetchSize(elementArray) {\n\t\tconst sizeResult = document.querySelectorAll('.size-result');\n\t\tconst sizeResultImage = document.querySelector('.sizeandfit__results--img img');\n\t\tconst height = sessionStorage.getItem('snf_height');\n\t\tconst weight = sessionStorage.getItem('snf_weight');\n\t\tconst form = sessionStorage.getItem('snf_form');\n\t\tconst image = sessionStorage.getItem('snf_image');\n\t\tconst loadingWrapper = document.querySelector('.sizeandfit__loading_pageWrapper');\n\t\tconst stepCounter = document.querySelector('.sizeandfit__steps');\n\t\tconst articleNumber = sessionStorage.getItem('snf_artnr');\n\t\tconst resultFailed = document.querySelector('.sizeandfit__resultsfail');\n\t\tconst resultFromPDP = document.querySelector('.sizeandfit__results-fromPDP');\n\t\tconst continueButton = document.querySelector('.sizeandfit__continue');\n\t\tconst finishButton = document.querySelector('.sizeandfit__finish');\n\t\tconst fromPDP = document.querySelector('.sizeandfit.from-pdp');\n\t\tconst closeButton = document.querySelector('.sizeandfit__close');\n\n\t\tlet type = sessionStorage.getItem('snf_type');\n\t\tlet artnr = '';\n\n\t\tif (!type) {\n\t\t\ttype = 'rectangular';\n\t\t}\n\n\t\tif (articleNumber) {\n\t\t\tartnr = `&product_id=${articleNumber}`;\n\t\t}\n\n\t\tconst fetchQuery = `&match_id=1&field_1=${type}&field_2=${form}&field_x=${weight}&field_y=${height}${artnr}`;\n\n\t\tstepCounter.classList.add('hide');\n\t\tloadingWrapper.style.display = 'block';\n\t\tthis.loading_start();\n\n\n\n\t\tfetch(`/cgi-bin/ibutik/API.fcgi?funk=PM${fetchQuery}`, {\n\t\t\tmethod: 'GET',\n\t\t\theaders: {\n\t\t\t\t'Content-Type': 'application/json'\n\t\t\t}\n\t\t})\n\t\t.then((response) => response.json())\n\t\t.then((data) => {\n\t\t\t// Simulating a delay to ensure the loader animation finishes first\n\t\t\tsetTimeout(() => {\n\t\t\t\tloadingWrapper.style.display = 'none';\n\n\t\t\t\tif (elementArray && Array.isArray(elementArray)) {\n\t\t\t\t\telementArray.forEach((element) => element.classList.remove('hide'));\n\t\t\t\t}\n\n\t\t\t\tstepCounter.classList.remove('hide');\n\n\t\t\t\tif (data.alt_value && data.alt_value_unavailable !== 1) {\n\t\t\t\t\tsizeResult.forEach((result) => {\n\t\t\t\t\t\tresult.textContent = data.alt_value;\n\t\t\t\t\t});\n\t\t\t\t\tsizeResultImage.setAttribute('src', image);\n\t\t\t\t} else if (data.value && !data.alt_value && data.value_unavailable !== 1) {\n\t\t\t\t\tsizeResult.forEach((result) => {\n\t\t\t\t\t\tresult.textContent = data.value;\n\t\t\t\t\t});\n\t\t\t\t\tsizeResultImage.setAttribute('src', image);\n\t\t\t\t} else if (data.value_unavailable === 1 || data.alt_value_unavailable === 1) {\n\t\t\t\t\tsizeResult.forEach((result) => {\n\t\t\t\t\t\tresult.textContent = data.value;\n\t\t\t\t\t});\n\t\t\t\t\tfinishButton.classList.add('hide');\n\t\t\t\t\tresultFailed.classList.remove('hide');\n\t\t\t\t\tresultFromPDP.classList.add('hide');\n\t\t\t\t\tcloseButton.classList.remove('hide');\n\t\t\t\t}\n\n\t\t\t\tif (fromPDP) {\n\t\t\t\t\tif (closeButton.classList.contains('hide')) {\n\t\t\t\t\t\tfinishButton.classList.remove('hide');\n\t\t\t\t\t}\n\t\t\t\t\tcontinueButton.classList.add('hide');\n\n\t\t\t\t\tSizeAndFit.showGeneratedSize();\n\t  \t\t\t} else {\n\t\t\t\t\tcontinueButton.classList.remove('hide');\n\t\t\t\t\tfinishButton.classList.add('hide');\n\t\t\t\t\tcontinueButton.querySelector('.finish').classList.remove('hide');\n\t\t\t\t\tcontinueButton.querySelector('.continue').classList.add('hide');\n\t\t\t\t}\n\t\t\t}, 1500);\n\t\t})\n\t\t.catch((error) => {\n\t\t\tconsole.error('Error:', error);\n\t\t});\n\t}\n\n\tbodyTypeHandler() {\n\t\tconst types = document.querySelectorAll('.sizeandfit__types-wrapper img');\n\n\t\ttypes.forEach((type) => {\n\t\t\tif (type.classList.contains('active')) {\n\t\t\t\t// Check if 'snf_type' does not exist in sessionStorage\n\t\t\t\tif (!sessionStorage.getItem('snf_type')) {\n\t\t\t\t\tconst formValue = type.getAttribute('data-value');\n\t\t\t\t\tsessionStorage.setItem('snf_type', formValue);\n\t\t\t\t}\n\t\t\t}\n\t\t\n\t\t\t// Then attach the click event listener to all types regardless\n\t\t\ttype.addEventListener('click', () => {\n\t\t\t\tconst formValue = type.getAttribute('data-value');\n\t\t\n\t\t\t\ttypes.forEach((otherType) => {\n\t\t\t\t\totherType.classList.remove('active');\n\t\t\t\t});\n\t\t\n\t\t\t\ttype.classList.add('active');\n\t\t\t\tsessionStorage.setItem('snf_type', formValue);\n\t\t\t});\n\t\t});\n\t}\n\n\tloading_start() {\n\t\tdocument.getElementsByClassName('progress')[0].style.width = '0%';\n\t\tdocument.getElementsByClassName('percentage')[0].innerHTML = '0%';\n\n\t\tlet count = 0;\n\t\tconst progressBar = document.querySelector('.progress');\n\t\tconst percentage = document.querySelector('.percentage');\n\t\tconst interval = setInterval(() => {\n\t\t\tcount = count + 2;\n\t\t\tprogressBar.style.width = count + '%';\n\t\t\tpercentage.innerHTML = count + '%';\n\t\t\tif (count === 100) {\n\t\t\t\tclearInterval(interval);\n\n\t\t\t\tthis.handleFinishBtn();\n\t\t\t}\n\t\t}, 30);\n\t}\n\n\tstatic async showGeneratedSize() {\n\t\tconst sizeMatchFailed = document.querySelector('.sizematchfailed');\n\t\tconst generatedsize = document.querySelector('.generatedsize');\n\t\tconst snf_result= document.querySelector('.snf_result');\n\t\tconst generatedsizeValue = document.querySelector('.generatedsize .size');\n\t\tconst sizeMatchFailedValue = document.querySelector('.sizematchfailed .size');\n\t\tconst sizes = document.querySelectorAll('.buybox__variant--item');\n\t\tconst snfTriggerButton = document.querySelectorAll('.snf-trigger__btn');\n\t\tconst sizeHolder = document.getElementById('variation-1');\n\t\tconst trueSizeFields = document.querySelectorAll('.TrueSize');\n\t\tconst articleNumber = sessionStorage.getItem('snf_artnr');\n\t\tconst pdpArtnr = document.querySelector('.product-id-info').textContent;\n\n\t\tsessionStorage.setItem('snf_step', '1');\n\n\t\ttry {\n\t\t\tlet artnr = '';\n\n\t\t\tif (articleNumber && 1==0) {\n\t\t\t\tartnr = `&product_id=${articleNumber}`;\n\t\t\t} else if (pdpArtnr) {\n\t\t\t\tartnr = `&product_id=${pdpArtnr}`;\n\t\t\t}\n\t  \t\tlet startTime = performance.now();\n\t\t\tconst response = await fetch(`/cgi-bin/ibutik/API.fcgi?funk=PM&match_id=1&get_customer=1${artnr}`, {\n\t\t\t\tmethod: 'GET',\n\t\t\t\theaders: {\n\t\t\t\t\t'Content-Type': 'application/json'\n\t\t\t\t}\n\t\t\t});\n\n\n\t\t\tlet eventHandledTime = performance.now();\n\t\t\texponea.track('speed', {\n                        'action': 'snf_getSize',\n                        'speed': `${eventHandledTime - startTime}`\n                        \n            });\n    \n\n\t\t\tconst data = await response.json();\n\t\t\tif (data.value && generatedsize) {\n\t\t\t\tlet sizeFound = false;\n                let data_size = data.value;\n                let data_size_variant = data.value_variant;\n                if (data.alt_value) {\n                    data_size = data.alt_value;\n                } \n                if (data.alt_value_variant) {\n                    data_size_variant = data.alt_value_variant;\n                } \n\t\t\t\t// Matching sizes and checking for disabled class\n\t\t\t\tsizes.forEach((size) => {\n\t\t\t\t\tconst sizeValue = size.getAttribute('data-value');\n\t\t\t\t\t\n\t\t\t\t\tif (data_size === sizeValue || data_size_variant  === sizeValue) {\n\t\t\t\t\t\tsizeFound = true;\n\n\t\t\t\t\t\tconst snfTriggerButton = document.querySelectorAll('.snf-trigger__btn');\n\t\t\t\t\t\tsnfTriggerButton[0].classList.add('hide');\n\t\t\t\t\t\tif (size.classList.contains('disabled')) {\n\t\t\t\t\t\t\tsizes.forEach((size) => size.classList.remove('active'));\n\t\t\t\t\t\t\tgeneratedsize.classList.add('hide');\n\t\t\t\t\t\t\tsizeMatchFailed.classList.remove('hide');\n\t\t\t\t\t\t\tsnf_result.classList.remove('hide');\n\t\t\t\t\t\t\tsizeMatchFailedValue.textContent = data_size;\n\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\tif(data_size_variant){\n\t\t\t\t\t\t\t\tsizeHolder.dataset.value = data_size_variant;\n\t\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\t\tsizeHolder.dataset.value = data_size;\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\tsessionStorage.setItem('snf_size', data_size);\n\t\t\t\t\t\t\tif (size.classList.contains('active')) {\n\t\t\t\t\t\t\t\treturn;\n\t\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\t\tsize.click();\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\tif(data.value_variant){\n\t\t\t\t\t\t\t\tgeneratedsizeValue.textContent = data_size_variant;\n\t\t\t\t\t\t\t\t\n\t\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\t\tgeneratedsizeValue.textContent = data_size;\n\t\t\t\t\t\t\t\t\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\tgeneratedsize.classList.remove('hide');\n\t\t\t\t\t\t\tsnf_result.classList.remove('hide')\n\t\t\t\t\t\t\tsizeMatchFailed.classList.add('hide');\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t});\n\n\t\t\t\t// If the size was not found\n\t\t\t\tif (!sizeFound) {\n\t\t\t\t\tgeneratedsize.classList.add('hide');\n\t\t\t\t\tsizeMatchFailed.classList.remove('hide');\n\t\t\t\t\tif(data.value_variant){\n\t\t\t\t\t\t\tsizeMatchFailedValue.textContent = data.value_variant;\n\t\t\t\t\t\t\t\t\n\t\t\t\t\t} else {\n\t\t\t\t\t\t\t\tsizeMatchFailedValue.textContent = data_size;\n\t\t\t\t\t}\n\t\t\t\t\tsnf_result.classList.remove('hide')\n\t\t\t\t\tconst triggerButton = document.querySelector('button.sizeAndFitTrigger');\n\t\t\t\t\tsessionStorage.setItem('snf_size', 'not_found');\n\t\t\t\t\tif (triggerButton) {\n\t\t\t\t\t\ttriggerButton.classList.add('hide');\n\t\t\t\t\t}\n\n\t\t\t\t\n\t\t\t\t\ttrueSizeFields.forEach(function(field) {\n\t\t\t\t\t\tfield.classList.add('hide'); // Add the 'hide' class to each element\n\t\t\t\t\t});}\n\t\t\t\telse{\n\t\t\t\t\ttrueSizeFields.forEach(function(field) {\n\t\t\t\t\t\tfield.classList.add('hide'); // Add the 'hide' class to each element\n\t\t\t\t\t});\n\t\t\t\t}\n\t\t\t}\n\t\t\t\n\n\t\t\tconst height = document.getElementById('snf-height');\n\t\t\tconst weight = document.getElementById('snf-weight');\n\n\t\t\tif (data.field_x && data.field_y) {\n\t\t\t\tif (height && weight) {\n\t\t\t\t\theight.value = data.field_y;\n\t\t\t\t\tweight.value = data.field_x;\n\t\t\t\t}\n\t\t\t} else if (localStorage.getItem('snf_height') && localStorage.getItem('snf_weight')) {\n\t\t\t\tif (height && weight) {\n\t\t\t\t\theight.value = localStorage.getItem('snf_height');\n\t\t\t\t\tweight.value = localStorage.getItem('snf_weight');\n\t\t\t\t}\n\t\t\t}\n\n\t\t\twindow.dispatchEvent(new CustomEvent(\"snf_done\"));\n\t\t} catch (error) {\n\t\t\tconsole.error('Error:', error);\n\t\t}\n\t}\n\n\thandleFinishBtn() {\n\t\tconst finishButton = document.querySelector('.sizeandfit__finish');\n\t\tconst buyButton = document.getElementById('air-buy');\n\t\tconst sizeAndFit = document.querySelector('.sizeandfit');\n\n\t\tfinishButton.addEventListener(\n\t\t\t'click',\n\t\t\t(e) => {\n\t\t\t\te.stopPropagation();\n\t\t\t\te.preventDefault();\n\t\t\t\tconst sizeNFit = document.getElementById('sizeandfit');\n\t\t\t\tconst backdropBlur = document.querySelector('.backdrop');\n\n\t\t\t\tSizeAndFit.showGeneratedSize();\n\n\t\t\t\tbuyButton.click();\n\t\t\t\tsessionStorage.setItem('snf_step', '1');\n\t\t\t\tfinishButton.classList.add('hide');\n\t\t\t\tsizeAndFit.classList.remove('from-pdp');\n\n\t\t\t\tbackdropBlur.classList.remove('active');\n\t\t\t\tsizeNFit.classList.remove('active');\n\t\t\t},\n\t\t\t{ once: true }\n\t\t);\n\t}\n}\n","import SimpleSlider from \"../../views/product/simple_slider\";\n\nlet animating = false;\nlet decisionVal = 80;\nlet pullDeltaX = 0;\nlet startX = 0;\nlet $card;\nlet _this;\nexport default class StyleAdvisor {\n  constructor() {\n    this.init_events()\n\n    if (document.getElementById('datepicker')) {\n      this.initCalendar();\n    }\n  }\n\n  init_events() {\n    const backdropBlur = document.querySelector(\".backdrop\")\n    const styleadvisor = document.getElementById(\"styleadvisor\")\n    window.liveEvent(\".StyleAdviceTrigger\", \"click\", (event, element) => {\n\n      if (sessionStorage) {\n        this.uuid = sessionStorage.getItem(\"style_uuid\");\n        if (!this.uuid) {\n          this.uuid = this.uuidv4();\n          sessionStorage.setItem(\"style_uuid\", this.uuid);\n        }\n\n        this.styleCounter = sessionStorage.getItem(\"style_counter\");\n\n        if (!this.styleCounter) {\n          this.styleCounter = 1;\n        }\n\n        this.stored_style_type = sessionStorage.getItem(\"style_type\");\n      }\n\n      if (typeof(_imbox) !== \"undefined\") {\n        _imbox.push(['hideLauncher']);\n        _imbox.push(['hideWidget']);\n      }\n\n      styleadvisor.classList.add(\"active\")\n      if (styleadvisor.hasAttribute(\"data-step\")) {\n        const step = styleadvisor.dataset.step;\n        if (step === \"2\" || step === \"3\") {\n          styleadvisor.classList.add(\"live\");\n        }\n      }\n      backdropBlur.classList.add(\"active\")\n      document.body.classList.add(\"styleadvisor\")\n      if (!styleadvisor.dataset.step) {\n        if (this.stored_style_type) {\n          this.getContent(4, 1)\n        }\n        else {\n          this.getContent(1)\n        }\n        \n        if (document.querySelectorAll(\".styleadvisor .snapping--wrapper\").length) {\n          document.querySelectorAll(\".styleadvisor .snapping--wrapper\").forEach(function (elem) {\n            new SimpleSlider(elem)\n          })\n        }\n      }\n    })\n\n    window.liveEvent(\".menu__styleadvicer a\", \"click\", (event, element) => {\n      if (sessionStorage) {\n        this.uuid = sessionStorage.getItem(\"style_uuid\");\n        if (!this.uuid) {\n          this.uuid = this.uuidv4();\n          sessionStorage.setItem(\"style_uuid\", this.uuid);\n        }\n\n        this.styleCounter = sessionStorage.getItem(\"style_counter\");\n\n        if (!this.styleCounter) {\n          this.styleCounter = 1;\n        }\n\n        this.stored_style_type = sessionStorage.getItem(\"style_type\");\n      }\n\n      if (typeof(_imbox) !== \"undefined\") {\n        _imbox.push(['hideLauncher']);\n        _imbox.push(['hideWidget']);\n      }\n\n      styleadvisor.classList.add(\"active\")\n      \n      if (styleadvisor.hasAttribute(\"data-step\")) {\n        const step = styleadvisor.dataset.step;\n        if (step === \"2\" || step === \"3\") {\n          styleadvisor.classList.add(\"live\");\n        }\n      }\n      backdropBlur.classList.add(\"active\")\n      document.body.classList.add(\"styleadvisor\")\n      if (!styleadvisor.dataset.step) {\n        if (this.stored_style_type) {\n          this.getContent(4, 1)\n        }\n        else {\n          this.getContent(1)\n        }\n        const styleAdvisorSlider = document.querySelector(\n          \".styleadvisor .snapping--wrapper\"\n        )\n\n        if (styleAdvisorSlider) {\n          new SimpleSlider(styleAdvisorSlider)\n        }\n      }\n    })\n\n    window.liveEvent(\".continuePop .restart, .StyleAdviceRestart\", \"click\", (event, element) => {\n      this.currentSlide = 1;\n      this.updateCurrentSlide();\n\n      document.querySelectorAll(\".brands_list_brand.--checked\").forEach((elem) => {\n        elem.classList.remove(\"--checked\");\n      });\n      if (document.querySelectorAll(\".brand_continue .styleadvisor__continue\").length) {\n        document.querySelectorAll(\".brand_continue .styleadvisor__continue\")[0].classList.add(\"--disabled\");\n      }\n\n      document.querySelectorAll('.styleadvisor__step').forEach((item)=>{\n        if(item.dataset.step === '4'){\n          item.remove();\n        }\n      });\n\n      this.getContent(1, 0, 1)\n      styleadvisor.classList.remove(\"live\")\n    })\n\n    window.liveEvent(\".continuePop .continue\", \"click\", (event, element) => {\n      styleadvisor.classList.remove(\"live\")\n    })\n\n    window.liveEvent(\".styleadvisor_back\", \"click\", (event, element) => {\n      const styleadvisor = document.getElementById(\"styleadvisor\")\n      this.getContent(parseInt(styleadvisor.dataset.step) - 1)\n    })\n\n    window.liveEvent(\".styleadvisor__header .close, .personlizedContent .cm_article_wrapper a\", \"click\", () => {\n      if (typeof(_imbox) !== \"undefined\") {\n        _imbox.push(['showLauncher'])\n      }\n      styleadvisor.classList.remove(\"active\")\n      backdropBlur.classList.remove(\"active\")\n      document.body.classList.remove(\"styleadvisor\")\n      if (sessionStorage) {\n        this.test_completed = sessionStorage.getItem(\"test_completed\");\n        if (this.test_completed && this.test_completed !== '') {\n          location.reload();\n          sessionStorage.setItem(\"test_completed\", \"\");\n        }\n      }\n    })\n\n    window.liveEvent(\".styleadvisor__continue\", \"click\", (event, element) => {\n      if (element.classList.contains(\"--disabled\")) return\n      var step=document.querySelector('.styleadvisor__step.--active').dataset.step;\n      if(step === \"1\") {\n        if (sessionStorage) {\n          this.styleCounter++;\n          sessionStorage.setItem(\"style_counter\", this.styleCounter);\n        }\n        exponea.track('style_event', {'action': 'start','type': 'styleadvisor','stylerun': this.uuid + \"_\" + this.styleCounter});\n      }\n\n      if (step === \"3\")\n      {\n         if (document.getElementsByClassName(\"styleadvisor__loading_pageWrapper\")[0].style.display === 'none')\n         {\n           document.getElementsByClassName(\"brands_list\")[0].style.display = \"none\";\n           document.getElementsByClassName(\"brand_continue\")[0].style.display = \"none\";\n           document.getElementsByClassName(\"styleadvisor__loading_pageWrapper\")[0].style.display = \"block\";\n           this.loading_start();\n         }\n      }\n\n      const styleadvisor = document.getElementById(\"styleadvisor\")\n      this.getContent(parseInt(styleadvisor.dataset.step) + 1)\n    })\n\n    /* SWIPE FUNKTIONALITET */\n    // window.liveEvent(\".styleadvisor_swipe\", \"mousedown\", (event, element) => {\n    //  if (event.buttons == 1) {\n    //    this.swipeHandler(event, element);\n    //  }\n    // });\n    // window.liveEvent(\".styleadvisor_swipe\", \"touchstart\", (event, element) => {\n    //  this.swipeHandler(event, element);\n    // });\n\n    window.liveEvent(\".styleadvisor_brand\", \"click\", (event, element) => {\n      if (\n        document.querySelectorAll(\".styleadvisor_brand.--checked\").length < 800 ||\n        element.classList.contains(\"--checked\")\n      ) {\n        element.classList.toggle(\"--checked\")\n      }\n\n      const checkedBrands = document.querySelectorAll(\n        \".styleadvisor_brand.--checked\"\n      ).length\n      if (checkedBrands >= 2) {\n        this.toggleContinueButton(0)\n      } else {\n        this.toggleContinueButton(1)\n      }\n    })\n\n    window.liveEvent(\"#styleadvisor_like\", \"click\", (event, element) => {\n      if (!this.buttonsLocked) {\n        this.buttonsLocked = true;\n        this.triggerSwipe(event, element, \"liked\");\n        this.updateCurrentSlide();\n      }\n    })\n    window.liveEvent(\"#styleadvisor_dislike\", \"click\", (event, element) => {\n      if (!this.buttonsLocked) {\n        this.buttonsLocked = true;\n        this.triggerSwipe(event, element, \"disliked\");\n        this.updateCurrentSlide();\n      }\n    })\n\n    window.liveEvent(\".styleadvisor__loginBtn\", \"click\", (event, element) => {\n      const styleadvisor_login_form = document.getElementById(\n        \"styleadvisor-login-form-wrapper\"\n      )\n      if (styleadvisor_login_form) {\n        styleadvisor_login_form.classList.toggle(\"hidden\")\n      }\n    })\n\n    window.liveEvent(\"#styleadvisor-login-form-wrapper .close\", \"click\", (event, element) => {\n      const styleadvisor_login_form = document.getElementById(\n        \"styleadvisor-login-form-wrapper\"\n      )\n      styleadvisor_login_form.classList.toggle(\"hidden\")\n    })\n    window.liveEvent(\"#styleadvisor__createprofile .close\", \"click\", (event, element) => {\n      const styleadvisor_login_form = document.getElementById(\n        \"styleadvisor__createprofile\"\n      )\n      styleadvisor_login_form.classList.toggle(\"hidden\")\n    })\n\n    window.liveEvent(\"#styleadvisor-login-form\", \"submit\", (event, element) => {\n      event.preventDefault()\n      this.login(element)\n    })\n\n    window.liveEvent(\"#styleadvisor-create-form\", \"submit\", (event, element) => {\n      event.preventDefault()\n      this.createProfile(element)\n    })\n\n    window.liveEvent(\"#styleadvisor__create\", \"keyup\", (event, element) => {\n      if (\n        /^([a-zA-Z0-9_\\.\\-])+\\@(([a-zA-Z0-9\\-])+\\.)+([a-zA-Z0-9]{2,4})+$/.test(\n          element.value\n        )\n      ) {\n        this.toggleContinueButton(0)\n      } else {\n        this.toggleContinueButton(1)\n      }\n    })\n  }\n\n  async getContent(step, restoring, restart) {\n    const styleadvisor = document.getElementById(\"styleadvisor\")\n    styleadvisor.classList.add(\"loading\")\n\n    if (step == 1 && !restoring && !restart)\n    {\n        const response = await fetch(\n          \"shop?funk=get_restoring_style&custom_func=1\"\n        )\n        const result = await response.json()\n        if (result.restoring_style_type) {\n          step = 4;\n          restoring = 1;\n        }\n    }\n\n    if (!restoring)\n    {\n      restoring = 0;\n    }\n\n    if (step == 4 && !restoring) {\n      this.save_styleadvisor(1);\n    }\n\n    let existing_step = styleadvisor.querySelector(\n      '.styleadvisor__step[data-step=\"' + step + '\"]'\n    )\n    if (existing_step) {\n      document\n        .querySelectorAll(\".styleadvisor__step.--active\")\n        .forEach((element) => {\n          element.classList.remove(\"--active\")\n        })\n      existing_step.classList.add(\"--active\")\n      styleadvisor.dataset.step = step\n\n      document.querySelectorAll(\".styleadvisor_swipe\").forEach((element) => {\n        element.classList.remove(\"--liked\")\n        element.classList.remove(\"--disliked\")\n        element.classList.remove(\"--current\")\n        element.setAttribute(\"style\", \"\")\n      })\n      styleadvisor.classList.remove(\"loading\")\n      if (step === 3)\n      {\n         // Reset the counter if its visible\n         if (document.getElementsByClassName(\"styleadvisor__loading_pageWrapper\")[0].style.display === 'block')\n         {\n           document.getElementsByClassName(\"brands_list\")[0].style.display = \"\";\n           document.getElementsByClassName(\"brand_continue\")[0].style.display = \"\";\n           document.getElementsByClassName(\"styleadvisor__loading_pageWrapper\")[0].style.display = \"none\";\n           document.getElementsByClassName(\"progress\")[0].style.width = \"0%\";\n           document.getElementsByClassName(\"percentage\")[0].innerHTML = \"0%\";\n         }\n      }\n    } else {\n      const response = await fetch(\n        \"shop?funk=get_style_advisor&custom_func=1&step=\" + step + \"&restoring=\" + restoring\n      )\n      const result = await response.json()\n\n      if (result.html) {\n        var newElement = document.createElement(\"div\")\n        newElement.className = \"styleadvisor__step --active\"\n        newElement.dataset.step = step\n        newElement.innerHTML = result.html\n\n        document\n          .querySelectorAll(\".styleadvisor__step.--active\")\n          .forEach((element) => {\n            element.classList.remove(\"--active\")\n          })\n\n        styleadvisor.appendChild(newElement)\n        styleadvisor.dataset.step = step\n\n        if (step == 2) {\n            // Set the total number of slides\n            this.totalSlides = document.getElementsByClassName(\"styleadvisor_swipe\").length;\n            this.currentSlide = 1;\n            document.getElementById(\"sa-totalSlides\").innerHTML = this.totalSlides;\n            this.updateCurrentSlide();\n        }\n\n        if (step == 4 && !restoring) {\n          var error_display = document.getElementById(\"style_advisor_error\");\n          if (error_display && window.getComputedStyle(error_display).display === 'block')\n          {\n            // error\n            exponea.track('style_event', {'action': 'error','type': 'styleadvisor','parameter': 'no_segment'});\n          }\n          else\n          {\n            // result_page\n            exponea.track('style_event', {'action': 'result_page','type': 'styleadvisor','stylerun': this.uuid + \"_\" + this.styleCounter, 'parameter': result.style_type});\n            sessionStorage.setItem(\"style_type\", result.style_type);\n          }\n        }\n\n        if (step == 6)\n        {\n            grecaptcha.render('captcha_element', {\n              'sitekey' : '6Lcs9cYUAAAAAO6RWrvcXgKPFUCI86ARhIsI7c5t'\n            });\n        }\n\n        styleadvisor.classList.remove(\"loading\")\n      }\n    }\n  }\n\n  loading_start() {\n    var interval;\n    var count = 0;\n    var progressBar = document.querySelector(\".progress\");\n    var percentage = document.querySelector(\".percentage\");\n    interval = setInterval(function() {\n      count++;\n      progressBar.style.width = count + \"%\";\n      percentage.innerHTML = count + \"%\";\n      if (count === 100) {\n        clearInterval(interval);\n      }\n    }, 50);\n  }\n\n  updateCurrentSlide() {\n    if (this.currentSlide <= this.totalSlides) {\n      document.getElementById(\"sa-count\").innerHTML = this.currentSlide;\n      this.currentSlide++;\n    }\n  }\n\n  releaseSlide() {\n    if (pullDeltaX >= decisionVal) {\n      $card.classList.add(\"--liked\")\n      $card.classList.remove(\"--current\")\n      _this.scaleBackgroundImages(1)\n\n      const segment_data = _this.get_segment_data_from_element($card)\n      _this.bloomreach_track(\"liked\", \"style_segment_image\", segment_data)\n    } else if (pullDeltaX <= -decisionVal) {\n      $card.classList.add(\"--disliked\")\n      $card.classList.remove(\"--current\")\n      _this.scaleBackgroundImages(1)\n\n      const segment_data = _this.get_segment_data_from_element($card)\n      _this.bloomreach_track(\"disliked\", \"style_segment_image\", segment_data)\n    } else {\n      $card.setAttribute(\"style\", \"transform: translateY(0) scale(1);\")\n      _this.scaleBackgroundImages(0)\n    }\n    pullDeltaX = 0\n\n    animating = false\n\n    if (\n      !document.querySelectorAll(\n        \".styleadvisor_swipe:not(.--liked, .--disliked)\"\n      ).length\n    ) {\n      _this.getContent(3)\n    }\n  }\n\n  swipeHandler(e, element) {\n    if (animating) return\n\n    $card = element\n    $card.classList.add(\"--current\")\n    startX = e.pageX || e.originalEvent.touches[0].pageX\n\n    document.addEventListener(\"mousemove\", this.handleMove, true)\n    document.addEventListener(\"touchmove\", this.handleMove, true)\n\n    _this = this\n\n    document.addEventListener(\"mouseup\", this.handleRelease, true)\n    document.addEventListener(\"touchend\", this.handleRelease, true)\n  }\n  /* SWIPE FUNKTIONALITET */\n  // handleMove(e) {\n  //  let x = e.pageX || e.originalEvent.touches[0].pageX;\n  //  pullDeltaX = (x - startX);\n  //  if (!pullDeltaX) return;\n\n  //  let percent = pullDeltaX < 1 ? pullDeltaX / 350 * -1 : pullDeltaX / 350 * 1;\n\n  //  animating = true;\n  //  let deg = pullDeltaX / 10;\n  //  $card.style.transform = \"translateX(\" + pullDeltaX + \"px) translateY(0px) scale(1) rotate(\" + deg + \"deg)\";\n\n  //  let opacity = pullDeltaX < 0 ? (pullDeltaX / 100 * -1) : pullDeltaX / 100;\n  //  $card.style.opacity = 1 - opacity * 0.3;\n  //  $card.classList.add(\"--current\");\n\n  //  _this.scaleBackgroundImages(percent);\n  // }\n\n  // handleRelease(e) {\n  //  document.removeEventListener(\"mousemove\", _this.handleMove, true);\n  //  document.removeEventListener(\"touchmove\", _this.handleMove, true);\n  //  document.removeEventListener(\"mouseup\", _this.handleRelease, true);\n  //  document.removeEventListener(\"touchend\", _this.handleRelease, true);\n\n  //  _this.releaseSlide();\n  // }\n\n  triggerSwipe(e, element, type) {\n    const currentImage = document.querySelectorAll(\n      \".styleadvisor_swipe:not(.--liked, .--disliked)\"\n    )[0]\n    if (!currentImage) {\n      return\n    }\n\n    currentImage.classList.add(\"--current\")\n\n    _this = this\n    let counter = 0\n    let swipeInterval = setInterval(function () {\n      counter++\n\n      let pullDeltaX = type == \"liked\" ? counter * 5 : counter * -5\n\n      let deg = pullDeltaX / 10\n      let opacity = pullDeltaX < 0 ? (pullDeltaX / 100) * -1 : pullDeltaX / 100\n\n      currentImage.style.transform =\n        \"translateX(\" +\n        pullDeltaX +\n        \"px) translateY(0px) scale(1) rotate(\" +\n        deg +\n        \"deg)\"\n      currentImage.style.opacity = 1 - opacity * 0.3\n\n      if (counter == 100) {\n        clearInterval(swipeInterval)\n        currentImage.classList.add(\"--\" + type)\n        const segment_data = _this.get_segment_data_from_element(currentImage)\n        _this.bloomreach_track(type, \"style_segment_image\", segment_data)\n\n        _this.buttonsLocked = false;\n\n        if (\n          !document.querySelectorAll(\n            \".styleadvisor_swipe:not(.--liked, .--disliked)\"\n          ).length\n        ) {\n          _this.getContent(3)\n        }\n      }\n      _this.scaleBackgroundImages(counter / 5)\n    }, 0)\n  }\n\n  scaleBackgroundImages(percent) {\n    const activeImages = document.querySelectorAll(\n      \".styleadvisor_swipe:not(.--liked, .--disliked, .--current)\"\n    )\n\n    let scale_drag = 0.1 * percent\n    let translate_drag = 2 * percent\n    let opacity_drag = 0.3 * percent\n\n    let scaleIncrement = scale_drag > 0.1 ? 1 : 0.9 + scale_drag\n    let transform = translate_drag > 2 ? 0 : 2 - translate_drag\n    let opacity = opacity_drag > 0.3 ? 1 : 0.7 + opacity_drag\n\n    activeImages.forEach((element) => {\n      element.style.transform =\n        \"translateY(\" + transform + \"px) scale(\" + scaleIncrement + \")\"\n      element.style.opacity = opacity\n\n      scaleIncrement = scaleIncrement - 0.1\n      transform = transform + 2\n      opacity = opacity > 0.4 ? opacity - 0.4 : 0\n    })\n  }\n\n  bloomreach_track(like_type, event_type, segment_data, title) {\n    if (!window.exponea) return;\n\n    window.exponea.track(\"style_event\", {\n      type: \"styleadvisor\",\n      action: like_type == \"liked\" ? \"like\" : \"dislike\",\n      parameter: event_type,\n      title: segment_data.title,\n      style_segment_1: segment_data.segment_1,\n      style_segment_2: segment_data.segment_2,\n      style_segment_3: segment_data.segment_3,\n      timestamp: Date.now(),\n      stylerun: this.uuid + '_' + this.styleCounter\n    })\n  }\n\n  get_segment_data_from_element(element) {\n    return {\n      title: element.dataset.id,\n      segment_1: element.dataset.id,\n      segment_2: element.dataset.id,\n      segment_3: element.dataset.id,\n    }\n  }\n\n  get_segment_data_from_brand(brand) {\n    return {\n      title: brand.dataset.name,\n      segment_1: brand.dataset.segment_1,\n      segment_2: brand.dataset.segment_2,\n      segment_3: brand.dataset.segment_3,\n    }\n  }\n\n  async login(form) {\n    if (!form.user.value && !form.pass.value) return\n\n    const data = new URLSearchParams(new FormData(form))\n\n    const response = await fetch(\"/shop\", {\n      method: \"POST\",\n      body: data,\n    })\n\n    const result = await response.json()\n\n    if (result.status.code == 200) {\n      document.getElementById(\"styleadvisor__loginwrapper\").style.display =\n        \"none\"\n      document.getElementById(\"styleadvisor__createwrapper\").style.display =\n        \"none\"\n      this.toggleContinueButton(0)\n      this.setLoginIcon();\n    } else {\n      document.getElementById(\"styleadvisor__login-error\").innerHTML =\n        \"Fel användaruppgifter\"\n    }\n  }\n\n  async createProfile(form) {\n    if (!form.user.value) return\n\n    const data = new URLSearchParams(new FormData(form))\n\n    const response = await fetch(\"/shop\", {\n      method: \"POST\",\n      body: data,\n    })\n\n    const result = await response.json()\n\n    if (result.status == 1) {\n      this.save_styleadvisor();\n      document.getElementById(\"styleadvisor__createprofile\").classList.add(\"hide\");\n\n      if (document.querySelectorAll(\"#styleadvisor__loginwrapper\").length) {\n        document.getElementById(\"styleadvisor__loginwrapper\").classList.add(\"hide\");\n      }\n      this.setLoginIcon();\n    }\n    else if (result.status == 2) {\n      document.getElementById(\"styleadvisor-create-password\").classList.remove(\"hide\");\n      document.getElementById(\"create-error\").innerHTML = result.message;\n    }\n  }\n\nasync save_styleadvisor(track) {\n  const brandList = [];\n  const segmentImages = [];\n\n  document.querySelectorAll(\".styleadvisor_brand.--checked\").forEach((element) => {\n    const segment_data = _this.get_segment_data_from_brand(element)\n    if (track)\n    {\n      _this.bloomreach_track(\"liked\", \"brand\", segment_data)\n    }\n    brandList.push(element.dataset.id);\n  });\n\n  if (track)\n  {\n    // Complete\n    exponea.track('style_event', {'action': 'complete','type': 'styleadvisor','stylerun': this.uuid + \"_\" + this.styleCounter});\n    sessionStorage.setItem(\"test_completed\", \"completed\");\n  }\n  document.querySelectorAll('.styleadvisor_swipe').forEach((element) => {\n    const imgs = element.getElementsByTagName('img');\n\n    let answer;\n\n    if (element.classList.contains('--disliked')) {\n      answer = '0';\n    } else if (element.classList.contains('--liked')) {\n      answer = '1';\n    }\n\n    if (imgs.length && answer !== '') {\n      segmentImages.push({ segment: element.dataset.id, image: imgs[0].getAttribute('src'), like: answer });\n    }\n  });\n\n  const data = new URLSearchParams();\n\n  data.append('funk', 'save_styleadvisor');\n  data.append('brands', JSON.stringify(brandList));\n  data.append('segment_data', JSON.stringify(segmentImages));\n\n  const response = await fetch('/shop', {\n    method: 'POST',\n    body: data\n  });\n\n  const result = await response.json();\n}\n\n  toggleContinueButton(locked) {\n    document\n      .querySelectorAll(\".styleadvisor__step.--active .styleadvisor__continue\")\n      .forEach((element) => {\n        if (locked) {\n          element.classList.add(\"--disabled\")\n        } else {\n          element.classList.remove(\"--disabled\")\n        }\n      })\n  }\n  test\n\n  async initCalendar() {\n    // <script type=\"text/javascript\" src=\"/themes/hypefront/design/script/vanilla-calendar.min.js\"></script>\n    let link = document.createElement(\"link\");\n    link.href = '/themes/hypefront/design/css/vanilla-calendar.min.css';\n    link.type = \"text/css\";\n    link.rel = \"stylesheet\";\n    document.getElementsByTagName(\"head\")[0].appendChild(link);\n\n    const d = new Date();\n    let currDay = d.getDate();\n    let currMonth = d.getMonth() + 1;\n    let currYear = d.getFullYear();\n\n    let monthLength = new Date(currYear, currMonth, 0).getDate();\n\n    if (currMonth < 10) {\n      currMonth = \"0\" + currMonth;\n    }\n    if (currDay < 10) {\n      currDay = \"0\" + currDay;\n    }\n\n    const qs = new URLSearchParams({\n      funk: 'Stilradgivning_Populate_Calendar',\n      year: currYear,\n      month: currMonth,\n      day: currDay,\n      monthLength: monthLength\n    }).toString();\n\n    const response = await fetch('/shop?' + qs);\n    const result = await response.json();\n    const enabledDays = [];\n\n    if (result && result['status'] === '1') {\n      if (result.json) {\n        this.dates = JSON.parse(result.json);\n\n        const dayExists = [];\n\n        for (let i = 0; i < this.dates.data.length; i++) {\n          const day = this.dates.data[i].starts_at.split(\"T\")[0];\n\n          if (!dayExists[day]) {\n            enabledDays.push(day);\n            dayExists[day] = true;\n          }\n        }\n      }\n\n    }\n\n    const obj = this;\n\n    const calendar = new VanillaCalendar('#datepicker', {\n      settings: {\n        lang: 'define',\n        range: {\n          enabled: enabledDays\n        }\n      },\n      locale: {\n        months: ['Januari', 'Februari', 'Mars', 'April', 'Maj', 'Juni', 'Juli', 'Augusti', 'September', 'Oktober', 'November', 'December'],\n        weekday: ['Sö', 'Må', 'Ti', 'On', 'To', 'Fr', 'Lö']\n      },\n      actions: {\n        clickDay(e, dates) {\n          if (dates.length == 0) return;\n          obj.getTimes(dates[0])\n        }\n      }\n    });\n    calendar.init();\n\n    document.getElementById('booking-btn').addEventListener('click', function () {\n      obj.bookTimeslot();\n    });\n  }\n\n  getTimes(day) {\n    const d = new Date(day);\n    let currDate = d.getDate();\n    let currMonth = d.getMonth() + 1;\n\n    if (currMonth < 10) {\n      currMonth = \"0\" + currMonth;\n    }\n    if (currDate < 10) {\n      currDate = \"0\" + currDate;\n    }\n\n    let timesHtml = '';\n    const obj = this;\n\n    for (let i = 0; i < this.dates.data.length; i++) {\n      const dateDay = this.dates.data[i].starts_at.split(\"T\")[0];\n\n      if (day !== dateDay) continue;\n\n      const time = this.dates.data[i].starts_at.split(\"T\")[1].split(\":00+\")[0];\n      const timestamp = parseInt(new Date(this.dates.data[i].starts_at).getTime() / 1000);\n\n      // Tider måste vara minst 6h from nu.\n      const timestampMin = parseInt(new Date().getTime() / 1000) + (6 * 60 * 60);\n\n      if (timestamp >= timestampMin) {\n        timesHtml += \"<div class='timepicker_time' data-start='\" + this.dates.data[i].starts_at + \"' data-end='\" + this.dates.data[i].ends_at + \"'>\" + time + \"</div>\";\n\n      }\n\n      document.getElementById('timepicker_times').innerHTML = timesHtml;\n\n      document.querySelectorAll('.timepicker_time').forEach(elem => {\n        elem.addEventListener('click', function () {\n          obj.reserveTimeslot(elem.dataset.start, elem.dataset.end, elem);\n        });\n      });\n\n    }\n  }\n\n  async reserveTimeslot(start, end, elem) {\n    if (!this.reserved_times) {\n      this.reserved_times = [];\n    }\n\n    if (!this.reserved_times[start]) {\n\n      const qs = new URLSearchParams({\n        funk: 'Stilradgivning_Reservera_Tid',\n        starts_at: start,\n        ends_at: end\n      }).toString();\n\n      const response = await fetch('/shop?' + qs);\n      const result = await response.json();\n\n      if (result && result['status'] === '1') {\n\n        document.querySelectorAll('.timepicker_time').forEach(elem => {\n          elem.classList.remove('reserved');\n        });\n\n        const json = JSON.parse(result.json);\n        elem.classList.add('reserved');\n        elem.setAttribute('res_id', json.id);\n        this.reserved_times[start] = json.id;\n      }\n    }\n  }\n\n  async bookTimeslot() {\n\n    const timeDiv = document.querySelector('.timepicker_time.reserved');\n    const phoneInput = document.getElementById('customer_phone');\n    const phone = phoneInput.value;\n    const thankyou_page_url = document.getElementById('thankyou_page_url').value;\n  \n    if (phone) {\n      phoneInput.classList.remove('error');\n    } else {\n      phoneInput.classList.add('error');\n      return false;\n    }\n\n    if (!timeDiv) return false;\n\n    const start = timeDiv.dataset.start;\n    const end = timeDiv.dataset.end;\n    const newDate = new Date(start);\n    const newDate_Ends = new Date(end);\n\n    const timestamp = parseInt(newDate.getTime() / 1000);\n    const timestamp_ends = parseInt(newDate_Ends.getTime() / 1000);\n    const resId = timeDiv.getAttribute('res_id');\n\n    const qs = new URLSearchParams({\n      funk: 'Stilradgivning_Boka_Tid',\n      starts_at: start,\n      starts_unix: timestamp,\n      ends_at: end,\n      ends_unix: timestamp_ends,\n      phone: phone,\n      res_id: resId\n    }).toString();\n\n    const response = await fetch('/shop?' + qs);\n    const result = await response.json();\n\n    if (result && result['status'] === '1') {\n      window.location.href = thankyou_page_url;\n      var br_phone = phone.replace(/^0/, \"0046\");\n      br_phone = br_phone.replace(/\\s/g, '');\n      exponea.track('style_event', {'action': 'accept','type': 'styleadvisor','parameter':'meeting','meeting_date': timestamp,'meeting_phone': br_phone});\n    } else {\n      alert('bokning kunde inte genomföras');\n    }\n  }\n \n  uuidv4() {\n    return ([1e7]+-1e3+-4e3+-8e3+-1e11).replace(/[018]/g, c =>\n      (c ^ crypto.getRandomValues(new Uint8Array(1))[0] & 15 >> c / 4).toString(16)\n    );\n  }\n\n  setLoginIcon() {\n    const login_icon = document.querySelector(\"#login-icon svg\");\n    const login_wrapper = document.getElementById(\"login-wrapper\");\n    const login_icon_html = login_icon.outerHTML;\n\n    login_icon.outerHTML = \"<a href='/shop?funk=dinsida'>\" + login_icon_html + \"</a>\";\n    document.querySelector(\"#login-icon svg\").setAttribute(\"fill\", \"black\");\n    login_wrapper.style.visibility = \"hidden\";\n  }\n\n}","export function formatPriceHtml(price, price_regular, campaign, price_prefix = \"\") {\n    const currency_prefix = window.shop_settings['currency_prefix'] || '';\n    const currency_suffix = window.shop_settings['currency_suffix'] || '';\n\n    price = _prettyPrice(price);\n\n    if (campaign) {\n        price_regular = _prettyPrice(price_regular);\n        return `<span class=\"buybox__price--regular--sale dark-black-text\">${currency_prefix}${price_prefix}${price_regular}${currency_suffix}</span>\n        <span class=\"buybox__price--campaign light-red-text dark-black-text\">${currency_prefix}${price_prefix}${price}${currency_suffix}</span>`;\n    } else {\n        return `<span class=\"buybox__price--regular dark-black-text\">${currency_prefix}${price_prefix}${price}${currency_suffix}</span>`;\n    }\n}\n\nfunction _prettyPrice(price) {\n    price = price.toString().replace(/\\B(?=(\\d{3})+(?!\\d))/g, ' ');\n    return price.replace(/\\./g, ',');\n}\n\nexport function executeJs(container) {\n    const scripts = container.getElementsByTagName('script');\n    for (let i = 0; i < scripts.length; i++) {\n        let execute = true;\n\n        if (scripts[i].getAttribute('type') === 'application/ld+json') {\n            execute = false;\n        }\n\n        if (execute) {\n            const consentType = scripts[i].getAttribute('consent_type');\n\n            if (consentType) {\n                execute = check_consent(consentType, \"\");\n            }\n        }\n\n        if (execute) {\n            const s = document.createElement(\"script\");\n\n            if (scripts[i].getAttribute('type') !== 'application/ld+json') {\n                s.text = scripts[i].innerHTML;\n\n                try {\n                    document.head.appendChild(s).parentNode.removeChild(s);\n                }\n                catch (err) {\n                    console.log(err);\n                }\n            }\n        }\n    }\n\n}\n\nexport function getCookie(name) {\n    var cookieArr = document.cookie.split(\";\");\n\n    for (var i = 0; i < cookieArr.length; i++) {\n        var cookiePair = cookieArr[i].split(\"=\");\n\n        if (name == cookiePair[0].trim()) {\n            return decodeURIComponent(cookiePair[1]);\n        }\n    }\n\n    return null;\n}\n\nexport function setStorage(name, value, expires) {\n    if (typeof (Storage) === 'undefined') return null;\n\n    if (expires) {\n        this.cart.expires = Date.now() + expires * 60000;\n    }\n    window.localStorage.setItem(name, JSON.stringify(value));\n}\n\nexport function removeStorage(name) {\n    if (typeof (Storage) === 'undefined') return null;\n    window.localStorage.removeItem(name);\n}\n\nexport function getStorage(name , expires) {\n    if (typeof (Storage) === 'undefined') return null;\n\n    let str = window.localStorage.getItem(name);\n\n    if (str == null) return undefined;\n\n    let data;\n\n    try {\n        data = JSON.parse(str);\n    } catch (e) {\n        return undefined;\n    }\n\n    if (data.expires && data.expires < Date.now()) {\n        return undefined;\n    }\n\n    return data;\n}\n","export default class BrandSearch {\n\n\tconstructor() {\n\t\tthis.init_events();\n\t}\n\n\tinit_events() {\n\t\twindow.liveEvent(\".brands_list_filter\", \"keyup\", (event, element) => {this.filter_brands(element.value, element.closest(\".brands_list\"));});\n\t\twindow.liveEvent(\".brands_list_show_all\", \"click\", (event, element) => {this.filter_brands(\"\", element.closest(\".brands_list\"))});\n\t\twindow.liveEvent(\".brands_list_letter\", \"click\", (event, element) => {\n\t\t\tthis.filter_brands_letter(element.innerText, element.closest(\".brands_list\"))\n\t\t});\n\t}\n\n\tfilter_brands(value, parent) {\n\t\tif (!value)\n\t\t{\n\t\t\tparent.querySelectorAll('.brands_list_brand, .brands_list_wrapper').forEach(element => {\n\t\t\t\telement.classList.remove(\"--hidden\");\n\t\t\t});\n\n\t\t\tparent.querySelectorAll('.brands_list_filter').forEach(element => {\n\t\t\t\telement.value = \"\";\n\t\t\t});\n\t\t}\n\t\telse\n\t\t{\n\t\t\tparent\n        .querySelectorAll(\".brands_list_wrapper\")\n        .forEach((element) => {\n          element.classList.remove(\"--hidden\")\n        })\n\n\t\t\tparent.querySelectorAll('.brands_list_brand').forEach(element => {\n\t\t\t\telement.classList.add(\"--hidden\");\n\t\t\t});\n\t\t\tparent.querySelectorAll('.brands_list_brand[data-value*=\"' + value.toLowerCase() + '\"]').forEach(element => {\n\t\t\t\telement.classList.remove(\"--hidden\");\n\t\t\t});\n\t\t\tparent.querySelectorAll('.brands_list_wrapper').forEach(element => {\n\t\t\t\tif (element.querySelectorAll('.brands_list_brand').length == element.querySelectorAll('.brands_list_brand.--hidden').length)\n\t\t\t\t{\n\t\t\t\t\telement.classList.add(\"--hidden\");\n\t\t\t\t}\n\t\t\t});\n\t\t}\n\t}\n\n\tfilter_brands_letter(letter, parent) {\n\t\tparent.querySelectorAll('.brands_list_brand').forEach(element => {\n\t\t\telement.classList.remove(\"--hidden\");\n\t\t});\n\n\t\tparent.querySelectorAll('.brands_list_wrapper').forEach(element => {\n\t\t\telement.classList.add(\"--hidden\");\n\t\t});\n\n\t\tparent.querySelectorAll('.brands_list_wrapper[data-letter*=\"' + letter.toLowerCase() + '\"]').forEach(element => {\n\t\t\telement.classList.remove(\"--hidden\");\n\t\t});\n\n\t\tparent.querySelectorAll('.brands_list_filter').forEach(element => {\n\t\t\telement.value = \"\";\n\t\t});\n\t}\n\n\t\n}\n\n  \n  ","export default class Checkout {\n\t\n}","export default class Reservation {\n\n\tconstructor(cart) {\n\t\tthis.cart = cart;\n\t\tthis.init();\n\t}\n\n\tinit() {\n\t\tdocument.querySelectorAll('.Stilradgivning_Artikel .Knapp_Kop a').forEach(element => {\n\t\t\telement.addEventListener('click', (e) => {\n\t\t\t\te.preventDefault();\n\t\t\t\tlet form = element.parentNode.parentNode.parentNode.parentNode.parentNode;\n\t\t\t\tlet product_id = form.altnr.value;\n\n\t\t\t\tif (product_id) {\n\t\t\t\t\tthis.cart.add_item(product_id, 1);\n\t\t\t\t}\n\t\t\t});\n\t\t});\n\t}\n}\n","import SimpleSlider from '../../views/product/simple_slider';\nimport { executeJs } from '../../scripts/utils.js';\nimport SizeAndFit from '../../components/size_and_fit/sizeAndFit';\n\nexport default class Ajaxify {\n\tconstructor(productPage, nav, filter) {\n\t\tthis.productPage = productPage;\n\t\tthis.navMenu = nav;\n\t\tthis.filter = filter;\n\t\tthis.isSetup = false;\n\t\tthis.productLoading = false;\n\t\tthis.productLoaded = false;\n\t\tthis.fromReqestType = '';\n\t\tthis.offset = 0;\n\t\tthis.initEvents();\n\t}\n\n\tinitEvents() {\n\t\twindow.liveEvent('.navigate-product', 'click', (event, element) => {\n\t\t\tif (document.querySelector('.backdrop').classList.contains('active')) {\n\t\t\t\tdocument.querySelector('.backdrop').classList.remove('active');\n\t\t\t\tdocument.querySelector('#air-cart-module').classList.remove('active');\n\t\t\t\tdocument.body.classList.remove('cart-open');\n\t\t\t\tdocument.body.style.overflow = '';\n\t\t\t}\n\t\t\tif (element.href) {\n\t\t\t\tevent.preventDefault();\n\t\t\t\tif (this.fromList(element)) {\n\t\t\t\t\t// Pass the element to the getProduct function\n\t\t\t\t\tthis.getProduct(element.href, element);\n\t\t\t\t} else {\n\t\t\t\t\tthis.navigatePage(element.href, 'product');\n\t\t\t\t}\n\t\t\t}\n\t\t});\n\n\t\tdocument.querySelectorAll('.Din_Sida_Onskelista_Wrapper .Knapp_Kop a').forEach((element) => {\n\n\t\t\telement.addEventListener('click', (e) => {\n\t\t\t\te.preventDefault();\n\n\n\t\t\t\tlet form = element.parentNode.parentNode.parentNode.parentNode.parentNode;\n\t\t\t\tlet product_id = form.altnr.value;\n\n\t\t\t\tif (product_id) {\n\t\t\t\t\tthis.cart.add_item(product_id, 1);\n\t\t\t\t}\n\t\t\t});\n\t\t});\n\n\t\tdocument.querySelectorAll('.toggle_content').forEach((toggleElement) => {\n\t\t\ttoggleElement.addEventListener('click', function() {\n\t\t\t\tconst targetSelector = toggleElement.getAttribute('data-target');\n\t\t\t\tconst targetElement = document.querySelector(targetSelector);\n\t\t\t\tif (targetElement) {\n\t\t\t\t\ttargetElement.classList.toggle('hide');\n\t\t\t\t}\n\t\t\t});\n\t\t});\n\n\t\tconst faqContainer = document.querySelector('.faq');\n\t\tif (faqContainer) {\n\t\t\tconst faqItems = faqContainer.querySelectorAll('ul li.accordion__item');\n\t\t\tconst faqData = [];\n\t\t\tfaqItems.forEach((item, index) => {\n\t\t\t\tconst question = item.querySelector('.accordion__item--btn').textContent.trim();\n\t\t\t\tconst answer = item.querySelector('ul').textContent.trim();\n\n\t\t\t\tfaqData.push({\n\t\t\t\t\t'@type': 'Question',\n\t\t\t\t\tname: question,\n\t\t\t\t\tacceptedAnswer: {\n\t\t\t\t\t\t'@type': 'Answer',\n\t\t\t\t\t\ttext: answer\n\t\t\t\t\t}\n\t\t\t\t});\n\t\t\t});\n\n\t\t\t// Create JSON-LD script element for schema markup\n\t\t\tconst script = document.createElement('script');\n\t\t\tscript.type = 'application/ld+json';\n\t\t\tscript.innerHTML = `\n\t\t\t{\n\t\t\t\t\"@context\": \"https://schema.org\",\n\t\t\t\t\"@type\": \"FAQPage\",\n\t\t\t\t\"mainEntity\": ${JSON.stringify(faqData)}\n\t\t\t}\n\t\t`;\n\n\t\t\t// Append the script element to the head of the document\n\t\t\tdocument.head.appendChild(script);\n\t\t}\n\n\t\twindow.liveEvent('#air-cart-module .close', 'click', (event, element) => {\n\t\t\tdocument.querySelector('.backdrop').classList.remove('active');\n\t\t\tdocument.querySelector('#air-cart-module').classList.remove('active');\n\t\t\tif (document.querySelector('#air-cart-module').classList.contains('error')) {\n\t\t\t\tdocument.querySelector('#air-cart-module').classList.remove('error');\n\t\t\t}\n\t\t\tdocument.body.classList.remove('cart-open');\n\t\t\tdocument.body.style.overflow = '';\n\t\t});\n\n\t\twindow.liveEvent('.backdrop', 'click', (event, element) => {\n\t\t\tif (document.querySelector('.backdrop').classList.contains('active')) {\n\t\t\t\tdocument.querySelector('.backdrop').classList.remove('active');\n\t\t\t\tdocument.querySelector('#air-cart-module').classList.remove('active');\n\t\t\t\tvar sizeandfitcontainer = document.querySelector('#sizeandfit');\n\t\t\t\tif (sizeandfitcontainer) {\n\t\t\t\t\tsizeandfitcontainer.classList.remove('active');\n\t\t\t\t\twindow.sizeNFitInitialized = false;\n\t\t\t\t}\n\t\t\t\tdocument.querySelector('#kundradgivning').classList.remove('active');\n\t\t\t\tdocument.querySelector('#styleadvisor').classList.remove('active');\n\t\t\t\tdocument.querySelector('#modal_area').classList.remove('active');\n\n\t\t\t\tif (document.querySelector('#air-cart-module').classList.contains('error')) {\n\t\t\t\t\tdocument.querySelector('#air-cart-module').classList.remove('error');\n\t\t\t\t}\n\t\t\t\tdocument.body.classList.remove('cart-open', 'sizeandfit-open', 'styleadvisor', 'kundradgivning');\n\t\t\t\tdocument.body.style.overflow = '';\n\t\t\t}\n\t\t});\n\n\t\twindow.liveEvent('.navigate', 'click', async(event, element) => {\n\t\t\tif (element.href) {\n\t\t\t\tthis.hash = window.location.hash;\n\t\t\t\tthis.element = element;\n\t\t\t\tlet listLoading = false;\n\t\t\t\tvar listSpinner = document.querySelector('.listspinner');\n\n\t\t\t\tevent.preventDefault();\n\n\t\t\t\tlistLoading = true;\n\t\t\t\tif ((listLoading = true)) {\n\t\t\t\t\t// Set a timeout to show the spinner after 100ms\n\t\t\t\t\tvar listTimeout = setTimeout(function() {\n\t\t\t\t\t\tlistSpinner.style.display = 'block';\n\t\t\t\t\t}, 100);\n\t\t\t\t}\n\n\t\t\t\tawait this.navigatePage(element.href, 'list');\n\n\t\t\t\tclearTimeout(listTimeout);\n\t\t\t\tlistSpinner.style.display = 'none';\n\t\t\t\tlistLoading = false;\n\t\t\t\tif (element.closest('.has__children')) {\n\t\t\t\t\telement.closest('.has__children').classList.add('reload');\n\t\t\t\t}\n\t\t\t}\n\t\t});\n\n\t\twindow.liveEvent('.productpage-back', 'click', (event, element) => {\n\t\t\thistory.back();\n\t\t});\n\n\t\twindow.onpopstate = (event) => {\n\t\t\tif (this.productLoaded) {\n\t\t\t\tthis.hideProduct();\n\t\t\t\tif (document.querySelector('.backdrop').classList.contains('active')) {\n\t\t\t\t\tdocument.querySelector('.backdrop').classList.remove('active');\n\t\t\t\t\tdocument.querySelector('#air-cart-module').classList.remove('active');\n\t\t\t\t\tif (document.querySelector('#air-cart-module').classList.contains('error')) {\n\t\t\t\t\t\tdocument.querySelector('#air-cart-module').classList.remove('error');\n\t\t\t\t\t}\n\t\t\t\t\tdocument.body.classList.remove('cart-open');\n\t\t\t\t\tdocument.body.style.overflow = '';\n\t\t\t\t}\n\t\t\t} else {\n\t\t\t\tif (event.state && event.state.ajax_nav) {\n\t\t\t\t\twindow.location = location.href;\n\t\t\t\t}\n\t\t\t}\n\t\t};\n\t}\n\n\tshowTooltip(elementWrapper, tooltip) {\n\t\telementWrapper.onmousemove = function(e) {\n\t\t\tvar x = e.clientX\n\t\t\t  , y = e.clientY;\n\t\t\ttooltip.style.top = y + 15 + 'px';\n\n\t\t\tif (tooltip.classList.contains('position-right')) {\n\t\t\t\ttooltip.style.left = x - 120 + 'px';\n\t\t\t} else {\n\t\t\t\ttooltip.style.left = x + 15 + 'px';\n\t\t\t}\n\t\t\tif (/Android|webOS|iPhone|iPad|iPod|BlackBerry/i.test(navigator.userAgent)) {\n\t\t\t\ttooltip.classList.add('active');\n\t\t\t\tsetTimeout(() => {\n\t\t\t\t\ttooltip.classList.remove('active');\n\t\t\t\t}, 3000);\n\t\t\t} else {\n\t\t\t\ttooltip.classList.add('active');\n\t\t\t}\n\t\t};\n\n\t\telementWrapper.onmouseout = function(e) {\n\t\t\ttooltip.classList.remove('active');\n\t\t};\n\t}\n\n\tfromList(element) {\n\t\tlet requestType = '';\n\n\t\tif (this.productLoaded)\n\t\t\treturn true;\n\n\t\tif (window.shop_settings) {\n\t\t\trequestType = window.shop_settings['request_type'];\n\t\t}\n\n\t\tif (requestType === 'product') {\n\t\t\treturn false;\n\t\t} else if (requestType === 'product_group' || requestType === 'brand' || requestType === 'brand_in_group' || requestType === 'search') {\n\t\t\treturn true;\n\t\t} else {\n\t\t\t// check for sliders\n\t\t\tif (element.parentNode.parentNode.classList.contains('snapping') || element.parentNode.parentNode.parentNode.classList.contains('product--list')) {\n\t\t\t\treturn true;\n\t\t\t} else {\n\t\t\t\treturn false;\n\t\t\t}\n\t\t}\n\t}\n\n\tsetup() {\n\t\tthis.mainContainer = document.getElementsByClassName('main')[0];\n\t\tthis.productContainer = document.createElement('main');\n\t\tthis.productContainer.id = 'main-second';\n\t\tthis.mainContainer.after(this.productContainer);\n\t\tthis.isSetup = true;\n\t}\n\n\tasync getProduct(url, element) {\n\t\t// Get the spinner element\n\t\tvar spinner = element.querySelector('.spinner');\n\n\t\t// Make sure the spinner element exists\n\t\tif (!spinner) {\n\t\t\t// If the spinner element does not exist, create a new element\n\t\t\tspinner = document.createElement('div');\n\t\t\tspinner.classList.add('spinner');\n\t\t\t// Append the spinner element to the clicked element\n\t\t\telement.appendChild(spinner);\n\t\t}\n\n\t\t// Set a timeout to show the spinner after 100ms\n\t\tvar timeout = setTimeout(function() {\n\t\t\tspinner.style.display = 'block';\n\t\t}, 100);\n\t\tif (!this.isSetup)\n\t\t\tthis.setup();\n\t\tif (this.productLoading)\n\t\t\treturn;\n\n\t\tif (!this.offset) {\n\t\t\tthis.offset = window.pageYOffset;\n\t\t}\n\n\t\tthis.productLoading = true;\n\t\tlet separator = url.includes('?') ? '&' : '?';\n\t\tlet productUrl = url + separator + 'sw=1';\n\n\t\tconst response = await fetch(productUrl);\n\t\tconst html = await response.text();\n\n\t\tthis.saveMeta();\n\n\t\tif (window.shop_settings) {\n\t\t\tthis.fromReqestType = window.shop_settings['request_type'];\n\t\t}\n\n\t\tthis.showProduct(html);\n\n\t\tthis.showProductBack();\n\n\t\tif (this.productLoaded) {\n\t\t\tclearTimeout(timeout);\n\t\t\tspinner.style.display = 'none';\n\t\t\twindow.history.replaceState({}, null, url);\n\t\t} else {\n\t\t\twindow.history.pushState({\n\t\t\t\tajax_nav: true\n\t\t\t}, null, url);\n\t\t}\n\t\tclearTimeout(timeout);\n\t\tspinner.style.display = 'none';\n\t\tthis.productLoading = false;\n\t\tthis.productLoaded = true;\n\t\twindow.dispatchEvent(new CustomEvent(\"pdp_ajax_loaded\"))\n\n\t\tsetTimeout(() => {\n\t\t\tsessionStorage.setItem('snf_artnr', document.querySelector('.product-id-info').textContent);\n\t\t}, 500);\n\n\t\tconst sizeAndFit = document.getElementById('sizeandfit');\n\t\tif (sizeAndFit) {\n\t\t\tconst backdropBlur = document.querySelector('.backdrop');\n\t\t\tconst sizeNFit = document.getElementById('sizeandfit');\n\t\t\tconst sizeNFitStep = sessionStorage.getItem('snf_step');\n\n\t\t\tdocument.querySelectorAll('.sizeAndFitTrigger').forEach(element => {\n\t\t\t\telement.addEventListener('click', () => {\n\t\t\t\t\tconst productPage = document.querySelector('.single-product');\n\t\t\t\t\tconst sizeAndFit = document.getElementById('sizeandfit');\n\t\t\t\t\tdocument.body.classList.add(\"sizeandfit-open\");\n\t\t\t\t\tif (productPage) {\n\t\t\t\t\t\tconst images = document.querySelectorAll('.productImg--wrapper img');\n\t\t\t\t\t\tconst productArtNr = document.querySelector('.product-id-info');\n\t\t\t\t\t\tsizeAndFit.classList.add('from-pdp');\n\n\t\t\t\t\t\tconst imageSource = images[0].getAttribute('src');\n\t\t\t\t\t\tsessionStorage.setItem('snf_image', imageSource);\n\t\t\t\t\t\tsessionStorage.setItem('snf_artnr', productArtNr.textContent);\n\t\t\t\t\t}\n\n\t\t\t\t\tbackdropBlur.classList.add('active');\n\t\t\t\t\tsizeNFit.classList.add('active');\n\t\t\t\t\tthis.activeStep();\n\n\t\t\t\t\tif (sizeNFitStep > '1') {\n\t\t\t\t\t\tthis.snfBackBtn();\n\t\t\t\t\t}\n\t\t\t\t});\n\t\t\t});\n\t\t}\n\t}\n\n\tshowProductBack() {\n\t\tthis.productContainer.querySelectorAll('.productpage-back').forEach(function(elem) {\n\t\t\telem.classList.remove('hidden');\n\t\t});\n\t}\n\n\tasync navigatePage(url, type) {\n\t\tif (!url)\n\t\t\treturn;\n\t\tif (!this.isSetup)\n\t\t\tthis.setup();\n\n\t\tlet separator = url.includes('?') ? '&' : '?';\n\t\tlet pageURL = url + separator + 'sw=1';\n\n\t\tconst response = await fetch(pageURL);\n\t\tconst html = await response.text();\n\n\t\tif (this.productLoaded) {\n\t\t\tthis.hideProduct();\n\t\t}\n\n\t\tthis.navMenu.hideMainNav(this.navMenu);\n\n\t\tthis.mainContainer.innerHTML = html;\n\n\t\twindow.history.pushState({\n\t\t\tajax_nav: true\n\t\t}, null, url);\n\n\t\texecuteJs(this.mainContainer);\n\n\t\tif (type === 'product') {\n\t\t\tthis.productPage.reinit();\n\t\t\tthis.mainContainer.querySelectorAll('.productpage-back').forEach(function(elem) {\n\t\t\t\telem.classList.remove('hidden');\n\t\t\t});\n\t\t\twindow.dispatchEvent(new CustomEvent(\"pdp_ajax_loaded\"));\n\n\t\t\tsetTimeout(() => {\n\t\t\t\tsessionStorage.setItem('snf_artnr', document.querySelector('.product-id-info').textContent);\n\t\t\t}, 500);\n\t\t} else if (type === 'list') {\n\t\t\tif (this.element && this.element.classList.contains('page__category--item')) {\n\t\t\t\tif (this.hash) {\n\t\t\t\t\twindow.location.hash = this.hash;\n\t\t\t\t}\n\t\t\t}\n\t\t\twindow.dispatchEvent(new CustomEvent(\"plp_ajax_loaded\"));\n\t\t\tinitializePage();\n\t\t\tthis.filter.reinit();\n\t\t}\n\n\t\tthis.initJs(document);\n\t\tthis.ajax_ga_pageview();\n\n\t\tthis.atm_pixels_after();\n\n\t\tdocument.querySelectorAll('.tooltip-span').forEach((tooltip) => {\n\t\t\tconst parent = tooltip.parentNode;\n\t\t\tthis.showTooltip(parent, tooltip);\n\t\t});\n\n\t\tif (type === \"list\") {\n\t\t\t// Create and dispatch the custom event\n\t\t\twindow.dispatchEvent(new CustomEvent(\"plp_ajax_loaded\"))\n\t\t}\n\n\t\tsetTimeout(() => {\n\t\t\twindow.scrollTo(0, 0);\n\t\t}, 10);\n\t}\n\n\tshowProduct(html) {\n\t\tthis.productContainer.innerHTML = html;\n\t\tthis.productContainer.style.display = 'block';\n\t\tthis.mainContainer.style.display = 'none';\n\t\twindow.scrollTo(0, 0);\n\t\texecuteJs(this.productContainer);\n\t\tthis.productPage.reinit();\n\t\tthis.initJs(this.productContainer);\n\t\tthis.ajax_ga_pageview();\n\t\tthis.atm_pixels_after();\n\t\tdocument.querySelector('#header').classList.remove('header__notScrolled');\n\t}\n\n\thideProduct() {\n\t\tif ('scrollRestoration' in history) {\n\t\t\thistory.scrollRestoration = 'manual';\n\t\t}\n\n\t\tthis.mainContainer.style.display = 'block';\n\t\tthis.productContainer.style.display = 'none';\n\t\tthis.productContainer.innerHTML = '';\n\t\tthis.productLoaded = false;\n\n\t\tthis.resetMeta();\n\n\t\tsetTimeout(() => {\n\t\t\twindow.scrollTo(0, this.offset);\n\t\t\tthis.offset = 0;\n\t\t}, 10);\n\t}\n\n\tsaveMeta() {\n\t\tconst titleElem = document.getElementsByTagName('title')[0];\n\t\tconst relElem = document.querySelector(\"link[rel='canonical']\");\n\n\t\tif (!titleElem.dataset.reset) {\n\t\t\ttitleElem.dataset.reset = document.title;\n\t\t}\n\n\t\tif (relElem && !relElem.dataset.reset) {\n\t\t\trelElem.dataset.reset = relElem.href;\n\t\t}\n\t}\n\n\tresetMeta() {\n\t\tconst titleElem = document.getElementsByTagName('title')[0];\n\t\tconst relElem = document.querySelector(\"link[rel='canonical']\");\n\n\t\tif (window.shop_settings) {\n\t\t\twindow.shop_settings['request_type'] = this.fromReqestType;\n\t\t}\n\n\t\tif (titleElem.dataset.reset) {\n\t\t\tdocument.title = titleElem.dataset.reset;\n\t\t\ttitleElem.dataset.reset = '';\n\t\t}\n\n\t\tif (relElem && relElem.dataset.reset) {\n\t\t\trelElem.href = relElem.dataset.reset;\n\t\t\trelElem.dataset.reset = '';\n\t\t}\n\t}\n\n\tinitJs(container) {\n\t\tcontainer.querySelectorAll('.snapping--wrapper').forEach(function(elem) {\n\t\t\tnew SimpleSlider(elem);\n\t\t});\n\n\t\twindow.lazyLoadInstance.update();\n\n\t\t/* Produkt grid bredd toggle - mobil */\n\t\tlet tabLink = document.querySelectorAll('.tab-link');\n\n\t\tlet videoWrapper = document.querySelector('.video');\n\t\tlet videoElem = document.querySelector('video');\n\t\t// Init videos if needed.\n\t\tcontainer.querySelectorAll('video, .videoInfoWrapper').forEach(function(elem) {\n\t\t\telem.addEventListener('click', function() {\n\t\t\t\tif (videoElem.paused) {\n\t\t\t\t\tvideoElem.play();\n\t\t\t\t} else {\n\t\t\t\t\tvideoElem.pause();\n\t\t\t\t}\n\t\t\t\tvideoWrapper.classList.toggle('playing');\n\t\t\t\tvideoWrapper.classList.add('started');\n\t\t\t});\n\t\t});\n\t}\n\tajax_ga_pageview() {\n\t\tif (typeof ga !== 'undefined') {\n\t\t\tsetTimeout(() => {\n\t\t\t\tconst page = window.location.pathname + window.location.search;\n\t\t\t\tga('set', 'page', page);\n\t\t\t\tga('send', 'pageview');\n\t\t\t}, 1);\n\t\t}\n\t}\n\tatm_pixels_after() {\n\t\tif (typeof atm_pixels_after_function !== 'undefined' && typeof atm_pixels_after_function === 'function') {\n\t\t\tatm_pixels_after_function();\n\t\t}\n\t}\n}\n","import { formatPriceHtml } from \"../../scripts/utils.js\";\n\nexport default class BundleProduct {\n\n    constructor(bundleData, buyButton) {\n        this.bundleData = bundleData;\n        this.fields = document.getElementsByClassName('buybox__bundles--items');\n        this.fieldItems = document.getElementsByClassName('buybox__bundles--item');\n        this.buyButton = buyButton;\n\n        this.init();\n    }\n\n    init() {\n        this.initEvents();\n    }\n\n    initEvents() {\n        // if bundle fields are selects.\n        // for (const f of this.fields) {\n        //    f.addEventListener('change', () => this.updateField());\n        // }\n\n        for (const f of this.fieldItems) {\n            f.addEventListener('click', (e) => this.updateFieldEvent(e));\n        }        \n    }\n\n    updateFieldEvent(e) {\n        let button = e.target;\n        const field = button.parentNode;\n    \n        this.buyButton.classList.remove('alert-disabled');\n        const alert = document.getElementById('alert-popup');\n\n        if (alert) {\n            alert.remove();\n        }\n\n        for (const c of field.children) {\n            if (c == button) {\n                c.classList.add('active');\n                field.dataset.value = c.dataset.value;\n            } else {\n                c.classList.remove('active');\n            }\n        }\n\n        this.updateField();\n    }\n\n    updateField() {\n        this.updateFields();\n    }\n\n    updateFields() {\n        let ids = [];\n\n        for (const field of this.fields) {\n            ids.push(field.dataset.value);\n        }\n\n        let price = 0;\n        let priceRegular = 0;\n        let campaign = false;\n\n        for (const [index, field] of this.bundleData.entries()) {\n            ids.sort();\n            field.items.sort();\n            \n            for (const item of field.items) {\n                if (ids[index] == item.id) {\n\n                    if (!item.price) {\n                        return;\n                    }\n\n                    if (item.campaign) {\n                        campaign = true;\n                        priceRegular += Number(item.price_regular);\n                    } else {\n                        priceRegular += Number(item.price);\n                    }\n\n                    price += Number(item.price);\n                }\n            }\n        }\n\n        const elems = document.getElementsByClassName('price-info');\n\n        for (var elem of elems) {\n            elem.innerHTML = formatPriceHtml(price, priceRegular, campaign);\n        }\n    }\n}\n","import { setStorage, removeStorage, getStorage } from \"../../scripts/utils.js\";\nexport default class Filter {\n\n\tconstructor() {\n\t\tthis.init();\n\t}\n\n\treinit() {\n\t\tthis.init();\n\t\tdocument.dispatchEvent(new Event(\"after_filter\"));\n\t}\n\n\tinit() {\n\t\tif (document.getElementsByClassName('page__filter').length == 0) return;\n\t\tif (window.location.hash) this.setFilterFromHash();\n\n\t\tlet main = document.querySelector(\"main\")\n\t\tlet grid = document.querySelector(\".product--group\")\n\t\tlet gridToggles = document.querySelectorAll(\".grid-icon\")\n\n\t\tif (screen.width < 768 && getStorage('air_view_' + filterSettings.get('id')) == 'single') {\n\t\t\tmain.classList.add(\"single\")\n\t\t\tgrid.classList.add(\"single\")\n\n\t\t\tgridToggles.forEach((element) => {\n\t\t\t\tif (element.classList.contains('single')) {\n\t\t\t\t\telement.classList.add(\"active\")\n\t\t\t\t} else {\n\t\t\t\t\telement.classList.remove(\"active\")\n\t\t\t\t}\n\t\t\t})\n\t\t}\n\n\t\tgridToggles.forEach((element) => {\n\t\t\telement.addEventListener(\"click\", function () {\n\t\t\t\tgridToggles.forEach(function (item) {\n\t\t\t\t\titem.classList.remove(\"active\")\n\t\t\t\t})\n\t\t\t\telement.classList.add(\"active\")\n\n\t\t\t\tif (element.classList.contains(\"single\")) {\n\t\t\t\t\tmain.classList.add(\"single\")\n\t\t\t\t\tgrid.classList.add(\"single\")\n\t\t\t\t\tsetStorage('air_view_' + filterSettings.get('id'), 'single');\n\t\t\t\t} else {\n\t\t\t\t\tmain.classList.remove(\"single\")\n\t\t\t\t\tgrid.classList.remove(\"single\")\n\t\t\t\t\tremoveStorage('air_view_' + filterSettings.get('id'));\n\t\t\t\t}\n\t\t\t})\n\t\t})\n\n\t\tdocument.querySelectorAll(\".filter_link\").forEach((element) => {\n\t\t\telement.addEventListener(\"click\", () => {\n\t\t\t\tthis.clearFilter();\n\t\t\t\tconst ids = element.dataset.id.split(',');\n\t\t\t\tconst values = element.dataset.value.toLowerCase().split(',');\n\n\t\t\t\tids.forEach((id) => {\n\t\t\t\t\tdocument.querySelectorAll(\".filter__container\").forEach((w) => {\n\t\t\t\t\t\tif (w.dataset.id == id) {\n\t\t\t\t\t\t\tw.querySelectorAll(\".filter__container--items\").forEach((input) => {\n\t\t\t\t\t\t\t\t\tif (values.includes(input.dataset.filter.toLowerCase())) {\n\t\t\t\t\t\t\t\t\t\t\tinput.click();\n\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t});\n\t\t\t\t\t\t}\n\t\t\t\t\t});\n\t\t\t\t});\n\t\t\t});\n\t\t});\n\n\n\t\tthis.moreButton = document.getElementById('filter_more');\n\t\tthis.sortSelect = document.getElementById(\"sort-order\");\n\n\t\tdocument.querySelectorAll('.filter__title').forEach(filter => {\n\t\t\tfilter.addEventListener('click', function (event) {\n\n\t\t\t\tvar active_filter = document.querySelector('.filter.--active');\n\t\t\t\tif (active_filter) {\n\t\t\t\t\tif (active_filter != filter.parentNode) {\n\t\t\t\t\t\tactive_filter.classList.remove(\"--active\");\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t\tfilter.parentNode.classList.toggle('--active');\n\t\t\t})\n\t\t});\n\n\t\tdocument.querySelectorAll('.ul-li-list span').forEach(element => {\n\t\t\telement.addEventListener('click', event => element.parentNode.classList.toggle('--active'));\n\t\t});\n\n\t\tdocument.querySelectorAll('.btn--filter, .page--settings--head').forEach(button => {\n\t\t\tbutton.addEventListener('click', function (event) {\n\t\t\t\tdocument\n\t\t\t\t\t.querySelectorAll(\n\t\t\t\t\t\t\".page--settings--wrapper, departments--settings--wrapper\"\n\t\t\t\t\t)\n\t\t\t\t\t.forEach((element) => {\n\t\t\t\t\t\telement.classList.toggle(\"--active\")\n\t\t\t\t\t\tdocument.querySelector(\".backdrop\").classList.toggle(\"filter-open\")\n\t\t\t\t\t})\n\t\t\t});\n\t\t});\n\n\t\tdocument.querySelectorAll('.filter__container--items').forEach(element => {\n\t\t\telement.addEventListener('click', event => this.handleEvent(element, event));\n\t\t});\n\n\t\tthis.paginationEvents();\n\n\t\tdocument.querySelectorAll('.filter_clear').forEach(element => {\n\t\t\telement.addEventListener('click', event => { this.clearFilter(); this.get() });\n\t\t});\n\n\t\tif (this.moreButton) this.moreButton.addEventListener('click', event => {\n\t\t\t\n\t\t\tif (!this.load) {\n\t\t\t\tthis.load = true;\n\t\t\t\tthis.get(filterSettings.get('current_offset') ? filterSettings.get('current_offset') : filterSettings.get('page_size'), 1);\n\t\t\t\tthis.infinit_scroll();\n\t\t\t\thistory.scrollRestoration = \"manual\";\n\t\t\t};\n\t\t});\n\t\tif (this.sortSelect) this.sortSelect.addEventListener('change', event => {\n\t\t\tthis.get();\n\t\t\tlet [sort, order] = this.sortSelect ? this.sortSelect.value.split('-') : [\"\", \"\"];\n\t\t\tthis.setState({\n\t\t\t\t\"sort\": sort,\n\t\t\t\t\"order\": order,\n\t\t\t\t\"page\": '',\n\t\t\t});\n\t\t});\n\n\t\tdocument.querySelectorAll('#sort-order-ul li').forEach(element => {\n\t\t\telement.addEventListener('click', event => {\n\t\t\t\tdocument.querySelectorAll('#sort-order-ul li').forEach(sort_li => {\n\t\t\t\t\tsort_li.classList.remove(\"--active\");\n\t\t\t\t});\n\t\t\t\tdocument.querySelectorAll('.active_sort_label').forEach(label => {\n\t\t\t\t\tlabel.innerHTML = element.innerHTML;\n\t\t\t\t});\n\t\t\t\telement.classList.add(\"--active\");\n\n\t\t\t\telement.parentNode.parentNode.classList.remove('--active');\n\n\t\t\t\tthis.get();\n\t\t\t\tlet [sort, order] = element.dataset.value.split('-');\n\n\t\t\t\tthis.setState({\n\t\t\t\t\t\"sort\": sort,\n\t\t\t\t\t\"order\": order,\n\t\t\t\t\t\"page\": ''\n\t\t\t\t});\n\n\t\t\t\tdocument.dispatchEvent(new CustomEvent(\"sort_changed\", {\n\t\t\t\t\t'detail': {\n\t\t\t\t\t\t'sort': sort,\n\t\t\t\t\t\t'order': order\n\t\t\t\t\t}\n\t\t\t\t}));\n\t\t\t});\n\t\t});\n\n\t\tdocument.querySelectorAll('.brand_filter_input').forEach(element => {\n\t\t\telement.addEventListener('keyup', event => { this.filter_brands(element.value); });\n\t\t});\n\n\t\twindow.liveEvent(\"body\", \"click\", (event, element) => {\n\t\t\tdocument.querySelectorAll('.filter.--active').forEach(active_filter => {\n\n\t\t\t\tif (!active_filter.contains(event.target)) {\n\t\t\t\t\tactive_filter.classList.remove(\"--active\");\n\t\t\t\t}\n\t\t\t});\n\n\t\t\tdocument.querySelectorAll('.filter.--active, .ul-li-list.--active').forEach(active_filter => {\n\n\t\t\t\tif (!active_filter.contains(event.target)) {\n\t\t\t\t\tactive_filter.classList.remove(\"--active\");\n\t\t\t\t}\n\t\t\t});\n\t\t});\n\n\t\tdocument.addEventListener('refresh_filter', () => {\n\t\t\tthis.get();\n\t\t});\n\t}\n\n\thandleEvent(element, event) {\n\t\tevent.preventDefault();\n\n\t\tif (element.classList.contains('--disabled')) return;\n\n\t\telement.classList.toggle('--active');\n\t\tthis.get();\n\n\t\t/* Scroll to filter on filterselect */\n\t\tconst ScrollToFilter = document.getElementById('FilterAnchor');\n\t\tconst headerHeight = document.getElementById('header').offsetHeight\n\t\twindow.scrollTo({\n\t\t\ttop: ScrollToFilter.offsetTop - headerHeight,\n\t\t\tleft: 0,\n\t\t\tbehavior: 'smooth'\n\t\t});\n\n\t}\n\n\tupdateFilterCount() {\n\t\t/* Filter choice counter*/\n\t\tlet filters = document.querySelectorAll(\".page__filter .filter\")\n\t\tfilters.forEach((filter) => {\n\t\t\tlet activeFilter = filter.querySelectorAll(\n\t\t\t\t\".filter__container--items.--active\"\n\t\t\t)\n\t\t\tif (activeFilter.length > 0) {\n\t\t\t\tfilter.querySelector(\".active_nbr\").innerHTML =\n\t\t\t\t\t\"<span class='filterCount'>(\" + activeFilter.length + \")</span>\"\n\t\t\t} else {\n\t\t\t\tfilter.querySelector(\".active_nbr\").innerHTML = ''\n\t\t\t}\n\t\t})\n\t}\n\n\tasync get(offset, append) {\n\t\tthis.updateFilterCount();\n\n\t\tconst data = new URLSearchParams();\n\t\tlet filterParams = \"\";\n\n\t\toffset = offset ? offset : 0;\n\n\t\tconst selectedFilters = this.getSelectedFilters();\n\t\tthis.setSelectedFilterBoxes(selectedFilters);\n\n\t\tObject.keys(selectedFilters).forEach(id => {\n\t\t\tif (filterParams) filterParams += \";\";\n\t\t\tfilterParams += id + \":\";\n\n\t\t\tlet values = \"\";\n\t\t\tselectedFilters[id].forEach(value => {\n\t\t\t\tif (values) values += \",\";\n\t\t\t\tvalues += value;\n\t\t\t});\n\t\t\tfilterParams += values;\n\t\t});\n\n\t\tconst json_filter = JSON.stringify(selectedFilters);\n\t\tif (window.location.hash || json_filter !== \"{}\") {\n\t\t\twindow.location.hash = json_filter\n\t\t}\n\n\t\tlet [sort, order] = this.sortSelect ? this.sortSelect.value.split('-') : [\"\", \"\"];\n\n\t\tlet sort_ul = document.querySelectorAll('#sort-order-ul li.--active')[0];\n\t\t[sort, order] = sort_ul ? sort_ul.dataset.value.split('-') : [\"\", \"\"];\n\n\t\tdata.append('funk', 'get_filter');\n\t\tfilterSettings.get('request_type') === 'search' ? data.append('q', filterSettings.get('q')) : data.append('id', filterSettings.get('id'));\n\t\tdata.append('type', filterSettings.get('request_type'));\n\t\tdata.append('filter_params', json_filter);\n\t\tdata.append('json', 1);\n\t\tdata.append('sort', sort);\n\t\tdata.append('order', order);\n\t\tdata.append('offset', offset ? offset : 0);\n\n\t\tconst response = await fetch('/shop', {\n\t\t\tmethod: 'POST',\n\t\t\tbody: data\n\t\t});\n\n\t\tconst result = await response.json();\n\t\tif (result.request_data) {\n\t\t\tlet container = document.querySelector(\".row.product--group\");\n\t\t\tif (!container) return;\n\n\t\t\tif (result.request_data.filters) this.setInactive(result.request_data.filters);\n\n\t\t\tif (append) {\n\t\t\t\tcontainer.insertAdjacentHTML(\"beforeend\", result.request_data.html);\n\t\t\t}\n\t\t\telse {\n\t\t\t\tcontainer.innerHTML = result.request_data.html;\n\t\t\t}\n\n\t\t\tif (this.moreButton) {\n\t\t\t\tif (offset + result.request_data.count >= result.request_data.total_count) {\n\t\t\t\t\tconsole.log()\n\t\t\t\t\tthis.moreButton.style.display = 'none';\n\t\t\t\t\tthis.moreButton.classList.remove('infinite');\n\n\t\t\t\t}\n\t\t\t\telse {\n\t\t\t\t\tthis.moreButton.style.display = '';\n\t\t\t\t\tlet currentUrl = window.location.pathname\n\n\t\t\t\t\tif (typeof ga !== 'undefined') {\n\t\t\t\t\t\tga(\"set\", \"page\", currentUrl + \"#\" + offset + result.request_data.count)\n          \t\t\t\tga(\"send\", \"pageview\")\n\t\t\t\t\t}\n\t\t\t\t}\t\n\t\t\t}\n\n\t\t\tdocument.querySelectorAll('.filter_count_showing').forEach(element => {\n\t\t\t\telement.innerHTML = offset + result.request_data.count;\n\t\t\t});\n\t\t\tdocument.querySelectorAll('.filter_count_total').forEach(element => {\n\t\t\t\telement.innerHTML = result.request_data.total_count;\n\t\t\t});\n\n\t\t\twindow.lazyLoadInstance.update();\n\n\t\t\tfilterSettings.set('total_count', result.request_data.total_count);\n\t\t\tfilterSettings.set('current_offset', offset + result.request_data.count);\n\n\t\t\tif (!offset) {\n\t\t\t\tthis.setState({ \"page\": '' });\n\t\t\t\tthis.updatePagination(1);\n\t\t\t}\n\n\t\t\tdocument.dispatchEvent(new Event(\"after_filter\"));\n\t\t\tif (this.moreButton) this.moreButton.classList.remove('loading');\n\t\t\tthis.load = false;\n\t\t}\n\t}\n\n\tgetSelectedFilters() {\n\t\tlet selectedFilters = {};\n\n\t\tdocument.querySelectorAll('.filter__container').forEach(filter_type => {\n\t\t\tfilter_type.querySelectorAll('.filter__container--items.--active').forEach(option => {\n\t\t\t\tif (!selectedFilters[filter_type.dataset.id]) {\n\t\t\t\t\tselectedFilters[filter_type.dataset.id] = [];\n\t\t\t\t}\n\t\t\t\tselectedFilters[filter_type.dataset.id].push(option.dataset.value);\n\t\t\t});\n\t\t});\n\n\t\treturn selectedFilters;\n\t}\n\n\tclearFilter() {\n\t\tdocument.querySelectorAll('.filter__container .--active').forEach(item => {\n\t\t\titem.classList.remove('--active');\n\t\t});\n\t}\n\n\tsetSelectedFilterBoxes(selectedFilters) {\n\t\tlet selectedFilterBoxes = \"\";\n\t\tconst parent = document.getElementById('selected_filters');\n\t\tif (!parent) return;\n\n\t\tObject.keys(selectedFilters).forEach(id => {\n\n\t\t\tselectedFilters[id].forEach(value => {\n\t\t\t\tselectedFilterBoxes += '<span class=\"selected_filter light-beige-bg-20 text--uppercase\" data-id=\"' + id + '\" data-value=\"' + value + '\">' + value + '<svg width=\"9\" height=\"10\" viewBox=\"0 0 9 10\" fill=\"none\" xmlns=\"https://www.w3.org/2000/svg\"><path d=\"M8.5 1L4.5 5M4.5 5L0.5 9M4.5 5L8.5 9M4.5 5L0.5 1\" stroke=\"black\"/></svg></span>';\n\t\t\t});\n\t\t});\n\t\tparent.innerHTML = selectedFilterBoxes;\n\n\t\tdocument.querySelectorAll('.selected_filter').forEach(element => {\n\t\t\telement.addEventListener('click', event => { this.toggleFilterValue(element.getAttribute('data-id'), element.getAttribute('data-value')); this.get(); });\n\t\t});\n\n\t\tdocument.querySelectorAll('.filter_clear').forEach(element => {\n\t\t\tselectedFilterBoxes ? element.classList.remove(\"hide\") : element.classList.add(\"hide\");\n\t\t\tselectedFilterBoxes ? element.parentNode.classList.remove(\"hide\") : element.parentNode.classList.add(\"hide\")\n\t\t});\n\t}\n\n\tsetInactive(filters) {\n\t\tfilters.forEach(filter => {\n\t\t\tif (filter.type === \"Tree\") {\n\t\t\t\tthis.setInactiveTree(filter.id, filter.values);\n\t\t\t}\n\t\t\telse if (filter.type === \"Slider_Range\") {\n\t\t\t\tthis.setInactiveSlider(filter.id, filter.values);\n\t\t\t}\n\t\t\telse {\n\t\t\t\tthis.setInactiveList(filter);\n\t\t\t}\n\t\t});\n\t}\n\n\tsetInactiveList(filter) {\n\t\tlet id = filter.id;\n\t\tlet values = filter.values;\n\t\tlet type = filter.type;\n\n\t\tif (type === 'range') return;\n\n\t\tlet enabled_options = {};\n\t\tvalues.forEach(value => {\n\t\t\tenabled_options[value.value] = 1;\n\t\t});\n\n\t\tdocument.querySelectorAll('.filter__container[data-id=' + id + '] .filter__container--items').forEach(option => {\n\t\t\tenabled_options[option.dataset.value] ? option.classList.remove(\"--disabled\") : option.classList.add(\"--disabled\");\n\t\t});\n\t}\n\n\ttoggleFilterValue(id, value) {\n\t\tconst element = document.querySelector('.filter__container[data-id=\"' + id + '\"] .filter__container--items[data-value=\"' + value + '\"]');\n\t\tif (element) element.classList.toggle('--active')\n\n\t}\n\n\tsetFilterFromHash() {\n\t\tconst selectedFilters = JSON.parse(decodeURI(window.location.hash.slice(1)));\n\n\t\tObject.keys(selectedFilters).forEach(id => {\n\t\t\tselectedFilters[id].forEach(value => {\n\t\t\t\tthis.toggleFilterValue(id, value);\n\t\t\t});\n\t\t});\n\n\t\tif (Object.keys(selectedFilters).length) this.get();\n\t}\n\n\tsetState(inParams) {\n\t\tconst params = new URLSearchParams(window.location.search);\n\n\t\tObject.keys(inParams).forEach(name => {\n\t\t\tinParams[name] ? params.set(name, inParams[name]) : params.delete(name);\n\t\t});\n\n\t\tlet newUrl = window.location.pathname;\n\t\tlet search = params.toString();\n\t\tif (search) {\n\t\t\tnewUrl += \"?\" + params.toString();\n\t\t}\n\n\t\tif (window.location.hash && window.location.hash !== \"#{}\") { newUrl += window.location.hash };\n\t\twindow.history.replaceState(null, \"\", decodeURIComponent(newUrl));\n\n\t\tif (typeof ga !== 'undefined') {\n\t\t\tga('set', 'page', newUrl)\n\t\t\tga('send', 'pageview')\n\t\t}\n\t}\n\n\tpaginationEvents() {\n\t\tdocument.querySelectorAll('.pagination-page:not(--dots)').forEach(element => {\n\t\t\telement.addEventListener('click', event => {\n\t\t\t\tthis.get((parseInt(element.textContent) - 1) * filterSettings.get('page_size'))\n\t\t\t\tthis.setState({ \"page\": element.textContent });\n\t\t\t\tthis.updatePagination(parseInt(element.textContent));\n\t\t\t\twindow.scrollTo({ top: 0, behavior: \"smooth\" });\n\t\t\t});\n\t\t});\n\t}\n\n\tupdatePagination(active_page) {\n\t\tlet number_of_pages = Math.ceil(filterSettings.get('total_count') / filterSettings.get('page_size'));\n\n\t\tif (active_page > number_of_pages) { active_page = number_of_pages; }\n\n\t\tlet pagination = active_page == 1 ? '<span class=\"pagination-page --active\">1</span>' : '<span class=\"pagination-page dark-grey-text\">1</span>';\n\t\tif (active_page - 2 > 2) {\n\t\t\tpagination += '<span class=\"pagination-page --dots dark-grey-text\">...</span>';\n\t\t}\n\n\t\tlet number = active_page - 2 > 2 ? active_page - 2 : 2;\n\t\tlet page_count = 1;\n\t\tlet loops = active_page < 4 ? 4 : 5;\n\n\t\twhile (number > 1 && number < number_of_pages && page_count <= loops) {\n\t\t\tif (number >= number_of_pages) break;\n\t\t\tpagination += active_page == number ? '<span class=\"pagination-page --active\">' + number + '</span>' : '<span class=\"pagination-page dark-grey-text\">' + number + '</span>';\n\n\t\t\tpage_count += 1;\n\t\t\tnumber += 1;\n\t\t}\n\n\t\tif (active_page + 3 < number_of_pages) {\n\t\t\tpagination += '<span class=\"pagination-page --dots dark-grey-text\">...</span>';\n\t\t}\n\n\t\tif (number_of_pages > 1) {\n\t\t\tpagination += active_page == number_of_pages ? '<span class=\"pagination-page --active\">' + number_of_pages + '</span>' : '<span class=\"pagination-page dark-grey-text\">' + number_of_pages + '</span>';\n\t\t}\n\n\t\tdocument.querySelectorAll('.page_navigation').forEach(element => {\n\t\t\telement.innerHTML = pagination;\n\t\t});\n\n\t\tthis.paginationEvents();\n\t}\n\n\tfilter_brands(value) {\n\t\tif (!value) {\n\t\t\tdocument.querySelectorAll('.filter__container[data-id=brand] .filter__item').forEach(element => {\n\t\t\t\telement.classList.remove(\"--hidden\");\n\t\t\t});\n\t\t}\n\t\telse {\n\t\t\tdocument.querySelectorAll('.filter__container[data-id=brand] .filter__item').forEach(element => {\n\t\t\t\telement.classList.add(\"--hidden\");\n\t\t\t});\n\n\t\t\tdocument.querySelectorAll('.filter__container[data-id=brand] .filter__item[data-filter*=\"' + value.toLowerCase() + '\"]').forEach(element => {\n\t\t\t\telement.classList.remove(\"--hidden\");\n\t\t\t});\n\n\t\t}\n\t}\n\n\tinfinit_scroll() {\n\t\tif (this.moreButton.classList.contains('infinite')) {\n\t\t\tlet count = parseInt(this.moreButton.dataset.count);\n\t\t\tcount == 3 ? this.moreButton.classList.remove(\"infinite\") : this.moreButton.setAttribute(\"data-count\", count + 1);\n\t\t}\n\t\telse {\n\t\t\tthis.moreButton.classList.add('infinite');\n\t\t\tthis.moreButton.setAttribute('data-count', 1);\n\n\t\t\tif (!this.moreButton.classList.contains('infinite_initiated')) {\n\t\t\t\tconst btn = this.moreButton;\n\n\t\t\t\twindow.onscroll = function () {\n\t\t\t\t\tif (btn) {\n\t\t\t\t\t\tconst to_top = btn.offsetTop - window.scrollY;\n\t\t\t\t\t\tif (to_top <= 2000) {\n\t\t\t\t\t\t\tif (!btn.classList.contains('loading') && btn.classList.contains('infinite')) {\n\t\t\t\t\t\t\t\tbtn.click();\n\t\t\t\t\t\t\t\tbtn.classList.add('loading');\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t};\n\t\t\t\tthis.moreButton.classList.add('infinite_initiated');\n\t\t\t}\n\t\t}\n\t}\n}","import Variation from \"./variation/variation\"\nimport BundleProduct from \"./bundle_product\"\nimport ImageZoom from \"./zoom\"\n\nexport default class ProductPage {\n  constructor(cart, buy_button_id = \"air-buy\", qty_input_id = \"air-qty\") {\n    this.cart = cart\n    this.buy_button_id = buy_button_id\n    this.qty_input_id = qty_input_id\n    this.alert_popup = undefined\n    this.closeAlert = undefined\n    if (window.shop_settings.request_type == \"product\") {\n      this.init()\n    }\n  }\n\n  reinit() {\n    if (typeof(lipscore) !== \"undefined\")\n    {\n      lipscore.initWidgets()\n    }\n    this.init()\n    document.dispatchEvent(new CustomEvent(\"product_cell_update\"))\n  }\n\n  init(status) {\n    this.buy_button = document.getElementById(this.buy_button_id)\n    this.qty_input = document.getElementById(this.qty_input_id)\n\n    document.dispatchEvent(new CustomEvent(\"product_page_viewed\"))\n    document.dispatchEvent(new CustomEvent(\"product_page_styleview\"))\n\n    if (window.variants) {\n      this.variations = new Variation(window.variants, this.buy_button)\n    } else if (window.bundle_fields) {\n      this.bundle = new BundleProduct(window.bundle_fields, this.buy_button)\n    }\n\n    if (this.buy_button) {\n      this.buy_button.addEventListener(\"click\", (e) => {\n        this.add_cart(e, this.buy_button)\n      })\n    }\n\n    // init simple buy buttons.\n    const btns = document.getElementsByClassName(\"buy-btn\")\n\n    for (const btn of btns) {\n      btn.addEventListener(\"click\", (e) => this.add_cart(e, btn))\n    }\n\n    this.initLipscore()\n\n    this.tabProps = document.getElementById(\"tab-properties\")\n\n    if (this.tabProps) {\n      this.tabProps.parentNode.addEventListener(\"click\", () => {\n        this.initTabProps()\n      })\n    }\n\n    /* ScrollTo more info about size */\n\n    const readMoreSize = document.querySelector(\".trueSizeLink\")\n    const readMoreScrollTo = document.querySelector(\".about--list\")\n\n    if (readMoreSize) {\n      readMoreSize.onclick = function () {\n        scrollToMore()\n      }\n    }\n    function scrollToMore() {\n      window.scrollTo({\n        top: readMoreScrollTo.offsetTop,\n        left: 0,\n        behavior: \"smooth\",\n      })\n    }\n\n    /* ScrollTo more info about size */\n    const readMoreReview = document.querySelector(\".buybox__rating\")\n    const readReviewScrollTo = document.querySelector(\"#reviewsAccordion\")\n    const triggerReview = document.querySelector(\"#reviewsAccordion > span\")\n    if (readMoreReview) {\n      readMoreReview.onclick = function () {\n        scrollToReview()\n      }\n    }\n    function scrollToReview() {\n      window.scrollTo({\n        top: readReviewScrollTo.offsetTop,\n        left: 0,\n        behavior: \"smooth\",\n      })\n      if (readReviewScrollTo.classList.contains(\"active\")) {\n      } else {\n        triggerReview.click()\n      }\n    }\n\n    if (!this.zoomInit) {\n      this.initZoom()\n    }\n\n    this.initTooltip()\n\n    // Handle add to cart for old gift card page.\n    this.handleGiftcards()\n  }\n\n  add_cart(e, elem) {\n    e.stopPropagation()\n\n    if (elem.classList.contains(\"alertable\")) {\n      this.show_alert_popup()\n      return\n    }\n\n    const product_id = elem.dataset.id\n    const qty = this.qty_input.value || 1\n    let extra_data = {}\n\n    if (elem.dataset.type === \"bundle\") {\n      const fields = this.bundle.fields\n\n      let fields_data = []\n\n      for (const f of fields) {\n        fields_data.push({ field_id: f.dataset.id, bundle_id: f.dataset.value })\n      }\n\n      extra_data[\"bundle_fields\"] = fields_data\n    }\n\n    elem.dispatchEvent(new CustomEvent(\"addToCart\"))\n\n    if (!product_id) {\n      return\n    }\n\n    this.cart.add_item(product_id, qty, extra_data)\n  }\n\n  async show_alert_popup() {\n    if (\n      this.buy_button.classList.contains(\"disabled\") ||\n      this.buy_button.classList.contains(\"alert-disabled\")\n    ) {\n      return\n    }\n\n    /* hide bevaka */\n\n    const product_id = this.buy_button.dataset.id\n    const stock_id = this.buy_button.dataset.stock_id\n\n    const response = await fetch(\n      \"/shop?funk=get_alert_popup&product_id=\" +\n        product_id +\n        \"&stock_id=\" +\n        stock_id\n    )\n    const result = await response.json()\n\n    if (result.status == 200) {\n      const data = result.data\n\n      let newsletter_html = \"\"\n\n      if (data.newsletter) {\n        newsletter_html = `\n                <div class=\"fs-12\">\n                    <input id=\"alert-newsletter\" type=\"checkbox\" />\n                    ${data.newsletter_phrase}\n                </div>\n                `\n      }\n\n      let html = `\n            <div id=\"alert-popup\" class=\"d-flex light-grey-b flex-column p-16 beige-tint-2-bg fs-14\">\n                <div id=\"close-alert\" class=\"close\">\n                    <svg width=\"17\" height=\"16\" viewBox=\"0 0 17 16\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n                    <path d=\"M2.99609 13.3333L13.6628 2.68511\" stroke=\"black\"/>\n                    <path d=\"M2.99609 2.66675L13.6535 13.3242\" stroke=\"black\"/>\n                    </svg>                \n                </div>\n                <div class=\"pb-8\">${data.heading}</div>\n                <div class=\"pb-8\">${data.phrase}</div>\n                <div class=\"pb-8 alert-input\">\n                    <input type=\"text\" id=\"alert-email\" placeholder=\"${data.placeholder}\" value=\"${data.email}\" />\n                    <button id=\"alert-save\" class=\"\">\n                        <svg width=\"17\" height=\"8\" viewBox=\"0 0 17 8\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n                            <path d=\"M16.6817 4.35355C16.8769 4.15829 16.8769 3.84171 16.6817 3.64645L13.4997 0.464466C13.3044 0.269204 12.9879 0.269204 12.7926 0.464466C12.5973 0.659728 12.5973 0.976311 12.7926 1.17157L15.621 4L12.7926 6.82843C12.5973 7.02369 12.5973 7.34027 12.7926 7.53553C12.9879 7.7308 13.3044 7.7308 13.4997 7.53553L16.6817 4.35355ZM0.328125 4.5H16.3281V3.5H0.328125V4.5Z\" fill=\"#082939\"/>\n                        </svg>\n                    </button>\n                </div>\n                ${newsletter_html}\n            </div>`\n\n      if (!this.alert_popup) {\n        this.alert_popup = document.createElement(\"div\")\n        this.buy_button.after(this.alert_popup)\n      }\n\n      this.alert_popup.innerHTML = html\n\n      const closeAlert = document.getElementById(\"close-alert\")\n      const alerPopup = document.getElementById(\"alert-popup\")\n\n      if (closeAlert) {\n        closeAlert.addEventListener(\"click\", function () {\n          alerPopup.parentNode.removeChild(alerPopup)\n        })\n      }\n\n      document.getElementById(\"alert-save\").addEventListener(\"click\", (e) => {\n        this.save_alert()\n      })\n    }\n  }\n\n  async save_alert() {\n    this.buy_button.classList.add(\"alert-disabled\")\n\n    const product_id = this.buy_button.dataset.id\n    const email = document.getElementById(\"alert-email\").value\n    const newsletter = document.getElementById(\"alert-newsletter\").checked\n\n    if (product_id && email) {\n      const data = new URLSearchParams()\n\n      data.append(\"funk\", \"save_alert\")\n      data.append(\"product_id\", product_id)\n      data.append(\"email\", email)\n      data.append(\"newsletter\", newsletter)\n\n      const response = await fetch(\"/shop\", {\n        method: \"POST\",\n        body: data,\n      })\n\n      const result = await response.json()\n\n      if (result.status == 200) {\n        this.alert_popup.remove()\n\n        if (result.data.phrase) {\n          const btnLabel =\n            this.buy_button.getElementsByClassName(\"air-buy-label\")[0]\n          btnLabel.innerHTML = result.data.phrase\n        }\n      }\n    }\n  }\n\n  initLipscore() {\n    setTimeout(function () {\n      const lipscoreWrapper = document.getElementById(\"lipscore-review-list\")\n      if (lipscoreWrapper && lipscoreWrapper.dataset[\"lsProductVotes\"] == 0) {\n        document\n          .getElementById(\"lipscore-review-list\")\n          .parentNode.parentNode.remove()\n      }\n    }, 400)\n  }\n\n  async initTabProps() {\n    if (this.tabPropsLoaded) return\n\n    this.tabPropsLoaded = true\n    const response = await fetch(\n      \"/cgi-bin/ibutik/API.fcgi?funk=get_tab_properties&artnr=\" +\n        window.product_id\n    )\n    const html = await response.text()\n    this.tabProps.innerHTML = html\n  }\n\n  handleGiftcards() {\n    const digital = document.getElementById(\"AIR_ibutik_laggtill_d\")\n    const irlGiftcard = document.getElementById(\"AIR_ibutik_laggtill_f\")\n\n    if (digital) {\n      const digitalBtn = digital.querySelector(\"a\")\n\n      digitalBtn.addEventListener(\"click\", (e) => {\n        this.addToCartGiftcard(e, digital)\n      })\n    }\n    if (irlGiftcard) {\n      const irlGiftcardBtn = irlGiftcard.querySelector(\"a\")\n\n      irlGiftcardBtn.addEventListener(\"click\", (e) => {\n        this.addToCartGiftcard(e, irlGiftcard)\n      })\n    }\n  }\n\n  async addToCartGiftcard(e, form) {\n    e.preventDefault()\n\n    const response = await fetch(\"/shop\", {\n      method: \"POST\",\n      body: new FormData(form),\n    })\n\n    this.cart.show(\"add\", { order: \"update_time\" })\n  }\n\n  initZoom() {\n    this.zoomInit = true\n    this.zoomActive = false\n\n    this.changeEvent = (e) => {\n      let tooltipSpan = document.querySelector(\n        \".snapping--wrapper .tooltip-span\"\n      )\n      if (this.zoomActive) {\n        tooltipSpan.classList.remove(\"notActive\")\n        this.removeZoom(e, this)\n      } else {\n        this.showZoom(e, this)\n        tooltipSpan.classList.add(\"notActive\")\n      }\n    }\n    this.removeEvent = (e) => {\n      this.removeZoom(e, this)\n    }\n    this.hoverEvent = (e) => {\n      this.showZoomHover(e, this)\n    }\n    this.hoverRemoveEvent = (e) => {\n      this.hideZoomHover(e, this)\n    }\n\n    this.imgWrapper = document.querySelector(\".single--product__img\")\n    this.imgWrapper.addEventListener(\"mouseover\", this.hoverEvent)\n    this.imgWrapper.addEventListener(\"mouseout\", this.hoverRemoveEvent)\n\n    document.addEventListener(\"slider_clicked\", this.changeEvent)\n    document.addEventListener(\"slider_changed\", this.removeEvent)\n  }\n\n  showZoomHover(e, _self) {\n    // Preload superzoom on hover.\n    if (!e.target.parentNode.classList.contains(\"superzoom-loaded\")) {\n      e.target.parentNode.classList.add(\"superzoom-loaded\")\n\n      if (e.target.parentNode.dataset.superzoom) {\n        let img = document.createElement(\"img\")\n        img.src = e.target.parentNode.dataset.superzoom\n      }\n    }\n  }\n\n  initTooltip() {\n    // let tooltipSpan = document.getElementById(\"tooltip-span\")\n    // let tooltipColor = document.getElementsByClassName(\"tooltip-color\")\n    // const imageWrapper =\n    //    document.querySelector(\".snapping--wrapper\")\n    // const colorWrapper = document.querySelector(\".row.variusColors\")\n\n    // let imageWrapper = document.querySelector('.single--product__img').parentNode;\n\n    // this.showTooltip(imageWrapper, tooltipSpan)\n    document.querySelectorAll(\".tooltip-span\").forEach((tooltip) => {\n      const parent = tooltip.parentNode\n\n      this.showTooltip(parent, tooltip)\n    })\n  }\n\n  hideZoomHover(e, _self) {}\n\n  showZoom(e, _self) {\n    // if (e.pointerType !== 'mouse') return;\n    _self.zoomActive = true\n    _self.zooms = []\n\n    _self.imgWrapper.removeEventListener(\"mouseover\", _self.hoverEvent)\n\n    let zoomWrapper = document.getElementById(\"zoomWrapper\")\n    let productDesc = document.querySelector(\".productDesc\")\n\n    const width = productDesc.offsetWidth - 10\n\n    document.querySelectorAll(\".productImg--wrapper img\").forEach((img) => {\n      const element = img.parentNode\n      let image = img.src\n\n      if (element.dataset.superzoom) {\n        image = element.dataset.superzoom\n      }\n\n      _self.zooms.push(\n        new ImageZoom(element, {\n          zoomContainer: zoomWrapper,\n          zoomWidth: width,\n          zoomImage: image,\n        })\n      )\n    })\n\n    if (e.detail) {\n      const evt = e.detail.evt\n\n      if (evt) {\n        setTimeout(function () {\n          let wrapper = evt.target.parentNode\n          wrapper.dispatchEvent(\n            new MouseEvent(\"mousemove\", {\n              clientX: evt.clientX,\n              clientY: evt.clientY,\n            })\n          )\n        }, 10)\n      }\n    }\n  }\n\n  removeZoom(e, _self) {\n    if (!_self.zoomActive) return\n\n    _self.zoomActive = false\n    let element = _self.imgWrapper\n\n    _self.zooms.forEach((zoom) => {\n      zoom.kill()\n    })\n\n    element.removeEventListener(\"click\", _self.removeEvent)\n    element.addEventListener(\"click\", _self.showEvent)\n    _self.imgWrapper.addEventListener(\"mouseover\", _self.hoverEvent)\n  }\n\n  showTooltip(elementWrapper, tooltip) {\n    elementWrapper.onmousemove = function (e) {\n      var x = e.clientX,\n        y = e.clientY\n      tooltip.style.top = y + 15 + \"px\"\n      tooltip.style.left = x + 15 + \"px\"\n      tooltip.classList.add(\"active\")\n    }\n    elementWrapper.onmouseout = function (e) {\n      tooltip.classList.remove(\"active\")\n    }\n  }\n}\n","\n\nexport default class SimpleSlider {\n\n\tconstructor(slider) {\n\t\tthis.slider = slider;\n\t\tthis.slidesWrapper = slider.querySelector('.snapping');\n\t\tthis.slides = this.slidesWrapper.children;\n\t\tconst parent = this.slider.parentElement;\n\t\tthis.prev = slider.querySelector('.nav-prev');\n\t\tthis.next = slider.querySelector('.nav-next');\n\n\t\tif (!this.prev) {\n\t\t\tif (parent.querySelector('.nav-prev')) {\n\t\t\t\tthis.prev = parent.querySelector('.nav-prev');\n\t\t\t}\n\t\t}\n\n\t\tif (!this.next) {\n\t\t\tif (parent.querySelector('.nav-next')) {\n\t\t\t\tthis.next = parent.querySelector('.nav-next');\n\t\t\t}\n\t\t}\n\n\t\tthis.slidesLength = this.slides.length;\n\n\t\tif (!this.slidesLength) return;\n\n\t\tthis.slideSize = this.slides[0].offsetWidth;\n\t\tthis.index = 1;\n\t\tthis.posX1 = 0;\n\t\tthis.posX2 = 0;\n\t\tthis.posInitial = 0;\n\t\tthis.touchEndPosition = 0;\n\t\tthis.touchEventTimer;\n\t\tthis.hasAutoslide = false;\n\n\t\tthis.initPagination();\n\t\tif (/Android|webOS|iPhone|iPad|iPod|BlackBerry/i.test(navigator.userAgent)) {\n\t\t}\n\t\telse{\n\t\t\tthis.initAutoslide();\n\t\t}\n\n\t\tthis.initEvents();\n\n\t\tthis.slider.classList.add('loaded');\n\t}\n\n\tinitEvents() {\n\t\tthis.mouseUpEvent = (e) => { this.dragEnd(e, this); };\n\t\tthis.mouseMoveEvent = (e) => { this.dragAction(e, this); };\n\n\t\tthis.disablePagination = false;\n\n\t\tif (this.slidesWrapper.scrollWidth <= this.slidesWrapper.clientWidth) {\n\t\t\tthis.disablePagination = true;\n\t\t}\n\n\t\tif (this.prev) {\n\t\t\tif (this.disablePagination) {\n\t\t\t\tthis.prev.style.display = 'none';\n\t\t\t} else {\n\t\t\t\tthis.prev.addEventListener('click', () => { this.shiftSlide(this, -1) });\n\t\t\t}\n\t\t}\n\t\tif (this.next) {\n\t\t\tif (this.disablePagination) {\n\t\t\t\tthis.next.style.display = 'none';\n\t\t\t} else {\n\t\t\t\tthis.next.addEventListener('click', () => { this.shiftSlide(this, 1) });\n\t\t\t}\n\t\t}\n\n\t\tthis.slidesWrapper.addEventListener('mousedown', (e) => { \n\t\t\tif (e.buttons == 1 && !e.target.closest(\".product__wishlist\")) {\n\t\t\t\tthis.dragStart(e, this);\n\t\t\t}\n\t\t});\n\n\t\tthis.slidesWrapper.addEventListener('touchend', (e) => { this.touchEvent(this) });\n\t\tthis.slidesWrapper.addEventListener('mousewheel', (e) => { this.touchEvent(this) });\n\t}\n\n\tinitAutoslide() {\n\t\tif (this.slidesWrapper.classList.contains('autoslide')) {\n\t\t\tthis.hasAutoslide = true;\n\t\t}\n\n\t\tif (this.hasAutoslide) {\n\t\t\tthis.maxScroll = this.slidesWrapper.scrollWidth - this.slidesWrapper.clientWidth;\n\t\t\tthis.autoslideTimer = setInterval(this.autoslideHandler, 50, this);\n\n\t\t\tthis.slidesWrapper.addEventListener('mouseover', () => { this.slidesWrapper.classList.add('pause'); });\n\t\t\tthis.slidesWrapper.addEventListener('mouseout', () => { this.slidesWrapper.classList.remove('pause'); });\n\t\t\tthis.slidesWrapper.addEventListener('touchstart', () => { this.slidesWrapper.classList.add('pause'); });\n\t\t\tthis.slidesWrapper.addEventListener('touchend', () => { this.slidesWrapper.classList.remove('pause'); });\n\t\t}\n\t}\n\n\tautoslideHandler(_self) {\n\t\tif (_self.slidesWrapper.classList.contains(\"sliding\")) return;\n\t\tif (_self.slidesWrapper.classList.contains(\"pause\")) return;\n\n\t\t_self.slidesWrapper.scrollLeft += 1;\n\t\tif (_self.slidesWrapper.scrollLeft >= _self.maxScroll) {\n\t\t\tclearInterval(_self.autoslideTimer);\n\t\t}\n\t}\n\n\tinitPagination() {\n\t\tthis.paginationWrapper = this.slider.getElementsByClassName('slider__pagination');\n\t\tthis.hasPagination = this.paginationWrapper.length ? true : false;\n\n\t\tif (this.hasPagination) {\n\t\t\tthis.paginationWrapper = this.slider.getElementsByClassName('slider__pagination')[0];\n\t\t\tthis.paginationWrapper.firstElementChild.classList.add('active');\n\n\t\t\t\n\t\t\tconst pagination_dots = this.paginationWrapper.getElementsByClassName('slider__pagination--dot');\n\n\t\t\tfor (const dot of pagination_dots) {\n\t\t\t\tdot.addEventListener('click', (e) => this.paginationClick(e, this));\n\t\t\t}\n\t\t}\n\t}\n\n\tpaginationClick(e, _self) {\n\t\tconst element = e.target;\n\t\tconst parent = element.parentElement;\n\t\t\n\t\t_self.index = Array.from(parent.children).indexOf(element) + 1;\n\n\t\t_self.slidesWrapper.scrollLeft = _self.slideSize * (_self.index - 1);\n\n\t\t_self.updatePagination();\n\t}\n\n\ttouchEvent(_self) {\n\t\t_self.touchEndPosition = _self.slidesWrapper.scrollLeft;\n\t\t_self.touchEventTimer = setInterval(_self.touchEventHandler, 50, _self);\n\t}\n\n\ttouchEventHandler(obj) {\n\t\tif (obj.touchEndPosition == obj.slidesWrapper.scrollLeft) {\n\t\t\tclearInterval(obj.touchEventTimer);\n\n\t\t\tobj.index = Math.round(obj.touchEndPosition / obj.slideSize) + 1;\n\t\t\tobj.updatePagination();\n\t\t} else {\n\t\t\tobj.touchEndPosition = obj.slidesWrapper.scrollLeft;\n\t\t}\n\t}\n\n\tdragStart(e, _self) {\n\t\t_self.posInitial = _self.slidesWrapper.scrollLeft;\n\t\t_self.initialX = e.clientX;\n\t\t_self.posX1 = e.clientX;\n\n\t\tdocument.addEventListener('mouseup', _self.mouseUpEvent);\n\t\tdocument.addEventListener('mousemove', _self.mouseMoveEvent);\n\t}\n\n\tdragAction(e, _self) {\n\t\t_self.slidesWrapper.classList.add(\"sliding\");\n\t\t_self.posX2 = _self.posX1 - e.clientX;\n\t\t_self.posX1 = e.clientX;\n\t\t_self.slidesWrapper.scrollLeft = _self.slidesWrapper.scrollLeft + _self.posX2;\n\t}\n\n\tdragEnd(e, _self) {\n\t\t_self.index = Math.round(_self.slidesWrapper.scrollLeft / _self.slideSize) + 1;\n\n\t\tdocument.removeEventListener('mouseup', _self.mouseUpEvent);\n\t\tdocument.removeEventListener('mousemove', _self.mouseMoveEvent);\n\n\t\t_self.slidesWrapper.classList.remove(\"sliding\");\n\n\t\tif (_self.initialX == e.clientX) {\n\t\t\tdocument.dispatchEvent(new CustomEvent(\"slider_clicked\", {detail: {evt: e}}));\n\t\t} else {\n\t\t\tdocument.dispatchEvent(new CustomEvent(\"slider_changed\", {detail: {evt: e}}));\n\t\t}\n\n\t\t_self.updatePagination();\n\t}\n\n\tshiftSlide(_self, dir) {\n\t\t_self.posInitial = _self.slidesWrapper.scrollLeft;\n\n\t\tif (dir == 1) {\n\t\t\tif (_self.index > _self.slidesLength || (_self.slidesWrapper.scrollWidth >= (_self.slidesWrapper.scrollLeft + _self.slidesWrapper.clientWidth - 1) && _self.slidesWrapper.scrollWidth <= (_self.slidesWrapper.scrollLeft + _self.slidesWrapper.clientWidth + 1))) {\n\t\t\t\t_self.slidesWrapper.scrollLeft = 0;\n\t\t\t\t_self.index = 1;\n\t\t\t} else {\n\t\t\t\t_self.slidesWrapper.scrollLeft = _self.posInitial + _self.slideSize;\n\t\t\t\t_self.index++;\n\t\t\t}\n\t\t} else if (dir == -1 && _self.index > 1) {\n\t\t\t_self.slidesWrapper.scrollLeft = _self.posInitial - _self.slideSize;\n\t\t\t_self.index--;\n\t\t}\n\n\t\tdocument.dispatchEvent(new CustomEvent(\"slider_changed\"));\n\n\t\tthis.updatePagination();\n\t}\n\n\tupdatePagination() {\n\t\tif (!this.hasPagination) { return; };\n\n\t\tthis.paginationWrapper.querySelectorAll('.active').forEach(e =>\n\t\t\te.classList.remove(\"active\")\n\t\t);\n\n\t\tthis.paginationWrapper.querySelectorAll('.slider__pagination--dot:nth-child(' + this.index + ')')[0].classList.add('active');\n\t}\n}\n","import {formatPriceHtml} from \"../../../scripts/utils.js\";\nexport default class Variation {\n\n    constructor(variantsData, buyButton) {\n        this.product_id = variantsData.product_id;\n        this.variantsData = variantsData.variants;\n        this.fields = document.getElementById('variation-1');\n        this.poi_sizes = document.querySelectorAll('.poi.buybox__variant--item');\n        this.variants = document.getElementsByClassName('buybox__variant--item');\n        this.buyButton = buyButton;\n        this.autoAdd = false;\n        this.isInitialized = false;  // Added to control re-initialization\n\n        this.init(this.variants);\n    }\n\n    init(variants) {\n        this.initEvents();\n        this.initPOI_toggle();\n    }\n\n    initEvents() {\n        const container = document.querySelector('.buybox__variant--items');\n        if (!container) return;\n\n        container.addEventListener('click', (event) => {\n            // Check if the clicked element is a .buybox__variant--item\n            var target = event.target.closest('.buybox__variant--item');\n            if (!target) return;\n\n            // Hide all overlay texts\n            var overlays = container.querySelectorAll('.overlay-text');\n\n            overlays.forEach((overlay) => {\n                overlay.classList.add('hide');\n                \n            });\n\n            // Show the overlay text for the clicked item\n            var overlayText = target.querySelector('.overlay-text');\n            if (overlayText) {\n                overlayText.classList.remove('hide');\n            }\n\n            // Also handle the field update event\n            this.updateFieldEvent(event);\n        });\n\n        this.buyButton.addEventListener('addToCart', e => { this.showCartError(e); });\n        \n        const labels = document.getElementsByClassName('buybox__variant--title');\n        for (const label of labels) {\n            label.addEventListener('click', e => { this.toggleVariantWrapper(label); });\n        }\n    }\n\n\n    toggleVariantWrapper(label) {\n        const wrapper = label.parentNode;\n        if (wrapper.classList.contains('open')) {\n            wrapper.classList.remove('open');\n        } else {\n            wrapper.classList.add('open');\n            label.classList.add('hide');\n        }\n    }\n\n    updateFieldEvent(e) {\n        let button = e.target.closest('.buybox__variant--item');\n        if (!button || !button.dataset.id) return;  \n\n        const variantId = button.dataset.id;\n        document.querySelector('.product-id-info').innerHTML=variantId;\n        const field = this.fields;//button.parentNode;\n        Array.from(this.poi_sizes).forEach(elem=> elem.classList.remove('active'));\n        Array.from(field.children).forEach(child => child.classList.remove('active'));\n        button.classList.toggle('active');\n        this.buyButton.classList.toggle(\"disabled\", !button.classList.contains('active'));\n        field.dataset.value = button.classList.contains('active') ? variantId : '';\n\n        this.updateLabel(field, button.classList.contains('active') ? variantId : '');\n        this.updateFields();\n    }\n\n    updateLabel(field, variantId) {\n        const labels = field.parentNode.querySelectorAll('.label'); // Assuming multiple labels\n        labels.forEach(label => {\n            const dataFor = label.getAttribute('data-for');\n            if (dataFor === variantId) {\n                const variant = this.variantsData.find(v => v.id === variantId);\n                if (variant) {\n                    label.textContent = variant.label || '';\n                }\n            }\n        });\n    }\n\n    updateFields() {\n        let values = [];\n        let allFieldsSelected = true;\n       \n\n            if (this.fields.dataset.value) {\n                values.push(this.fields.dataset.value);\n            } else {\n                allFieldsSelected = false;\n            }\n   \n        allFieldsSelected ? this.setVariant(values) : this.clearVariant();\n    }\n\n    async setVariant(values) {\n        for (const value of values) {\n            const variant = this.variantsData.find(v => v.id === value);\n            if (variant) {\n                const response = await fetch(`/shop?funk=get_variant&product_id=${this.product_id}&variant_id=${variant.id}`);\n                const result = await response.json();\n    \n                if (result.status.code === 200) {\n                    const data = result.data;\n                    this.updateVariantInfo(variant, data);  // Correctly call updateVariantInfo here\n                } else {\n                    console.error('Failed to fetch variant data:', result.status.message);\n                }\n            } else {\n                console.error('Variant not found for ID:', value);\n            }\n        }\n    }\n\n    initPOI_toggle() {\n        const toggleTrigger = document.querySelector(\".poi_toggle\");\n        const variantContainers = document.querySelectorAll(\".buybox__variant--items\");\n    \n        if (toggleTrigger) {\n            toggleTrigger.addEventListener(\"click\", () => {\n                this.unselectVariants();\n                variantContainers.forEach(container => {\n                    Array.from(container.children).forEach(child => {\n                        if (!child.classList.contains(\"poi_toggle\")) {\n                            child.classList.toggle(\"hide\"); // Toggle visibility for each non-toggle child\n                        }\n                    });\n                });\n    \n                // Determine the toggle text based on the visibility of the first item across all containers\n                const someVisible = Array.from(variantContainers).some(container => \n                    container.querySelector('.poi.buybox__variant--item') && !container.querySelector('.poi.buybox__variant--item').classList.contains(\"hide\")\n                );\n    \n                toggleTrigger.textContent = someVisible ? \"Visa endast nya\" : \"Visa endast Pre-owned\";\n            });\n        }\n    }\n\n    unselectVariants() {\n        Array.from(this.variants).forEach(item => {\n            item.classList.remove('active');\n            Array.from(item.getElementsByTagName('span')).forEach(span => {\n                span.classList.add('hide');\n            });\n        });\n\n        const airBuyElement = this.buyButton;\n        if (airBuyElement) {\n            airBuyElement.classList.add('disabled');\n            airBuyElement.classList.remove('error');\n            airBuyElement.dataset.id = '';\n        }\n        this.clearVariant();\n        this.clearFields();\n        this.buyButton.addEventListener('addToCart', e => { this.showCartError(e); });\n    }\n\n    updateVariantInfo(variant, data) {\n        // Update buy button label and classes based on variant properties\n        const btnLabel = this.buyButton.getElementsByClassName('air-buy-label')[0];\n    \n        if (variant.buyable) {\n            btnLabel.textContent = btnLabel.dataset.buyable;\n            this.buyButton.classList.add('buyable');\n            this.buyButton.classList.remove('alertable');\n        } else if (variant.watchable) {\n            btnLabel.textContent = btnLabel.dataset.alertable;\n            this.buyButton.classList.add('alertable');\n            this.buyButton.classList.remove('buyable');\n        }\n    \n        // Set buy button data attributes for variant tracking\n        this.buyButton.dataset.id = variant.id;\n        this.buyButton.dataset.stock_id = variant.availability_id;\n        this.buyButton.classList.remove('error');\n        // Update various elements across the page with variant-specific data\n        this.updateVariantElements(variant.id,data);\n        if (this.autoAdd) {\n            document.querySelector(\"#air-buy\").click();\n            this.autoAdd = false;\n        }\n    }\n\n    updateVariantElements(variantId, data) {\n\n        // Assume data contains the pricing and other variant-specific information\n        const priceElement = document.querySelector('.price-info ');\n        if (!priceElement) {\n            return;\n        }\n    \n        // Assuming formatPriceHtml is a function defined elsewhere that formats the price HTML\n        priceElement.innerHTML = (0,_scripts_utils_js__WEBPACK_IMPORTED_MODULE_0__.formatPriceHtml)(data.price, data.price_regular, data.campaign, data.price_prefix);\n    }\n\n    clearVariant() {\n        this.buyButton.dataset.id = '';\n    }\n\n    clearFields() {\n        // Iterate over each field and reset its dataset value\n        \n            if (this.fields.dataset.value) {\n                this.fields.dataset.value = ''; // Reset the dataset value\n            } \n        \n    }\n\n    showCartError() {\n        let error = false;\n        for (const field of this.variants) {\n            if (!field.dataset.id) {\n\n\n                field.classList.add('error');\n                field.parentElement.classList.add('error');\n                document.querySelector(\"#air-buy\").classList.add(\"error\");\n                error = true;\n            } else {\n                field.classList.remove('error');\n                field.parentElement.classList.remove('error');\n            }\n        }\n\n        if (error) {\n            this.errorEvent = () => this.hideErrorEvent();\n            document.addEventListener('click', this.errorEvent);\n        }\n    }\n\n    hideErrorEvent() {\n        for (const field of this.fields) {\n            field.classList.remove('error');\n            field.parentElement.classList.remove('error');\n        }\n        document.removeEventListener('click', this.errorEvent);\n    }\n}\n","import {getCookie} from \"../../scripts/utils.js\";\n\nconst storage_name = 'air_wishlist';\nconst expire_time = 60; // In minutes.\nlet wishlist;\n\nexport default class Wishlist {\n\n\tconstructor(cart) {\n\t\tthis.cart = cart;\n\t\tthis.init();\n\t\tthis.init_events();\n\t}\n\n\tinit() {\n\t\tif (!getCookie('SESS')) return;\n\t\tif (!document.getElementsByClassName(\"header__wishlist\").length) return;\n\n\t\tdocument.querySelectorAll('.Din_Sida_Onskelista_Wrapper .Knapp_Kop a').forEach(element => {\n\t\t\tconsole.log(element);\n\t\t\telement.addEventListener('click', (e) => {\n\t\t\t\te.preventDefault();\n\t\t\t\tconsole.log(element.parentNode.parentNode.parentNode);\n\n\t\t\t\tlet form = element.parentNode.parentNode.parentNode.parentNode.parentNode;\n\t\t\t\tlet product_id = form.altnr.value;\n\n\t\t\t\tif (product_id) {\n\t\t\t\t\tthis.cart.add_item(product_id, 1);\n\t\t\t\t}\n\t\t\t});\n\t\t});\n\n\t\twishlist = this.get_storage();\n\n\t\tif (wishlist) {\n\t\t\tthis.render();\n\t\t} else {\n\t\t\tthis.get();\n\t\t}\n\t}\n\n\tinit_events() {\n\t\twindow.liveEvent(\".product__wishlist\", \"click\", (event, element) => { \n\t\t\tthis.handle_event(element, event);\n\t\t});\n\n\t\tdocument.addEventListener('after_filter', () => {\n\t\t\tthis.init();\n\t\t});\n\n\t\tdocument.addEventListener('product_cell_update', () => {\n\t\t\tthis.init();\n\t\t});\n\t}\n\n\tasync get() {\n\t\tconst response = await fetch('/shop?funk=get_wishlist');\n\t\tconst result = await response.json();\n\n\t\tif (result.status.code == 200) {\n\t\t\twishlist = result.data;\n\n\t\t\tthis.save_storage();\n\t\t\tthis.render();\n\t\t}\n\t}\n\n\tget_storage() {\n\t\tif (typeof (Storage) === 'undefined') return null;\n\n\t\tlet str = window.localStorage.getItem(storage_name);\n\n\t\tif (str == null) return undefined;\n\n\t\tlet data;\n\n\t\ttry {\n\t\t\tdata = JSON.parse(str);\n\t\t} catch (e) {\n\t\t\treturn undefined;\n\t\t}\n\n\t\tif (data.expires < Date.now()) {\n\t\t\treturn undefined;\n\t\t}\n\n\t\treturn data;\n\t}\n\n\tsave_storage() {\n\t\tif (typeof (Storage) === 'undefined') return null;\n\n\t\twishlist.expires = Date.now() + expire_time * 60000;\n\t\twindow.localStorage.setItem(storage_name, JSON.stringify(wishlist));\n\t}\n\n\thandle_event(element, event) {\n\t\tevent.preventDefault();\n\n\t\tif (element.classList.contains('--filled')) {\n\t\t\telement.classList.remove(\"--filled\");\n\t\t\tthis.remove_item(element.dataset.id);\n\t\t}\n\t\telse {\n\t\t\telement.classList.add(\"--filled\");\n\t\t\tthis.add_item(element.dataset.id);\n\t\t}\n\t}\n\n\tasync add_item(id) {\n\t\tconst data = new URLSearchParams();\n\n\t\tdata.append('funk', 'add_wishlist_item');\n\t\tdata.append('id', id);\n\t\t\n\t\tconst response = await fetch('/shop', {\n\t\t\tmethod: 'POST',\n\t\t\tbody: data\n\t\t});\n\n\t\tconst result = await response.json();\n\t\tif (result.status.code == 200) {\n\t\t\twishlist = result.data.wishlist;\n\n\t\t\tthis.save_storage();\n\t\t\tthis.render();\n\t\t}\n\t}\n\n\tasync remove_item(id) {\n\t\tconst data = new URLSearchParams();\n\n\t\tdata.append('funk', 'remove_wishlist_item');\n\t\tdata.append('id', id);\n\t\t\n\t\tconst response = await fetch('/shop', {\n\t\t\tmethod: 'POST',\n\t\t\tbody: data\n\t\t});\n\n\t\tconst result = await response.json();\n\t\tif (result.status.code == 200) {\n\t\t\twishlist = result.data.wishlist;\n\n\t\t\tthis.save_storage();\n\t\t\tthis.render();\n\t\t}\n\t}\n\n\trender() {\n\t\tdocument.querySelectorAll('.product__wishlist.--filled').forEach(element => {\n\t\t\telement.classList.remove(\"--filled\");\n\t\t});\n\n\t\t// Lights up stars for products in wishlist\n\t\tlet i = 0;\n\t\twhile (i < wishlist.length) {\n\t\t\tconst elements = document.querySelectorAll('[data-id=\"' + wishlist[i].id + '\"]');\n\t\t\telements.forEach(function(element) {\n\t\t\t\telement.classList.add('--filled');\n\t\t\t});\n\n\t\t\ti++;\n\t\t}\n\n\t\t// Lights up star in header\n\t\tvar header_element = document.getElementsByClassName(\"header__wishlist\");\n\t\tif (!header_element) return;\n\n\t\tif (wishlist.length) {\n\t\t\theader_element[0].classList.add('--filled');\n\t\t}\n\t\telse {\n\t\t\theader_element[0].classList.remove(\"--filled\");\n\t\t}\n\t}\n}\n","(function (root, factory) {\n    if (typeof module !== 'undefined' && module.exports) {\n        module.exports = factory();\n    } else {\n        root.ImageZoom = factory();\n    }\n}(this, function () {\n    /**\n     * @param {Object} container DOM element, which contains an image to be zoomed (required)\n     * @param {Object} options js-image-zoom options (required)\n     * **width** (number) - width of the source image (optional)\n     * **height** (number) - height of the source image (optional).\n     * **zoomWidth** (number) - width of the zoomed image. Zoomed image height equals source image height (optional)\n     * **img** (string) - url of the source image. Provided if container does not contain img element as a tag (optional)\n     * **scale** (number) - zoom scale. if not provided, scale is calculated as natural image size / image size, provided in params (optional if zoomWidth param is provided)\n     * **offset** (object) - {vertical: number, horizontal: number}. Zoomed image offset (optional)\n     * **zoomContainer** (node) - DOM node reference where zoomedImage will be appended to (default to the container element of image)\n     * **zoomStyle** (string) - custom style applied to the zoomed image (i.e. 'opacity: 0.1;background-color: white;')\n     * **zoomPosition** (string) - position of zoomed image. It can be:  `top`, `left`, `bottom`, `original` or the default `right`.\n     * **zoomLensStyle** (string) custom style applied to to zoom lents (i.e. 'opacity: 0.1;background-color: white;')\n     */\n    return function ImageZoom(container, opts) {\n        \"use strict\";\n        var options = opts;\n        if (!container) {\n            return;\n        }\n        var data = {\n            sourceImg: {\n                element: null,\n                width: 0,\n                height: 0,\n                naturalWidth: 0,\n                naturalHeight: 0\n            },\n            img: {\n                element: null,\n                width: 0,\n                height: 0,\n                naturalWidth: 0,\n                naturalHeight: 0\n            },\n            zoomedImgOffset: {\n                vertical: 0,\n                horizontal: 0\n            },\n            zoomedImg: {\n                element: null,\n                width: 0,\n                height: 0\n            },\n            zoomLens: {\n                element: null,\n                width: 0,\n                height: 0\n            }\n        };\n\n        var div = document.createElement('div');\n        var lensDiv = document.createElement('div');\n        var scaleX;\n        var scaleY;\n        var offset;\n        var zoomScaleX;\n        var zoomScaleY;\n        var zoomOffset;\n        data.zoomedImgOffset = {\n            vertical: options.offset && options.offset.vertical ? options.offset.vertical : 0,\n            horizontal: options.offset && options.offset.horizontal ? options.offset.horizontal : 0\n        };\n        data.zoomPosition = options.zoomPosition || 'right';\n        data.zoomContainer = (options.zoomContainer) ? options.zoomContainer : container;\n        function getOffset(el) {\n            if (el) {\n                var elRect = el.getBoundingClientRect();\n                return {left: elRect.left, top: elRect.top};\n            }\n            return {left: 0, top: 0};\n        }\n\n        function leftLimit(min) {\n            return options.width - min;\n        }\n\n        function topLimit(min) {\n            return options.height - min;\n        }\n\n        function getValue(val, min, max) {\n            if (val < min) {\n                return min;\n            }\n            if (val > max) {\n                return max;\n            }\n            return val;\n        }\n\n        function getPosition(v, min, max) {\n            var value = getValue(v, min, max);\n            return value - min;\n        }\n\n        function zoomLensLeft(left) {\n            var leftMin = data.zoomLens.width / 2;\n            return getPosition(left, leftMin, leftLimit(leftMin));\n        }\n\n        function zoomLensTop(top) {\n            var topMin = data.zoomLens.height / 2;\n            return getPosition(top, topMin, topLimit(topMin));\n        }\n\n        function setZoomedImgSize(options, data) {\n            if (options.scale) {\n                data.zoomedImg.element.style.width = options.width * options.scale + 'px';\n                data.zoomedImg.element.style.height = options.height * options.scale + 'px';\n            } else if (options.zoomWidth) {\n                data.zoomedImg.element.style.width = options.zoomWidth + 'px';\n                data.zoomedImg.element.style.height = data.sourceImg.element.style.height;\n            } else {\n                data.zoomedImg.element.style.width = '100%';\n                data.zoomedImg.element.style.height = '100%';\n            }\n        }\n\n        function onSourceImgLoad() {\n            // use height determined by browser if height is not set in options\n            options.height = options.height || data.sourceImg.element.height;\n            // data.sourceImg.element.style.height = options.height + 'px';\n            data.sourceImg.element.style.height = '100%';\n\n            // use width determined by browser if width is not set in options\n            options.width = options.width || data.sourceImg.element.width;\n            data.sourceImg.element.style.width = options.width + 'px';\n\n            setZoomedImgSize(options, data);\n\n            data.sourceImg.naturalWidth = data.sourceImg.element.naturalWidth;\n            data.sourceImg.naturalHeight = data.sourceImg.element.naturalHeight;\n            data.zoomedImg.element.style.backgroundSize = data.img.element.naturalWidth + 'px ' + data.img.element.naturalHeight + 'px';\n\n            if (options.zoomStyle) {\n                data.zoomedImg.element.style.cssText += options.zoomStyle;\n            }\n            if (options.zoomLensStyle) {\n                data.zoomLens.element.style.cssText += options.zoomLensStyle;\n            } else {\n                data.zoomLens.element.style.background = 'white';\n                data.zoomLens.element.style.opacity = '0.4';\n            }\n\n            zoomScaleX = data.img.element.naturalWidth / options.width;\n            zoomScaleY = data.img.element.naturalHeight / options.height;\n            zoomOffset = getOffset(data.img.element);\n\n            scaleX = data.sourceImg.naturalWidth / options.width;\n            scaleY = data.sourceImg.naturalHeight / options.height;\n            offset = getOffset(data.sourceImg.element);\n\n            // set zoomLens dimensions\n            // if custom scale is set\n            if (options.scale) {\n                data.zoomLens.width = options.width / (data.sourceImg.naturalWidth / (options.width * options.scale));\n                data.zoomLens.height = options.height / (data.sourceImg.naturalHeight / (options.height * options.scale));\n            }\n\n            // else if zoomWidth is set\n            else if (options.zoomWidth) {\n                data.zoomLens.width = options.zoomWidth / zoomScaleX;\n                data.zoomLens.height = options.height / zoomScaleY;\n            }\n\n            // else read from the zoomedImg\n            else {\n                data.zoomedImg.element.style.display = 'block';\n                data.zoomLens.width = data.zoomedImg.element.clientWidth / scaleX;\n                data.zoomLens.height = data.zoomedImg.element.clientHeight / scaleY;\n                data.zoomedImg.element.style.display = 'none';\n            }\n\n            data.zoomLens.element.style.position = 'absolute';\n            data.zoomLens.element.style.width = data.zoomLens.width + 'px';\n            data.zoomLens.element.style.height = data.zoomLens.height + 'px';\n            data.zoomLens.element.pointerEvents = 'none';\n        }\n\n        function setup() {\n            // create sourceImg element\n            if (options.img) {\n                var img = document.createElement('img');\n                img.src = options.img;\n                data.sourceImg.element = container.appendChild(img);\n            } else {\n                data.sourceImg.element = container.children[0];\n\n                // if sourceImg is not an img (might be a picture element), try to find one\n                if (data.sourceImg.element.nodeName !== \"IMG\") {\n                    data.sourceImg.element = data.sourceImg.element.querySelector('img');\n                }\n            }\n\n            // \n            if (options.zoomImage) {\n                let img = document.createElement('img');\n                img.src = options.zoomImage;\n                data.img.element = img;\n            } else {\n                data.img.element = data.sourceImg.element;\n            }\n\n\n\n            options = options || {};\n            container.style.position = 'relative';\n            // data.sourceImg.element.style.width = options.width ? options.width + 'px' : 'auto';\n            // data.sourceImg.element.style.height = options.height ? options.height + 'px' : 'auto';\n\n            \n\n            data.zoomLens.element = container.appendChild(lensDiv);\n            data.zoomLens.element.style.display = 'none';\n            data.zoomLens.element.classList.add('js-image-zoom__zoomed-area');\n\n            data.zoomedImg.element = data.zoomContainer.appendChild(div);\n            data.zoomedImg.element.classList.add('js-image-zoom__zoomed-image');\n            data.zoomedImg.element.style.backgroundImage = \"url('\" + data.img.element.src + \"')\";\n            // data.zoomedImg.element.style.backgroundImage = \"url('\" + data.sourceImg.element.src + \"')\";\n            data.zoomedImg.element.style.backgroundRepeat = 'no-repeat';\n            data.zoomedImg.element.style.display = 'none';\n            data.zoomedImg.element.style.zIndex = '2';\n\n            data.zoomedImg.element.style.position = 'absolute';\n            data.zoomedImg.element.style.top = data.zoomedImgOffset.vertical + 'px';\n            data.zoomedImg.element.style.right = data.zoomedImgOffset.horizontal - (data.zoomedImgOffset.horizontal * 2) + 'px';\n            data.zoomedImg.element.style.transform = 'translateX(100%)';\n\n\n            // setup event listeners\n            container.addEventListener('mousemove', events, false);\n            container.addEventListener('mouseenter', events, false);\n            container.addEventListener('mouseleave', events, false);\n            data.zoomLens.element.addEventListener('mouseenter', events, false);\n            data.zoomLens.element.addEventListener('mouseleave', events, false);\n            window.addEventListener('scroll', events, false);\n\n            return data;\n        }\n\n        function kill() {\n\n            // remove event listeners\n            container.removeEventListener('mousemove', events, false);\n            container.removeEventListener('mouseenter', events, false);\n            container.removeEventListener('mouseleave', events, false);\n            data.zoomLens.element.removeEventListener('mouseenter', events, false);\n            data.zoomLens.element.removeEventListener('mouseleave', events, false);\n            window.removeEventListener('scroll', events, false);\n\n            // remove dom nodes\n            if (data.zoomLens && data.zoomedImg) {\n                container.removeChild(data.zoomLens.element);\n                data.zoomContainer.removeChild(data.zoomedImg.element);\n            }\n\n            if (options.img) {\n                container.removeChild(data.sourceImg.element);\n            } else {\n                data.sourceImg.element.style.width = '';\n                data.sourceImg.element.style.height = '';\n            }\n\n            return data;\n        }\n\n        var events = {\n            handleEvent: function (event) {\n                switch (event.type) {\n                    case 'mousemove':\n                        return this.handleMouseMove(event);\n                    case 'mouseenter':\n                        return this.handleMouseEnter(event);\n                    case 'mouseleave':\n                        return this.handleMouseLeave(event);\n                    case 'scroll':\n                        return this.handleScroll(event);\n                }\n            },\n            handleMouseMove: function (event) {\n                var offsetX;\n                var offsetY;\n                var backgroundTop;\n                var backgroundRight;\n                var backgroundPosition;\n                if (offset) {\n                    offsetX = zoomLensLeft(event.clientX - offset.left);\n                    offsetY = zoomLensTop(event.clientY - offset.top);\n                    backgroundTop = offsetX * zoomScaleX;\n                    backgroundRight = offsetY * zoomScaleY;\n                    backgroundPosition = '-' + backgroundTop + 'px ' + '-' + backgroundRight + 'px';\n                    data.zoomedImg.element.style.backgroundPosition = backgroundPosition;\n                    data.zoomLens.element.style.cssText += 'top:' + offsetY + 'px;' + 'left:' + offsetX + 'px;display: block;';\n\n                }\n            },\n            handleMouseEnter: function () {\n                data.zoomedImg.element.style.display = 'block';\n                data.zoomLens.element.style.display = 'block';\n\n            },\n            handleMouseLeave: function () {\n                data.zoomedImg.element.style.display = 'none';\n                data.zoomLens.element.style.display = 'none';\n            },\n            handleScroll: function () {\n                offset = getOffset(data.sourceImg.element);\n            }\n        };\n\n        // Setup/Initialize library\n        setup();\n\n        // if (data.sourceImg.element.complete) {\n        if (data.img.element.complete) {\n            onSourceImgLoad();\n        } else {\n            data.img.element.onload = onSourceImgLoad;\n            // data.sourceImg.element.onload = onSourceImgLoad;\n        }\n\n        return {\n            setup: function () {\n                setup();\n            },\n            kill: function () {\n                kill();\n            },\n            _getInstanceInfo: function () {\n                return {\n                    setup: setup,\n                    kill: kill,\n                    onSourceImgLoad: onSourceImgLoad,\n                    data: data,\n                    options: options\n                }\n            }\n        }\n    }\n}));","// extracted by mini-css-extract-plugin\nexport {};","!function(n,t){\"object\"==typeof exports&&\"undefined\"!=typeof module?module.exports=t():\"function\"==typeof define&&define.amd?define(t):(n=\"undefined\"!=typeof globalThis?globalThis:n||self).LazyLoad=t()}(this,(function(){\"use strict\";function n(){return n=Object.assign||function(n){for(var t=1;t<arguments.length;t++){var e=arguments[t];for(var i in e)Object.prototype.hasOwnProperty.call(e,i)&&(n[i]=e[i])}return n},n.apply(this,arguments)}var t=\"undefined\"!=typeof window,e=t&&!(\"onscroll\"in window)||\"undefined\"!=typeof navigator&&/(gle|ing|ro)bot|crawl|spider/i.test(navigator.userAgent),i=t&&\"IntersectionObserver\"in window,o=t&&\"classList\"in document.createElement(\"p\"),a=t&&window.devicePixelRatio>1,r={elements_selector:\".lazy\",container:e||t?document:null,threshold:300,thresholds:null,data_src:\"src\",data_srcset:\"srcset\",data_sizes:\"sizes\",data_bg:\"bg\",data_bg_hidpi:\"bg-hidpi\",data_bg_multi:\"bg-multi\",data_bg_multi_hidpi:\"bg-multi-hidpi\",data_bg_set:\"bg-set\",data_poster:\"poster\",class_applied:\"applied\",class_loading:\"loading\",class_loaded:\"loaded\",class_error:\"error\",class_entered:\"entered\",class_exited:\"exited\",unobserve_completed:!0,unobserve_entered:!1,cancel_on_exit:!0,callback_enter:null,callback_exit:null,callback_applied:null,callback_loading:null,callback_loaded:null,callback_error:null,callback_finish:null,callback_cancel:null,use_native:!1,restore_on_error:!1},c=function(t){return n({},r,t)},l=function(n,t){var e,i=\"LazyLoad::Initialized\",o=new n(t);try{e=new CustomEvent(i,{detail:{instance:o}})}catch(n){(e=document.createEvent(\"CustomEvent\")).initCustomEvent(i,!1,!1,{instance:o})}window.dispatchEvent(e)},u=\"src\",s=\"srcset\",d=\"sizes\",f=\"poster\",_=\"llOriginalAttrs\",g=\"data\",v=\"loading\",b=\"loaded\",m=\"applied\",p=\"error\",h=\"native\",E=\"data-\",I=\"ll-status\",y=function(n,t){return n.getAttribute(E+t)},k=function(n){return y(n,I)},w=function(n,t){return function(n,t,e){var i=\"data-ll-status\";null!==e?n.setAttribute(i,e):n.removeAttribute(i)}(n,0,t)},A=function(n){return w(n,null)},L=function(n){return null===k(n)},O=function(n){return k(n)===h},x=[v,b,m,p],C=function(n,t,e,i){n&&(void 0===i?void 0===e?n(t):n(t,e):n(t,e,i))},N=function(n,t){o?n.classList.add(t):n.className+=(n.className?\" \":\"\")+t},M=function(n,t){o?n.classList.remove(t):n.className=n.className.replace(new RegExp(\"(^|\\\\s+)\"+t+\"(\\\\s+|$)\"),\" \").replace(/^\\s+/,\"\").replace(/\\s+$/,\"\")},z=function(n){return n.llTempImage},T=function(n,t){if(t){var e=t._observer;e&&e.unobserve(n)}},R=function(n,t){n&&(n.loadingCount+=t)},G=function(n,t){n&&(n.toLoadCount=t)},j=function(n){for(var t,e=[],i=0;t=n.children[i];i+=1)\"SOURCE\"===t.tagName&&e.push(t);return e},D=function(n,t){var e=n.parentNode;e&&\"PICTURE\"===e.tagName&&j(e).forEach(t)},H=function(n,t){j(n).forEach(t)},V=[u],F=[u,f],B=[u,s,d],J=[g],P=function(n){return!!n[_]},S=function(n){return n[_]},U=function(n){return delete n[_]},$=function(n,t){if(!P(n)){var e={};t.forEach((function(t){e[t]=n.getAttribute(t)})),n[_]=e}},q=function(n,t){if(P(n)){var e=S(n);t.forEach((function(t){!function(n,t,e){e?n.setAttribute(t,e):n.removeAttribute(t)}(n,t,e[t])}))}},K=function(n,t,e){N(n,t.class_applied),w(n,m),e&&(t.unobserve_completed&&T(n,t),C(t.callback_applied,n,e))},Q=function(n,t,e){N(n,t.class_loading),w(n,v),e&&(R(e,1),C(t.callback_loading,n,e))},W=function(n,t,e){e&&n.setAttribute(t,e)},X=function(n,t){W(n,d,y(n,t.data_sizes)),W(n,s,y(n,t.data_srcset)),W(n,u,y(n,t.data_src))},Y={IMG:function(n,t){D(n,(function(n){$(n,B),X(n,t)})),$(n,B),X(n,t)},IFRAME:function(n,t){$(n,V),W(n,u,y(n,t.data_src))},VIDEO:function(n,t){H(n,(function(n){$(n,V),W(n,u,y(n,t.data_src))})),$(n,F),W(n,f,y(n,t.data_poster)),W(n,u,y(n,t.data_src)),n.load()},OBJECT:function(n,t){$(n,J),W(n,g,y(n,t.data_src))}},Z=[\"IMG\",\"IFRAME\",\"VIDEO\",\"OBJECT\"],nn=function(n,t){!t||function(n){return n.loadingCount>0}(t)||function(n){return n.toLoadCount>0}(t)||C(n.callback_finish,t)},tn=function(n,t,e){n.addEventListener(t,e),n.llEvLisnrs[t]=e},en=function(n,t,e){n.removeEventListener(t,e)},on=function(n){return!!n.llEvLisnrs},an=function(n){if(on(n)){var t=n.llEvLisnrs;for(var e in t){var i=t[e];en(n,e,i)}delete n.llEvLisnrs}},rn=function(n,t,e){!function(n){delete n.llTempImage}(n),R(e,-1),function(n){n&&(n.toLoadCount-=1)}(e),M(n,t.class_loading),t.unobserve_completed&&T(n,e)},cn=function(n,t,e){var i=z(n)||n;on(i)||function(n,t,e){on(n)||(n.llEvLisnrs={});var i=\"VIDEO\"===n.tagName?\"loadeddata\":\"load\";tn(n,i,t),tn(n,\"error\",e)}(i,(function(o){!function(n,t,e,i){var o=O(t);rn(t,e,i),N(t,e.class_loaded),w(t,b),C(e.callback_loaded,t,i),o||nn(e,i)}(0,n,t,e),an(i)}),(function(o){!function(n,t,e,i){var o=O(t);rn(t,e,i),N(t,e.class_error),w(t,p),C(e.callback_error,t,i),e.restore_on_error&&q(t,B),o||nn(e,i)}(0,n,t,e),an(i)}))},ln=function(n,t,e){!function(n){return Z.indexOf(n.tagName)>-1}(n)?function(n,t,e){!function(n){n.llTempImage=document.createElement(\"IMG\")}(n),cn(n,t,e),function(n){P(n)||(n[_]={backgroundImage:n.style.backgroundImage})}(n),function(n,t,e){var i=y(n,t.data_bg),o=y(n,t.data_bg_hidpi),r=a&&o?o:i;r&&(n.style.backgroundImage='url(\"'.concat(r,'\")'),z(n).setAttribute(u,r),Q(n,t,e))}(n,t,e),function(n,t,e){var i=y(n,t.data_bg_multi),o=y(n,t.data_bg_multi_hidpi),r=a&&o?o:i;r&&(n.style.backgroundImage=r,K(n,t,e))}(n,t,e),function(n,t,e){var i=y(n,t.data_bg_set);if(i){var o=i.split(\"|\"),a=o.map((function(n){return\"image-set(\".concat(n,\")\")}));n.style.backgroundImage=a.join(),\"\"===n.style.backgroundImage&&(a=o.map((function(n){return\"-webkit-image-set(\".concat(n,\")\")})),n.style.backgroundImage=a.join()),K(n,t,e)}}(n,t,e)}(n,t,e):function(n,t,e){cn(n,t,e),function(n,t,e){var i=Y[n.tagName];i&&(i(n,t),Q(n,t,e))}(n,t,e)}(n,t,e)},un=function(n){n.removeAttribute(u),n.removeAttribute(s),n.removeAttribute(d)},sn=function(n){D(n,(function(n){q(n,B)})),q(n,B)},dn={IMG:sn,IFRAME:function(n){q(n,V)},VIDEO:function(n){H(n,(function(n){q(n,V)})),q(n,F),n.load()},OBJECT:function(n){q(n,J)}},fn=function(n,t){(function(n){var t=dn[n.tagName];t?t(n):function(n){if(P(n)){var t=S(n);n.style.backgroundImage=t.backgroundImage}}(n)})(n),function(n,t){L(n)||O(n)||(M(n,t.class_entered),M(n,t.class_exited),M(n,t.class_applied),M(n,t.class_loading),M(n,t.class_loaded),M(n,t.class_error))}(n,t),A(n),U(n)},_n=[\"IMG\",\"IFRAME\",\"VIDEO\"],gn=function(n){return n.use_native&&\"loading\"in HTMLImageElement.prototype},vn=function(n,t,e){n.forEach((function(n){return function(n){return n.isIntersecting||n.intersectionRatio>0}(n)?function(n,t,e,i){var o=function(n){return x.indexOf(k(n))>=0}(n);w(n,\"entered\"),N(n,e.class_entered),M(n,e.class_exited),function(n,t,e){t.unobserve_entered&&T(n,e)}(n,e,i),C(e.callback_enter,n,t,i),o||ln(n,e,i)}(n.target,n,t,e):function(n,t,e,i){L(n)||(N(n,e.class_exited),function(n,t,e,i){e.cancel_on_exit&&function(n){return k(n)===v}(n)&&\"IMG\"===n.tagName&&(an(n),function(n){D(n,(function(n){un(n)})),un(n)}(n),sn(n),M(n,e.class_loading),R(i,-1),A(n),C(e.callback_cancel,n,t,i))}(n,t,e,i),C(e.callback_exit,n,t,i))}(n.target,n,t,e)}))},bn=function(n){return Array.prototype.slice.call(n)},mn=function(n){return n.container.querySelectorAll(n.elements_selector)},pn=function(n){return function(n){return k(n)===p}(n)},hn=function(n,t){return function(n){return bn(n).filter(L)}(n||mn(t))},En=function(n,e){var o=c(n);this._settings=o,this.loadingCount=0,function(n,t){i&&!gn(n)&&(t._observer=new IntersectionObserver((function(e){vn(e,n,t)}),function(n){return{root:n.container===document?null:n.container,rootMargin:n.thresholds||n.threshold+\"px\"}}(n)))}(o,this),function(n,e){t&&(e._onlineHandler=function(){!function(n,t){var e;(e=mn(n),bn(e).filter(pn)).forEach((function(t){M(t,n.class_error),A(t)})),t.update()}(n,e)},window.addEventListener(\"online\",e._onlineHandler))}(o,this),this.update(e)};return En.prototype={update:function(n){var t,o,a=this._settings,r=hn(n,a);G(this,r.length),!e&&i?gn(a)?function(n,t,e){n.forEach((function(n){-1!==_n.indexOf(n.tagName)&&function(n,t,e){n.setAttribute(\"loading\",\"lazy\"),cn(n,t,e),function(n,t){var e=Y[n.tagName];e&&e(n,t)}(n,t),w(n,h)}(n,t,e)})),G(e,0)}(r,a,this):(o=r,function(n){n.disconnect()}(t=this._observer),function(n,t){t.forEach((function(t){n.observe(t)}))}(t,o)):this.loadAll(r)},destroy:function(){this._observer&&this._observer.disconnect(),t&&window.removeEventListener(\"online\",this._onlineHandler),mn(this._settings).forEach((function(n){U(n)})),delete this._observer,delete this._settings,delete this._onlineHandler,delete this.loadingCount,delete this.toLoadCount},loadAll:function(n){var t=this,e=this._settings;hn(n,e).forEach((function(n){T(n,t),ln(n,e,t)}))},restoreAll:function(){var n=this._settings;mn(n).forEach((function(t){fn(t,n)}))}},En.load=function(n,t){var e=c(t);ln(n,e)},En.resetStatus=function(n){A(n)},t&&function(n,t){if(t)if(t.length)for(var e,i=0;e=t[i];i+=1)l(n,e);else l(n,t)}(En,window.lazyLoadOptions),En}));\n","// The module cache\nvar __webpack_module_cache__ = {};\n\n// The require function\nfunction __webpack_require__(moduleId) {\n\t// Check if module is in cache\n\tvar cachedModule = __webpack_module_cache__[moduleId];\n\tif (cachedModule !== undefined) {\n\t\treturn cachedModule.exports;\n\t}\n\t// Create a new module (and put it into the cache)\n\tvar module = __webpack_module_cache__[moduleId] = {\n\t\t// no module.id needed\n\t\t// no module.loaded needed\n\t\texports: {}\n\t};\n\n\t// Execute the module function\n\t__webpack_modules__[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\n\t// Return the exports of the module\n\treturn module.exports;\n}\n\n","// getDefaultExport function for compatibility with non-harmony modules\n__webpack_require__.n = (module) => {\n\tvar getter = module && module.__esModule ?\n\t\t() => (module['default']) :\n\t\t() => (module);\n\t__webpack_require__.d(getter, { a: getter });\n\treturn getter;\n};","// define getter functions for harmony exports\n__webpack_require__.d = (exports, definition) => {\n\tfor(var key in definition) {\n\t\tif(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) {\n\t\t\tObject.defineProperty(exports, key, { enumerable: true, get: definition[key] });\n\t\t}\n\t}\n};","__webpack_require__.o = (obj, prop) => (Object.prototype.hasOwnProperty.call(obj, prop))","// define __esModule on exports\n__webpack_require__.r = (exports) => {\n\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\t}\n\tObject.defineProperty(exports, '__esModule', { value: true });\n};","import Ajaxify from './default/views/product/ajaxify';\nimport accordion from './default/components/organisms/accordion';\nimport Header from './default/components/organisms/header/header';\nimport Cart from './default/components/molecules/cart/cart';\nimport Grid from './default/abstracts/grid/grid';\nimport Login from './default/components/molecules/login/login';\nimport Nav from './default/components/atoms/Navigation/main-navigation';\nimport Search from './default/blocks/search/search';\nimport CountryPicker from './default/blocks/country-picker/country-picker';\nimport Toplist from './default/components/molecules/toplist/toplist';\nimport Ace from './default/components/ace/Ace';\nimport ProductPage from './default/views/product/product_page';\nimport Newsletter from './default/blocks/newsletters/newsletter';\nimport Filter from './default/views/product/filter';\nimport StyleAdvisor from './default/components/style_advisor/styleadvisor';\nimport BrandSearch from './default/views/brand/brandsearch';\nimport Wishlist from './default/views/product/wishlist';\nimport Reservation from './default/views/mypages/reservation';\nimport LazyLoad from 'vanilla-lazyload';\nimport MyStyle from './default/components/mystyle';\nimport SimpleSlider from './default/views/product/simple_slider';\nimport RecentlyViewed from './default/blocks/productlists/recentlyviewed.js';\nimport StyleView from './default/blocks/productlists/styleview.js';\nimport Checkout from './default/views/checkout/checkout';\nimport SizeAndFit from './default/components/size_and_fit/sizeAndFit';\n\n// handle scss\nimport './default/app.scss';\n\nclass App {\n\tconstructor() {\n\t\tthis.liveEvent();\n\t\tthis.init();\n\n\t\tthis.header = new Header();\n\t\tthis.checkout = new Checkout();\n\t\tthis.accordion = new accordion();\n\t\tthis.cart = new Cart();\n\t\tthis.login = new Login();\n\t\tthis.grid = new Grid();\n\t\tthis.nav = new Nav();\n\t\tthis.search = new Search();\n\t\tthis.toplist = new Toplist();\n\t\tthis.countryPicker = new CountryPicker();\n\t\tthis.recently_viewed = new RecentlyViewed();\n\t\tthis.styleview = new StyleView();\n\t\tthis.product_page = new ProductPage(this.cart);\n\t\tthis.wishlist = new Wishlist(this.cart);\n\t\tthis.reservation = new Reservation(this.cart);\n\t\tthis.filter = new Filter();\n\t\tthis.ajaxify = new Ajaxify(this.product_page, this.nav, this.filter);\n\t\tthis.style_advisor = new StyleAdvisor();\n\t\tthis.brand_search = new BrandSearch();\n\t\tthis.ace = new Ace();\n\t\tthis.mystyle = new MyStyle();\n\t\tthis.newsletter = new Newsletter();\n\t\tthis.size_and_fit = new SizeAndFit();\n\n\t\tconst smoothScrollToAnchor = (anchor) => {\n\t\t\tconst { top } = document.querySelector(anchor).getBoundingClientRect();\n\t\t\tconst startPosition = window.pageYOffset;\n\t\t\tconst distance = top - startPosition;\n\t\t\tconst duration = 1000;\n\t\t\tlet start = null;\n\t\t\tconst step = (timestamp) => {\n\t\t\t\tif (!start) start = timestamp;\n\t\t\t\tconst progress = timestamp - start;\n\t\t\t\twindow.scrollTo(0, easeInOutCubic(progress, startPosition, distance, duration));\n\t\t\t\tif (progress < duration) window.requestAnimationFrame(step);\n\t\t\t};\n\n\t\t\twindow.requestAnimationFrame(step);\n\t\t};\n\n\t\tconst easeInOutCubic = (t, b, c, d) => {\n\t\t\tt /= d / 2;\n\t\t\treturn t < 1 ? (c / 2) * t * t * t + b : (c / 2) * ((t -= 2) * t * t + 2) + b;\n\t\t};\n\n\t\twindow.liveEvent('.smoothAnchor', 'click', (event, element) => {\n\t\t\tevent.preventDefault();\n\t\t\tconst target = element.dataset.scrolltarget;\n\t\t\tsmoothScrollToAnchor(target);\n\t\t});\n\n\t\tfunction showTooltip(elementWrapper, tooltip) {\n\t\t\telementWrapper.onmousemove = function (e) {\n\t\t\t\tvar x = e.clientX,\n\t\t\t\t\ty = e.clientY;\n\t\t\t\ttooltip.style.top = y + 15 + 'px';\n\n\t\t\t\tif (tooltip.classList.contains('position-right')) {\n\t\t\t\t\ttooltip.style.left = x - 120 + 'px';\n\t\t\t\t} else {\n\t\t\t\t\ttooltip.style.left = x + 15 + 'px';\n\t\t\t\t}\n\t\t\t\tif (/Android|webOS|iPhone|iPad|iPod|BlackBerry/i.test(navigator.userAgent)) {\n\t\t\t\t\ttooltip.classList.add('active');\n\t\t\t\t\tsetTimeout(() => {\n\t\t\t\t\t\ttooltip.classList.remove('active');\n\t\t\t\t\t}, 3000);\n\t\t\t\t} else {\n\t\t\t\t\ttooltip.classList.add('active');\n\t\t\t\t}\n\t\t\t};\n\n\t\t\telementWrapper.onmouseout = function (e) {\n\t\t\t\ttooltip.classList.remove('active');\n\t\t\t};\n\t\t}\n\n\t\tdocument.querySelectorAll('.tooltip-span').forEach((tooltip) => {\n\t\t\tconst parent = tooltip.parentNode;\n\t\t\tshowTooltip(parent, tooltip);\n\t\t});\n\n\t\tconst backdrop = document.querySelector('.backdrop');\n\n\t\t// Preowned info toggle\n\t\tlet preownedInfo = document.querySelector('#testJJ');\n\t\tlet preownedInfoBtn = document.querySelector('.modal a');\n\n\t\tif (preownedInfoBtn) {\n\t\t\tpreownedInfoBtn.addEventListener('click', function () {\n\t\t\t\tpreownedInfo.classList.add('active');\n\t\t\t\tbackdrop.classList.add('active');\n\t\t\t});\n\t\t}\n\n\t\tlet video = document.querySelector('video');\n\t\tlet videoElements = document.querySelectorAll('video, .videoInfoWrapper');\n\t\tlet videoWrapper = document.querySelector('.video');\n\t\tif (videoElements) {\n\t\t\tvideoElements.forEach((element) => {\n\t\t\t\telement.addEventListener('click', function () {\n\t\t\t\t\tif (video.paused) {\n\t\t\t\t\t\tvideo.play();\n\t\t\t\t\t} else {\n\t\t\t\t\t\tvideo.pause();\n\t\t\t\t\t}\n\t\t\t\t\tvideoWrapper.classList.toggle('playing');\n\t\t\t\t\tvideoWrapper.classList.add('started');\n\t\t\t\t});\n\t\t\t});\n\t\t}\n\n\t\t/* Fredrik special för egenskaper */\n\t\tvar products = document.querySelectorAll('.product--group .big img:not(.product__img--hover)');\n\n\t\tproducts.forEach(myFunction);\n\n\t\tfunction myFunction(item, index, arr) {\n\t\t\titem.src = item.src.replace('.jpg', '_2.jpg').replace('artiklar/', 'artiklar/zoom/');\n\t\t}\n\n\t\tconst target = document.querySelector('.menu__categories');\n\t\tconst close = document.querySelectorAll('.close');\n\n\t\tif (target) {\n\t\t\ttarget.addEventListener('mouseover', mOver, false);\n\t\t\ttarget.addEventListener('mouseout', mOut, false);\n\t\t}\n\n\t\tfunction mOver(event) {\n\t\t\tif (event.target.closest('.has__children, .brandsLink')) {\n\t\t\t\tdocument.body.classList.add('activeNav');\n\t\t\t\tbackdrop.classList.add('active');\n\t\t\t}\n\t\t}\n\n\t\tfunction mOut() {\n\t\t\tconst clicked = document.querySelector('.reload');\n\t\t\tif (clicked) {\n\t\t\t\tclicked.classList.remove('reload');\n\t\t\t}\n\n\t\t\tbackdrop.classList.remove('active');\n\t\t\tdocument.body.classList.remove('activeNav');\n\t\t}\n\n\t\tconst kundradgivning = document.querySelector('.kundradgivning');\n\t\tif (kundradgivning) {\n\t\t\twindow.liveEvent('.header__customerservice', 'click', (event, element) => {\n\t\t\t\tkundradgivning.classList.add('active');\n\t\t\t\tbackdrop.classList.add('active');\n\t\t\t\tdocument.body.classList.add('fullbackdrop');\n\t\t\t});\n\n\t\t\tconst kundradgivningClose = document.querySelector('.kundradgivning .close');\n\t\t\tif (kundradgivningClose) {\n\t\t\t\tkundradgivningClose.addEventListener('click', () => {\n\t\t\t\t\tkundradgivning.classList.remove('active');\n\t\t\t\t\tbackdrop.classList.remove('active');\n\t\t\t\t\tdocument.body.classList.remove('fullbackdrop');\n\t\t\t\t});\n\t\t\t}\n\t\t}\n\n\t\tconst modalSlideOut = document.querySelector('#modal_area');\n\t\tif (modalSlideOut) {\n\t\t\twindow.liveEvent('.modalTrigger', 'click', (event, element) => {\n\t\t\t\t// Get the data-header and data-content attributes from the clicked element\n\t\t\t\tconst headerText = element.getAttribute('data-header');\n\t\t\t\tconst contentText = element.getAttribute('data-content');\n\n\t\t\t\t// Find the modal header and content elements\n\t\t\t\tconst modalHeader = modalSlideOut.querySelector('.modal__header h2');\n\t\t\t\tconst modalContent = modalSlideOut.querySelector('.modal__content');\n\n\t\t\t\t// Update the modal header and content with the new text\n\t\t\t\tif (modalHeader) {\n\t\t\t\t\tmodalHeader.textContent = headerText;\n\t\t\t\t}\n\t\t\t\tif (modalContent) {\n\t\t\t\t\tmodalContent.innerHTML = contentText;\n\t\t\t\t}\n\t\t\t\tif (contentText && contentText.includes('lipscore')) {\n\t\t\t\t\tlipscore.initWidgets();\n\t\t\t\t}\n\n\t\t\t\t// Add the active class to the modal and backdrop\n\t\t\t\tmodalSlideOut.classList.add('active');\n\t\t\t\tif (backdrop) {\n\t\t\t\t\tbackdrop.classList.add('active');\n\t\t\t\t\tdocument.body.classList.add('fullbackdrop');\n\t\t\t\t}\n\t\t\t});\n\n\t\t\tconst modalSlideOutClose = document.querySelector('#modal_area .close');\n\t\t\tif (modalSlideOutClose) {\n\t\t\t\tmodalSlideOutClose.addEventListener('click', () => {\n\t\t\t\t\tmodalSlideOut.classList.remove('active');\n\t\t\t\t\tbackdrop.classList.remove('active');\n\t\t\t\t\tdocument.body.classList.remove('fullbackdrop');\n\t\t\t\t});\n\t\t\t}\n\t\t}\n\n\t\tconst sizeNFit = document.getElementById('sizeandfit');\n\t\tconst styleadvisor = document.getElementById('styleadvisor');\n\t\tconst login_form= document.getElementById('login-wrapper');\n\t\tconst cart = document.querySelector('#air-cart');\n\t\tbackdrop.addEventListener('click', function () {\n\t\t\tdocument.body.style.overflow = '';\n\t\t\tcart.classList.remove('active');\n\t\t\tdocument.body.classList.remove('cart-open');\n\t\t\tbackdrop.classList.remove('active');\n\t\t\tif (document.querySelector('.page--settings--wrapper')) {\n\t\t\t\tdocument.querySelector('.page--settings--wrapper').classList.remove('--active');\n\t\t\t}\n\t\t\tbackdrop.classList.remove('filter-open');\n\t\t\tif (document.querySelector('#header .header__search #suggest-area.active')) {\n\t\t\t\tdocument.querySelector('#header .header__search #suggest-area.active').style.maxHeight = '0px';\n\t\t\t}\n\n\t\t\tif (styleadvisor.classList.contains('active') && typeof _imbox !== 'undefined') {\n\t\t\t\t_imbox.push(['showLauncher']);\n\t\t\t}\n\t\t\tif (sizeNFit && sizeNFit.classList.contains('active')) {\n\t\t\t\tsessionStorage.clear();\n\t\t\t\tsessionStorage.setItem('snf_step', '1');\n\t\t\t\tsizeNFit.classList.remove('from-pdp');\n\t\t\t\tsizeNFit.classList.remove('active');\n\t\t\t\tdocument.body.classList.remove('sizeandfit-open');\n\t\t\t}\n\t\t\tlogin_form.classList.remove('active');\n\t\t\tkundradgivning.classList.remove('active');\n\t\t\tstyleadvisor.classList.remove('active');\n\t\t\tdocument.body.classList.remove('styleadvisor');\n\t\t\tdocument.getElementById('suggest-result').style.display = 'none';\n\t\t\tdocument.getElementById('suggest-init').style.display = 'none';\n\n\t\t\tif (sessionStorage) {\n\t\t\t\tthis.test_completed = sessionStorage.getItem('test_completed');\n\t\t\t\tif (this.test_completed && this.test_completed !== '') {\n\t\t\t\t\tlocation.reload();\n\t\t\t\t\tsessionStorage.setItem('test_completed', '');\n\t\t\t\t}\n\t\t\t}\n\t\t});\n\t\tclose.forEach((element) => {\n\t\t\telement.addEventListener('click', function () {\n\t\t\t\tdocument.body.style.overflow = '';\n\t\t\t\tbackdrop.classList.remove('active');\n\t\t\t\tif (cart) {\n\t\t\t\t\tcart.classList.remove('active');\n\t\t\t\t}\n\n\t\t\t\tdocument.body.classList.remove('cart-open');\n\t\t\t\tstyleadvisor.classList.remove('active');\n\t\t\t\tdocument.body.classList.remove('styleadvisor');\n\t\t\t\tdocument.getElementById('suggest-result').style.display = 'none';\n\t\t\t\tdocument.getElementById('suggest-init').style.display = 'none';\n\t\t\t});\n\t\t});\n\t}\n\n\tinit() {\n\t\tthis.lazyload();\n\n\t\t// init sliders\n\t\tdocument.querySelectorAll('.snapping--wrapper').forEach(function (elem) {\n\t\t\tnew SimpleSlider(elem);\n\t\t});\n\t}\n\n\tlazyload() {\n\t\twindow.lazyLoadInstance = new LazyLoad({\n\t\t\tunobserve_entered: true, // <- Avoid executing the function multiple times\n\t\t\tcallback_enter: this.executeLazyFunction // Assigning the function defined above\n\t\t});\n\t\twindow.lazyFunctions = {};\n\t}\n\n\texecuteLazyFunction(element) {\n\t\tvar lazyFunctionName = element.getAttribute('data-lazy-function');\n\t\tvar lazyFunction = window.lazyFunctions[lazyFunctionName];\n\t\tif (!lazyFunction) return;\n\t\tlazyFunction(element);\n\t}\n\n\tliveEvent() {\n\t\twindow.liveEvent = (selector, event, handler) => {\n\t\t\tdocument.body.addEventListener(\n\t\t\t\tevent,\n\t\t\t\tfunction (e) {\n\t\t\t\t\tvar target = e.target;\n\t\t\t\t\twhile (target != null) {\n\t\t\t\t\t\tvar isMatch = target.matches(selector);\n\t\t\t\t\t\tif (isMatch) {\n\t\t\t\t\t\t\thandler(e, target);\n\t\t\t\t\t\t\treturn;\n\t\t\t\t\t\t}\n\t\t\t\t\t\ttarget = target.parentElement;\n\t\t\t\t\t}\n\t\t\t\t},\n\t\t\t\ttrue\n\t\t\t);\n\t\t};\n\t}\n}\n\nconst app = new App();\n"],"names":[],"sourceRoot":""}