function getFocusableElements(container){return Array.from(container.querySelectorAll("summary, a[href], button:enabled, [tabindex]:not([tabindex^='-']), [draggable], area, input:not([type=hidden]):enabled, select:enabled, textarea:enabled, object, iframe"))}class SectionId{static#separator="__";static parseId(qualifiedSectionId){return qualifiedSectionId.split(SectionId.#separator)[0]}static parseSectionName(qualifiedSectionId){return qualifiedSectionId.split(SectionId.#separator)[1]}static getIdForSection(sectionId,sectionName){return`${sectionId}${SectionId.#separator}${sectionName}`}}class HTMLUpdateUtility{static viewTransition(oldNode,newContent,preProcessCallbacks=[],postProcessCallbacks=[]){preProcessCallbacks?.forEach(callback=>callback(newContent));const newNodeWrapper=document.createElement("div");HTMLUpdateUtility.setInnerHTML(newNodeWrapper,newContent.outerHTML);const newNode=newNodeWrapper.firstChild,uniqueKey=Date.now();oldNode.querySelectorAll("[id], [form]").forEach(element=>{element.id&&(element.id=`${element.id}-${uniqueKey}`),element.form&&element.setAttribute("form",`${element.form.getAttribute("id")}-${uniqueKey}`)}),oldNode.parentNode.insertBefore(newNode,oldNode),oldNode.style.display="none",postProcessCallbacks?.forEach(callback=>callback(newNode)),setTimeout(()=>oldNode.remove(),500)}static setInnerHTML(element,html){element.innerHTML=html,element.querySelectorAll("script").forEach(oldScriptTag=>{const newScriptTag=document.createElement("script");Array.from(oldScriptTag.attributes).forEach(attribute=>{newScriptTag.setAttribute(attribute.name,attribute.value)}),newScriptTag.appendChild(document.createTextNode(oldScriptTag.innerHTML)),oldScriptTag.parentNode.replaceChild(newScriptTag,oldScriptTag)})}}document.querySelectorAll('[id^="Details-"] summary').forEach(summary=>{summary.setAttribute("role","button"),summary.setAttribute("aria-expanded",summary.parentNode.hasAttribute("open")),summary.nextElementSibling?.getAttribute("id")&&summary.setAttribute("aria-controls",summary.nextElementSibling.id),summary.addEventListener("click",event=>{event.currentTarget.setAttribute("aria-expanded",!event.currentTarget.closest("details").hasAttribute("open"))}),!summary.closest("header-drawer, menu-drawer")&&summary.parentElement.addEventListener("keyup",onKeyUpEscape)});const trapFocusHandlers={};function trapFocus(container,elementToFocus=container){var elements=getFocusableElements(container),first=elements[0],last=elements[elements.length-1];removeTrapFocus(),trapFocusHandlers.focusin=event=>{event.target!==container&&event.target!==last&&event.target!==first||document.addEventListener("keydown",trapFocusHandlers.keydown)},trapFocusHandlers.focusout=function(){document.removeEventListener("keydown",trapFocusHandlers.keydown)},trapFocusHandlers.keydown=function(event){event.code?.toUpperCase()==="TAB"&&(event.target===last&&!event.shiftKey&&(event.preventDefault(),first.focus()),(event.target===container||event.target===first)&&event.shiftKey&&(event.preventDefault(),last.focus()))},document.addEventListener("focusout",trapFocusHandlers.focusout),document.addEventListener("focusin",trapFocusHandlers.focusin),elementToFocus?.focus(),elementToFocus?.tagName==="INPUT"&&["search","text","email","url"].includes(elementToFocus?.type)&&elementToFocus?.value&&elementToFocus?.setSelectionRange(0,elementToFocus?.value.length)}try{document.querySelector(":focus-visible")}catch{focusVisiblePolyfill()}function focusVisiblePolyfill(){const navKeys=["ARROWUP","ARROWDOWN","ARROWLEFT","ARROWRIGHT","TAB","ENTER","SPACE","ESCAPE","HOME","END","PAGEUP","PAGEDOWN"];let currentFocusedElement=null,mouseClick=null;window.addEventListener("keydown",event=>{navKeys.includes(event.code?.toUpperCase())&&(mouseClick=!1)}),window.addEventListener("mousedown",event=>{mouseClick=!0}),window.addEventListener("focus",()=>{currentFocusedElement&¤tFocusedElement.classList.remove("focused"),!mouseClick&&(currentFocusedElement=document.activeElement,currentFocusedElement.classList.add("focused"))},!0)}function pauseAllMedia(){document.querySelectorAll(".js-youtube").forEach(video=>{video.contentWindow.postMessage('{"event":"command","func":"pauseVideo","args":""}',"*")}),document.querySelectorAll(".js-vimeo").forEach(video=>{video.contentWindow.postMessage('{"method":"pause"}',"*")}),document.querySelectorAll("video").forEach(video=>video.pause()),document.querySelectorAll("product-model").forEach(model=>{model.modelViewerUI&&model.modelViewerUI.pause()})}function removeTrapFocus(elementToFocus=null){document.removeEventListener("focusin",trapFocusHandlers.focusin),document.removeEventListener("focusout",trapFocusHandlers.focusout),document.removeEventListener("keydown",trapFocusHandlers.keydown),elementToFocus&&elementToFocus.focus()}function onKeyUpEscape(event){if(event.code?.toUpperCase()!=="ESCAPE")return;const openDetailsElement=event.target.closest("details[open]");if(!openDetailsElement)return;const summaryElement=openDetailsElement.querySelector("summary");openDetailsElement.removeAttribute("open"),summaryElement.setAttribute("aria-expanded",!1),summaryElement.focus()}class QuantityInput extends HTMLElement{constructor(){super(),this.input=this.querySelector("input"),this.changeEvent=new Event("change",{bubbles:!0}),this.input.addEventListener("change",this.onInputChange.bind(this)),this.querySelectorAll("button").forEach(button=>button.addEventListener("click",this.onButtonClick.bind(this)))}quantityUpdateUnsubscriber=void 0;connectedCallback(){this.validateQtyRules(),this.quantityUpdateUnsubscriber=subscribe(PUB_SUB_EVENTS.quantityUpdate,this.validateQtyRules.bind(this))}disconnectedCallback(){this.quantityUpdateUnsubscriber&&this.quantityUpdateUnsubscriber()}onInputChange(event){this.validateQtyRules()}onButtonClick(event){event.preventDefault();const previousValue=this.input.value;event.target.name==="plus"?parseInt(this.input.dataset.min)>parseInt(this.input.step)&&this.input.value==0?this.input.value=this.input.dataset.min:this.input.stepUp():this.input.stepDown(),previousValue!==this.input.value&&this.input.dispatchEvent(this.changeEvent),this.input.dataset.min===previousValue&&event.target.name==="minus"&&(this.input.value=parseInt(this.input.min))}validateQtyRules(){const value=parseInt(this.input.value);if(this.input.min&&this.querySelector(".quantity__button[name='minus']").classList.toggle("disabled",parseInt(value)<=parseInt(this.input.min)),this.input.max){const max=parseInt(this.input.max);this.querySelector(".quantity__button[name='plus']").classList.toggle("disabled",value>=max)}}}customElements.define("quantity-input",QuantityInput);function debounce(fn,wait){let t;return(...args)=>{clearTimeout(t),t=setTimeout(()=>fn.apply(this,args),wait)}}function throttle(fn,delay){let lastCall=0;return function(...args){const now=new Date().getTime();if(!(now-lastCall"u"&&(window.Shopify={}),Shopify.bind=function(fn,scope){return function(){return fn.apply(scope,arguments)}},Shopify.setSelectorByValue=function(selector,value){for(var i=0,count=selector.options.length;i0&&Shopify.setSelectorByValue(this.provinceEl,value)},countryHandler:function(e){var opt=this.countryEl.options[this.countryEl.selectedIndex],raw=opt.getAttribute("data-provinces"),provinces=JSON.parse(raw);if(this.clearOptions(this.provinceEl),provinces&&provinces.length==0)this.provinceContainer.style.display="none";else{for(var i=0;isummary.addEventListener("click",this.onSummaryClick.bind(this))),this.querySelectorAll("button:not(.localization-selector):not(.country-selector__close-button):not(.country-filter__reset-button):not(.button-show-more):not(.reset__button)").forEach(button=>button.addEventListener("click",this.onCloseButtonClick.bind(this)))}onKeyUp(event){if(event.code?.toUpperCase()!=="ESCAPE")return;const openDetailsElement=event.target.closest("details[open]");openDetailsElement&&(openDetailsElement===this.mainDetailsToggle?this.closeMenuDrawer(event,this.mainDetailsToggle.querySelector("summary")):this.closeSubmenu(openDetailsElement))}onSummaryClick(event){const summaryElement=event.currentTarget,detailsElement=summaryElement.parentNode,parentMenuElement=detailsElement.closest(".has-submenu"),isOpen=detailsElement.hasAttribute("open"),reducedMotion=window.matchMedia("(prefers-reduced-motion: reduce)");function addTrapFocus(){trapFocus(summaryElement.nextElementSibling,detailsElement.querySelector("button")),summaryElement.nextElementSibling.removeEventListener("transitionend",addTrapFocus)}detailsElement===this.mainDetailsToggle?(isOpen&&event.preventDefault(),isOpen?this.closeMenuDrawer(event,summaryElement):this.openMenuDrawer(summaryElement),window.matchMedia("(max-width: 990px)")&&document.documentElement.style.setProperty("--viewport-height",`${window.innerHeight}px`)):setTimeout(()=>{detailsElement.classList.add("menu-opening"),summaryElement.setAttribute("aria-expanded",!0),parentMenuElement&&parentMenuElement.classList.add("submenu-open"),!reducedMotion||reducedMotion.matches?addTrapFocus():summaryElement.nextElementSibling.addEventListener("transitionend",addTrapFocus)},100)}openMenuDrawer(summaryElement){setTimeout(()=>{this.mainDetailsToggle.classList.add("menu-opening")}),summaryElement.setAttribute("aria-expanded",!0),trapFocus(this.mainDetailsToggle,summaryElement),document.body.classList.add(`overflow-hidden-${this.dataset.breakpoint}`)}closeMenuDrawer(event,elementToFocus=!1){event!==void 0&&(this.mainDetailsToggle.classList.remove("menu-opening"),this.mainDetailsToggle.querySelectorAll("details").forEach(details=>{details.removeAttribute("open"),details.classList.remove("menu-opening")}),this.mainDetailsToggle.querySelectorAll(".submenu-open").forEach(submenu=>{submenu.classList.remove("submenu-open")}),document.body.classList.remove(`overflow-hidden-${this.dataset.breakpoint}`),removeTrapFocus(elementToFocus),this.closeAnimation(this.mainDetailsToggle),event instanceof KeyboardEvent&&elementToFocus?.setAttribute("aria-expanded",!1))}onFocusOut(){setTimeout(()=>{this.mainDetailsToggle.hasAttribute("open")&&!this.mainDetailsToggle.contains(document.activeElement)&&this.closeMenuDrawer()})}onCloseButtonClick(event){const detailsElement=event.currentTarget.closest("details");this.closeSubmenu(detailsElement),document.body.classList.remove(`overflow-hidden-${this.dataset.breakpoint}`)}closeSubmenu(detailsElement){const parentMenuElement=detailsElement.closest(".submenu-open");parentMenuElement&&parentMenuElement.classList.remove("submenu-open"),detailsElement.classList.remove("menu-opening"),detailsElement.querySelector("summary").setAttribute("aria-expanded",!1),removeTrapFocus(detailsElement.querySelector("summary")),this.closeAnimation(detailsElement)}closeAnimation(detailsElement){let animationStart;const handleAnimation=time=>{animationStart===void 0&&(animationStart=time),time-animationStart<400?window.requestAnimationFrame(handleAnimation):(detailsElement.removeAttribute("open"),detailsElement.closest("details[open]")&&trapFocus(detailsElement.closest("details[open]"),detailsElement.querySelector("summary")))};window.requestAnimationFrame(handleAnimation)}}customElements.define("menu-drawer",MenuDrawer);class HeaderDrawer extends MenuDrawer{constructor(){super()}openMenuDrawer(summaryElement){this.header=this.header||document.querySelector(".section-header"),this.borderOffset=this.borderOffset||this.closest(".header-wrapper").classList.contains("header-wrapper--border-bottom")?1:0,document.documentElement.style.setProperty("--header-bottom-position",`${parseInt(this.header.getBoundingClientRect().bottom-this.borderOffset)}px`),this.header.classList.add("menu-open"),setTimeout(()=>{this.mainDetailsToggle.classList.add("menu-opening")}),summaryElement.setAttribute("aria-expanded",!0),window.addEventListener("resize",this.onResize);let mainMenu=summaryElement.nextElementSibling,mainMenuCloseBtn=mainMenu?.querySelector(".menu-drawer-close-button");trapFocus(mainMenu,mainMenuCloseBtn),setTimeout(()=>{mainMenuCloseBtn?.focus()},100),document.body.classList.add(`overflow-hidden-${this.dataset.breakpoint}`)}closeMenuDrawer(event,elementToFocus){elementToFocus&&(super.closeMenuDrawer(event,elementToFocus),this.header.classList.remove("menu-open"),window.removeEventListener("resize",this.onResize))}onResize=()=>{this.header&&document.documentElement.style.setProperty("--header-bottom-position",`${parseInt(this.header.getBoundingClientRect().bottom-this.borderOffset)}px`),document.documentElement.style.setProperty("--viewport-height",`${window.innerHeight}px`)}}customElements.define("header-drawer",HeaderDrawer);class ModalDialog extends HTMLElement{constructor(){super(),this.querySelector('[id^="ModalClose-"]').addEventListener("click",this.hide.bind(this,!1)),this.addEventListener("keyup",event=>{event.code?.toUpperCase()==="ESCAPE"&&this.hide()}),this.classList.contains("media-modal")?this.addEventListener("pointerup",event=>{event.pointerType==="mouse"&&!event.target.closest("deferred-media, product-model")&&this.hide()}):this.addEventListener("click",event=>{event.target===this&&this.hide()})}connectedCallback(){this.moved||(this.moved=!0,document.body.appendChild(this))}show(opener){this.openedBy=opener;const popup=this.querySelector(".template-popup");this.setAttribute("open",""),popup&&popup.loadContent(),trapFocus(this,this.querySelector('[role="dialog"]')),window.pauseAllMedia()}hide(){document.body.dispatchEvent(new CustomEvent("modalClosed")),this.removeAttribute("open"),removeTrapFocus(this.openedBy),window.pauseAllMedia()}}customElements.define("modal-dialog",ModalDialog);class BulkModal extends HTMLElement{constructor(){super()}connectedCallback(){const handleIntersection=(entries,observer)=>{if(entries[0].isIntersecting&&(observer.unobserve(this),this.innerHTML.trim()==="")){const productUrl=this.dataset.url.split("?")[0];fetch(`${productUrl}?section_id=bulk-quick-order-list`).then(response=>response.text()).then(responseText=>{const sourceQty=new DOMParser().parseFromString(responseText,"text/html").querySelector(".quick-order-list-container").parentNode;this.innerHTML=sourceQty.innerHTML}).catch(e=>{console.error(e)})}};new IntersectionObserver(handleIntersection.bind(this)).observe(document.querySelector(`#QuickBulk-${this.dataset.productId}-${this.dataset.sectionId}`))}}customElements.define("bulk-modal",BulkModal);class ModalOpener extends HTMLElement{constructor(){super();const button=this.querySelector("button");button&&button.addEventListener("click",()=>{const modal=document.querySelector(this.getAttribute("data-modal"));modal&&modal.show(button)})}}customElements.define("modal-opener",ModalOpener);class DeferredMedia extends HTMLElement{constructor(){super();const poster=this.querySelector('[id^="Deferred-Poster-"]');poster&&poster.addEventListener("click",this.loadContent.bind(this))}loadContent(focus=!0){if(window.pauseAllMedia(),!this.getAttribute("loaded")){const content=document.createElement("div");content.appendChild(this.querySelector("template").content.firstElementChild.cloneNode(!0)),this.setAttribute("loaded",!0);const deferredElement=this.appendChild(content.querySelector("video, model-viewer, iframe"));focus&&deferredElement.focus(),deferredElement.nodeName=="VIDEO"&&deferredElement.getAttribute("autoplay")&&deferredElement.play()}}}customElements.define("deferred-media",DeferredMedia);class SliderComponent extends HTMLElement{constructor(){if(super(),this.slider=this.querySelector('[id^="Slider-"]'),this.sliderItems=this.querySelectorAll('[id^="Slide-"]'),this.enableSliderLooping=!1,this.currentPageElement=this.querySelector(".slider-counter--current"),this.pageTotalElement=this.querySelector(".slider-counter--total"),this.prevButton=this.querySelector('button[name="previous"]'),this.nextButton=this.querySelector('button[name="next"]'),this.isGellerySlider=this.slider?.classList.contains("product__media-list")||!1,this.slideMode=this.getAttribute("data-slide-mode")||"slide",this.isThumbnail=this.slider?.classList.contains("thumbnail-list")||!1,this.direction=this.getAttribute("data-slider-direction")||"horizontal",!this.slider||!this.nextButton)return;if(this.initThumbnailsMaxH(),this.initPages(),new ResizeObserver(entries=>{this.initThumbnailsMaxH(),this.initPages()}).observe(this.slider),this.slider.addEventListener("scroll",this.update.bind(this)),this.prevButton.addEventListener("click",this.onButtonClick.bind(this)),this.nextButton.addEventListener("click",this.onButtonClick.bind(this)),this.isGellerySlider&&this.slideMode=="fade"){let gelleryObserver=new MutationObserver(mutations=>{mutations.forEach(mutation=>{mutation.attributeName==="class"&&this.handleProductMediaButtonState()})}),observerTarget=this.querySelectorAll(".product__media-list li")||[];gelleryObserver.observe(observerTarget[0],{attributes:!0,attributeFilter:["class"]}),gelleryObserver.observe(observerTarget[observerTarget.length-1],{attributes:!0,attributeFilter:["class"]}),this.prevButton.removeEventListener("click",this.onButtonClick),this.prevButton.addEventListener("click",this.onGelleryButtonClick.bind(this)),this.nextButton.removeEventListener("click",this.onButtonClick),this.nextButton.addEventListener("click",this.onGelleryButtonClick.bind(this));const MIN_SWIPE_DISTANCE=20;var startX=0;this.addEventListener("touchstart",event=>{startX=event.touches[0].clientX}),this.addEventListener("touchend",event=>{var endX=event.changedTouches[0].clientX,distance=endX-startX;Math.abs(distance)>MIN_SWIPE_DISTANCE&&(distance>0?this.prevButton.click():this.nextButton.click())})}if(this.isThumbnail){let mutationObserver=new MutationObserver(mutationsList=>{for(let mutation of mutationsList)mutation.type==="attributes"&&this.handleThumbnailButtonState()}),observerTarget=this.querySelectorAll(".thumbnail-list li")||[];mutationObserver.observe(observerTarget[0]?.childNodes[0],{attributes:!0}),mutationObserver.observe(observerTarget[observerTarget.length-1]?.childNodes[0],{attributes:!0});let observerView=new IntersectionObserver(entries=>{entries.forEach(entry=>{if(entry.isIntersecting){let target=entry.target;target.removeAttribute("aria-hidden"),target.querySelectorAll("button")?.forEach(button=>{button.removeAttribute("tabindex")})}else{let target=entry.target;target.setAttribute("aria-hidden","true"),target.querySelectorAll("button")?.forEach(button=>{button.setAttribute("tabindex","-1")})}})},{root:this.slider,threshold:.1});Array.from(observerTarget).forEach(item=>observerView.observe(item));const THUMBNAIL_MIN_SWIPE_DISTANCE=this.sliderItems.length>0?this.sliderItems[0].clientWidth:42;var thumbnail_timeout=null;this.slider.addEventListener("scroll",()=>{var scrollDistance=this.slider.scrollLeft;Math.abs(scrollDistance){this.selectFirstThumbnail()},200))})}}initThumbnailsMaxH(){if(this.isThumbnail){if(window.innerWidth>=1100){let pc_number=parseInt(this.getAttribute("data-thumbnails-pc")),MaxH=this.slider.clientHeight;if(pc_number>0&&this.sliderItems.length>pc_number){let tempH=(pc_number-1)*10;this.sliderItems.forEach((item,index)=>{indexthis.direction==="vertical"?element.clientHeight>0:element.clientWidth>0),!(this.sliderItemsToShow.length<2)&&(this.direction==="vertical"?this.sliderItemOffset=this.sliderItemsToShow[1].offsetTop-this.sliderItemsToShow[0].offsetTop:this.sliderItemOffset=this.sliderItemsToShow[1].offsetLeft-this.sliderItemsToShow[0].offsetLeft,this.slidesPerPage=Math.floor(this.direction==="vertical"?(this.slider.clientHeight-this.sliderItemsToShow[0].offsetTop)/this.sliderItemOffset:(this.slider.clientWidth-this.sliderItemsToShow[0].offsetLeft)/this.sliderItemOffset),this.totalPages=this.sliderItemsToShow.length-this.slidesPerPage+1,this.update())}resetPages(){this.sliderItems=this.querySelectorAll('[id^="Slide-"]'),this.initPages()}update(){if(!this.slider||!this.nextButton)return;const previousPage=this.currentPage;this.direction==="vertical"?this.currentPage=Math.round(this.slider.scrollTop/this.sliderItemOffset)+1:this.currentPage=Math.round(this.slider.scrollLeft/this.sliderItemOffset)+1,this.currentPageElement&&this.pageTotalElement&&(this.currentPageElement.textContent=this.currentPage,this.pageTotalElement.textContent=this.totalPages),this.currentPage!=previousPage&&this.dispatchEvent(new CustomEvent("slideChanged",{detail:{currentPage:this.currentPage,currentElement:this.sliderItemsToShow[this.currentPage-1]}})),!this.enableSliderLooping&&(this.isThumbnail?this.handleThumbnailButtonState():this.isGellerySlider&&this.slideMode=="fade"?this.handleProductMediaButtonState():this.handleButtonState())}selectFirstThumbnail(){if(window.innerWidth<1100&&this.isThumbnail&&(Math.ceil(this.slider.scrollLeft+this.slider.clientWidth)=this.slider.scrollWidth&&!this.isChildInViewport(this.slider,this.slider.querySelector('[aria-current="true"]').parentElement))){let elementSetLen=this.querySelectorAll('[id^="Slide-"]')?.length;for(let i=0;iparentRect.left}handleProductMediaButtonState(){let firtNodeState=this.sliderItemsToShow[0]?.classList.contains("is-active"),lastNodeState=this.sliderItemsToShow[this.sliderItemsToShow.length-1]?.classList.contains("is-active");firtNodeState?(this.prevButton.setAttribute("disabled","disabled"),this.prevButton.setAttribute("tabindex","-1")):(this.prevButton.removeAttribute("disabled"),this.prevButton.setAttribute("tabindex","0")),lastNodeState?(this.nextButton.setAttribute("disabled","disabled"),this.nextButton.setAttribute("tabindex","-1")):(this.nextButton.removeAttribute("disabled"),this.nextButton.setAttribute("tabindex","0"))}handleThumbnailButtonState(){let firtNodeState=this.sliderItemsToShow[0]?.childNodes[0].getAttribute("aria-current"),lastNodeState=this.sliderItemsToShow[this.sliderItemsToShow.length-1]?.childNodes[0].getAttribute("aria-current");this.isSlideVisible(this.sliderItemsToShow[0])&&(this.direction==="vertical"?this.slider.scrollTop:this.slider.scrollLeft)===0&&firtNodeState==="true"?this.prevButton.setAttribute("disabled","disabled"):this.prevButton.removeAttribute("disabled"),this.isSlideVisible(this.sliderItemsToShow[this.sliderItemsToShow.length-1])&&lastNodeState==="true"?this.nextButton.setAttribute("disabled","disabled"):this.nextButton.removeAttribute("disabled")}handleButtonState(){this.isSlideVisible(this.sliderItemsToShow[0])&&this.slider.scrollLeft===0?this.prevButton.setAttribute("disabled","disabled"):this.prevButton.removeAttribute("disabled"),this.isSlideVisible(this.sliderItemsToShow[this.sliderItemsToShow.length-1])?this.nextButton.setAttribute("disabled","disabled"):this.nextButton.removeAttribute("disabled")}isSlideVisible(element,offset=0){if(element){const lastVisibleSlide=this.direction==="vertical"?this.slider.clientHeight+this.slider.scrollTop-offset:this.slider.clientWidth+this.slider.scrollLeft-offset;return this.direction==="vertical"?element.offsetTop+element.clientHeight<=lastVisibleSlide&&element.offsetTop>=this.slider.scrollTop:element.offsetLeft+element.clientWidth<=lastVisibleSlide&&element.offsetLeft>=this.slider.scrollLeft}}onButtonClick(event){event.preventDefault(),this.onThumbnailButtonClick(event,this);const step=event.currentTarget.dataset.step||1;this.slideScrollPosition=event.currentTarget.name==="next"?(this.direction==="vertical"?this.slider.scrollTop:this.slider.scrollLeft)+step*this.sliderItemOffset:(this.direction==="vertical"?this.slider.scrollTop:this.slider.scrollLeft)-step*this.sliderItemOffset,this.setSlidePosition(this.slideScrollPosition)}onThumbnailButtonClick(event,_this=this){event.currentTarget.name==="next"&&_this.querySelector('[aria-current="true"]')?.parentNode?.nextElementSibling?_this.querySelector('[aria-current="true"]').parentNode.nextElementSibling.childNodes[0].click():event.currentTarget.name==="previous"&&_this.querySelector('[aria-current="true"]')?.parentNode?.previousElementSibling&&_this.querySelector('[aria-current="true"]').parentNode.previousElementSibling.childNodes[0].click()}onGelleryButtonClick(event,_this=this){event.preventDefault();let quickAddPopupFlag=!!event.target.closest(".quick-add-modal__content-info");if(event.currentTarget.name==="next"){let nextSlide=_this.querySelector(".product__media-item.is-active").nextElementSibling,nextMediaId=quickAddPopupFlag&&nextSlide?.getAttribute("data-media-id").indexOf("quickadd-")===-1?"quickadd-"+nextSlide?.getAttribute("data-media-id"):nextSlide?.getAttribute("data-media-id");document.querySelector(`[data-target="${nextMediaId}"]`)?document.querySelector(`[data-target="${nextMediaId}"]`)?.childNodes[0]?.click():nextSlide&&(_this.querySelectorAll("[data-media-id]").forEach(element=>{element.classList.remove("is-active"),element.setAttribute("aria-current",!0)}),nextSlide?.classList.add("is-active"),nextSlide?.removeAttribute("aria-current"))}else if(event.currentTarget.name==="previous"){let prevSlide=_this.querySelector(".product__media-item.is-active").previousElementSibling,prevMediaId=quickAddPopupFlag&&prevSlide?.getAttribute("data-media-id").indexOf("quickadd-")===-1?"quickadd-"+prevSlide?.getAttribute("data-media-id"):prevSlide?.getAttribute("data-media-id");document.querySelector(`[data-target="${prevMediaId}"]`)?document.querySelector(`[data-target="${prevMediaId}"]`)?.childNodes[0]?.click():prevSlide&&(_this.querySelectorAll("[data-media-id]").forEach(element=>{element.classList.remove("is-active"),element.setAttribute("aria-current",!0)}),prevSlide?.classList.add("is-active"),prevSlide?.removeAttribute("aria-current"))}}setSlidePosition(position){this.direction==="vertical"?this.slider.scrollTo({top:position}):this.slider.scrollTo({left:position})}}customElements.define("slider-component",SliderComponent);class SlideshowComponent extends SliderComponent{constructor(){super(),this.sliderControlWrapper=this.querySelector(".slider-buttons"),this.enableSliderLooping=!0,this.sliderControlWrapper&&(this.sliderFirstItemNode=this.slider.querySelector(".slideshow__slide"),this.sliderItemsToShow.length>0&&(this.currentPage=1),this.announcementBarSlider=this.querySelector(".announcement-bar-slider"),this.announcerBarAnimationDelay=this.announcementBarSlider?250:0,this.sliderControlLinksArray=Array.from(this.sliderControlWrapper.querySelectorAll(".slider-counter__link")),this.sliderControlLinksArray.forEach(link=>link.addEventListener("click",this.linkToSlide.bind(this))),this.slider.addEventListener("scroll",this.setSlideVisibility.bind(this)),this.setSlideVisibility(),this.announcementBarSlider&&(this.announcementBarArrowButtonWasClicked=!1,this.reducedMotion=window.matchMedia("(prefers-reduced-motion: reduce)"),this.reducedMotion.addEventListener("change",()=>{this.slider.getAttribute("data-autoplay")==="true"&&this.setAutoPlay()}),[this.prevButton,this.nextButton].forEach(button=>{button.addEventListener("click",()=>{this.announcementBarArrowButtonWasClicked=!0},{once:!0})})),this.slider.getAttribute("data-autoplay")==="true"&&this.setAutoPlay())}setAutoPlay(){this.autoplaySpeed=this.slider.dataset.speed*1e3,this.addEventListener("mouseover",this.focusInHandling.bind(this)),this.addEventListener("mouseleave",this.focusOutHandling.bind(this)),this.addEventListener("focusin",this.focusInHandling.bind(this)),this.addEventListener("focusout",this.focusOutHandling.bind(this)),this.querySelector(".slideshow__autoplay")?(this.sliderAutoplayButton=this.querySelector(".slideshow__autoplay"),this.sliderAutoplayButton.addEventListener("click",this.autoPlayToggle.bind(this)),this.autoplayButtonIsSetToPlay=!0,this.play()):this.reducedMotion.matches||this.announcementBarArrowButtonWasClicked?this.pause():this.play()}onButtonClick(event){super.onButtonClick(event),this.wasClicked=!0;const isFirstSlide=this.currentPage===1,isLastSlide=this.currentPage===this.sliderItemsToShow.length;if(!isFirstSlide&&!isLastSlide){this.applyAnimationToAnnouncementBar(event.currentTarget.name);return}isFirstSlide&&event.currentTarget.name==="previous"?this.slideScrollPosition=this.slider.scrollLeft+this.sliderFirstItemNode.clientWidth*this.sliderItemsToShow.length:isLastSlide&&event.currentTarget.name==="next"&&(this.slideScrollPosition=0),this.setSlidePosition(this.slideScrollPosition),this.applyAnimationToAnnouncementBar(event.currentTarget.name)}setSlidePosition(position){this.setPositionTimeout&&clearTimeout(this.setPositionTimeout),this.setPositionTimeout=setTimeout(()=>{this.slider.scrollTo({left:position})},this.announcerBarAnimationDelay)}update(){super.update(),this.sliderControlButtons=this.querySelectorAll(".slider-counter__link"),this.prevButton.removeAttribute("disabled"),this.sliderControlButtons.length&&(this.sliderControlButtons.forEach(link=>{link.classList.remove("slider-counter__link--active"),link.removeAttribute("aria-current")}),this.sliderControlButtons[this.currentPage-1].classList.add("slider-counter__link--active"),this.sliderControlButtons[this.currentPage-1].setAttribute("aria-current",!0))}autoPlayToggle(){this.togglePlayButtonState(this.autoplayButtonIsSetToPlay),this.autoplayButtonIsSetToPlay?this.pause():this.play(),this.autoplayButtonIsSetToPlay=!this.autoplayButtonIsSetToPlay}focusOutHandling(event){if(this.sliderAutoplayButton){const focusedOnAutoplayButton=event.target===this.sliderAutoplayButton||this.sliderAutoplayButton.contains(event.target);if(!this.autoplayButtonIsSetToPlay||focusedOnAutoplayButton)return;this.play()}else!this.reducedMotion.matches&&!this.announcementBarArrowButtonWasClicked&&this.play()}focusInHandling(event){this.sliderAutoplayButton?(event.target===this.sliderAutoplayButton||this.sliderAutoplayButton.contains(event.target))&&this.autoplayButtonIsSetToPlay?this.play():this.autoplayButtonIsSetToPlay&&this.pause():this.announcementBarSlider.contains(event.target)&&this.pause()}play(){this.slider.setAttribute("aria-live","off"),clearInterval(this.autoplay),this.autoplay=setInterval(this.autoRotateSlides.bind(this),this.autoplaySpeed)}pause(){this.slider.setAttribute("aria-live","polite"),clearInterval(this.autoplay)}togglePlayButtonState(pauseAutoplay){pauseAutoplay?(this.sliderAutoplayButton.classList.add("slideshow__autoplay--paused"),this.sliderAutoplayButton.setAttribute("aria-label",window.accessibilityStrings.playSlideshow)):(this.sliderAutoplayButton.classList.remove("slideshow__autoplay--paused"),this.sliderAutoplayButton.setAttribute("aria-label",window.accessibilityStrings.pauseSlideshow))}autoRotateSlides(){const slideScrollPosition=this.currentPage===this.sliderItems.length?0:this.slider.scrollLeft+this.sliderItemOffset;this.setSlidePosition(slideScrollPosition),this.applyAnimationToAnnouncementBar()}setSlideVisibility(event){this.sliderItemsToShow.forEach((item,index)=>{const linkElements=item.querySelectorAll("a");index===this.currentPage-1?(linkElements.length&&linkElements.forEach(button=>{button.removeAttribute("tabindex")}),item.setAttribute("aria-hidden","false"),item.removeAttribute("tabindex")):(linkElements.length&&linkElements.forEach(button=>{button.setAttribute("tabindex","-1")}),item.setAttribute("aria-hidden","true"),item.setAttribute("tabindex","-1"))}),this.wasClicked=!1}applyAnimationToAnnouncementBar(button="next"){if(!this.announcementBarSlider)return;const itemsCount=this.sliderItems.length,increment=button==="next"?1:-1,currentIndex=this.currentPage-1;let nextIndex=(currentIndex+increment)%itemsCount;nextIndex=nextIndex===-1?itemsCount-1:nextIndex;const nextSlide=this.sliderItems[nextIndex],currentSlide=this.sliderItems[currentIndex],animationClassIn="announcement-bar-slider--fade-in",animationClassOut="announcement-bar-slider--fade-out",isFirstSlide=currentIndex===0,isLastSlide=currentIndex===itemsCount-1,direction=button==="next"&&!isLastSlide||button==="previous"&&isFirstSlide?"next":"previous";currentSlide.classList.add(`${animationClassOut}-${direction}`),nextSlide.classList.add(`${animationClassIn}-${direction}`),setTimeout(()=>{currentSlide.classList.remove(`${animationClassOut}-${direction}`),nextSlide.classList.remove(`${animationClassIn}-${direction}`)},this.announcerBarAnimationDelay*2)}linkToSlide(event){event.preventDefault();const slideScrollPosition=this.slider.scrollLeft+this.sliderFirstItemNode.clientWidth*(this.sliderControlLinksArray.indexOf(event.currentTarget)+1-this.currentPage);this.slider.scrollTo({left:slideScrollPosition})}}customElements.define("slideshow-component",SlideshowComponent);class VariantSelects extends HTMLElement{constructor(){super()}connectedCallback(){this.addEventListener("change",event=>{const target=this.getInputForEventTarget(event.target);this.updateSelectionMetadata(event),publish(PUB_SUB_EVENTS.optionValueSelectionChange,{data:{event,target,selectedOptionValues:this.selectedOptionValues,selectedVariantTitle:this.selectedVariantTitle}})})}updateSelectionMetadata({target}){const{value,tagName}=target;if(tagName==="SELECT"&&target.selectedOptions.length){Array.from(target.options).find(option=>option.getAttribute("selected")).removeAttribute("selected"),target.selectedOptions[0].setAttribute("selected","selected");const swatchValue=target.selectedOptions[0].dataset.optionSwatchValue,selectedDropdownSwatchValue=target.closest(".product-form__input").querySelector("[data-selected-value] > .swatch");if(!selectedDropdownSwatchValue)return;swatchValue?(selectedDropdownSwatchValue.style.setProperty("--swatch--background",swatchValue),selectedDropdownSwatchValue.classList.remove("swatch--unavailable")):(selectedDropdownSwatchValue.style.setProperty("--swatch--background","unset"),selectedDropdownSwatchValue.classList.add("swatch--unavailable")),selectedDropdownSwatchValue.style.setProperty("--swatch-focal-point",target.selectedOptions[0].dataset.optionSwatchFocalPoint||"unset")}else if(tagName==="INPUT"&&target.type==="radio"){const selectedSwatchValue=target.closest(".product-form__input").querySelector("[data-selected-value]");selectedSwatchValue&&(selectedSwatchValue.innerHTML=value)}}getInputForEventTarget(target){return target.tagName==="SELECT"?target.selectedOptions[0]:target}get selectedOptionValues(){return Array.from(this.querySelectorAll("select option[selected], fieldset:not(.add_collection_swatch) input:checked")).map(({dataset})=>dataset.optionValueId)}get selectedVariantTitle(){return Array.from(this.querySelectorAll("select option[selected], fieldset:not(.add_collection_swatch) input:checked")).map(input=>input.value).join(" / ")}}customElements.define("variant-selects",VariantSelects);class ProductRecommendations extends HTMLElement{observer=void 0;constructor(){super()}connectedCallback(){this.initializeRecommendations(this.dataset.productId)}initializeRecommendations(productId){this.observer?.unobserve(this),this.observer=new IntersectionObserver((entries,observer)=>{entries[0].isIntersecting&&(observer.unobserve(this),this.loadRecommendations(productId))},{rootMargin:"0px 0px 400px 0px"}),this.observer.observe(this)}loadRecommendations(productId){fetch(`${this.dataset.url}&product_id=${productId}§ion_id=${this.dataset.sectionId}`).then(response=>response.text()).then(text=>{const html=document.createElement("div");html.innerHTML=text;const recommendations=html.querySelector("product-recommendations");recommendations?.innerHTML.trim().length&&recommendations?.querySelectorAll("ul.product-grid li").length>0?(this.innerHTML=recommendations.innerHTML,$(this.querySelector("ul.product-grid")).slick({infinite:!0,draggable:!0,slidesToShow:4,slidesToScroll:1,prevArrow:'',nextArrow:'',responsive:[{breakpoint:1e3,settings:{slidesToShow:2}}]})):this.remove(),!this.querySelector("slideshow-component")&&this.classList.contains("complementary-products")&&this.remove(),html.querySelector(".grid__item")&&this.classList.add("product-recommendations--loaded")}).catch(e=>{console.error(e)})}}customElements.define("product-recommendations",ProductRecommendations);class AccountIcon extends HTMLElement{constructor(){super(),this.icon=this.querySelector(".icon")}connectedCallback(){document.addEventListener("storefront:signincompleted",this.handleStorefrontSignInCompleted.bind(this))}handleStorefrontSignInCompleted(event){event?.detail?.avatar&&this.icon?.replaceWith(event.detail.avatar.cloneNode())}}customElements.define("account-icon",AccountIcon);class BulkAdd extends HTMLElement{constructor(){super(),this.queue=[],this.requestStarted=!1,this.ids=[]}startQueue(id,quantity){this.queue.push({id,quantity});const interval=setInterval(()=>{this.queue.length>0?this.requestStarted||this.sendRequest(this.queue):clearInterval(interval)},250)}sendRequest(queue){this.requestStarted=!0;const items={};queue.forEach(queueItem=>{items[parseInt(queueItem.id)]=queueItem.quantity}),this.queue=this.queue.filter(queueElement=>!queue.includes(queueElement)),(this.closest("quick-order-list")||this.closest("quick-add-bulk")).updateMultipleQty(items)}resetQuantityInput(id){const input=this.querySelector(`#Quantity-${id}`);input.value=input.getAttribute("value"),this.isEnterPressed=!1}setValidity(event,index,message){event.target.setCustomValidity(message),event.target.reportValidity(),this.resetQuantityInput(index),event.target.select()}validateQuantity(event){const inputValue=parseInt(event.target.value),index=event.target.dataset.index;inputValueparseInt(event.target.max)?this.setValidity(event,index,window.quickOrderListStrings.max_error.replace("[max]",event.target.max)):inputValue%parseInt(event.target.step)!=0?this.setValidity(event,index,window.quickOrderListStrings.step_error.replace("[step]",event.target.step)):(event.target.setCustomValidity(""),event.target.reportValidity(),this.startQueue(index,inputValue))}getSectionsUrl(){return window.pageNumber?`${window.location.pathname}?page=${window.pageNumber}`:`${window.location.pathname}`}getSectionInnerHTML(html,selector){return new DOMParser().parseFromString(html,"text/html").querySelector(selector).innerHTML}}customElements.get("bulk-add")||customElements.define("bulk-add",BulkAdd);class Linkredirect extends HTMLElement{constructor(){super(),this.urllink=this.querySelector(".link-redirect"),this.openTarget=this.urllink.getAttribute("data-target")||"_self",this.urlToOpen=this.urllink.getAttribute("data-link"),this.urllink.addEventListener("click",()=>{this.openTarget==="_blank"?window.open(this.urlToOpen,"new"):window.location.href=this.urlToOpen})}}customElements.define("link-redirect",Linkredirect);class CheckLabel extends HTMLElement{constructor(){super();const label=this.querySelector("label");label.addEventListener("click",this.onChangeChecked.bind(this)),label.addEventListener("keydown",this.onKeyDown.bind(this))}onChangeChecked(event){const el=event.target,input=el.parentElement.querySelector("input");input?.getAttribute("checked")!="false"?(input.setAttribute("checked","false"),el.classList.remove("active")):(input.setAttribute("checked","true"),el.classList.add("active"))}onKeyDown(event){(event.key==="Enter"||event.key===" ")&&(event.preventDefault(),this.onChangeChecked(event))}}customElements.define("check-label",CheckLabel),customElements.get("size-type-grouping")||customElements.define("size-type-grouping",class extends HTMLElement{constructor(){super()}connectedCallback(){this.handleSizeGrouping()}handleSizeGrouping(){if(this.querySelector(".size-type")){var initmatchtype=this.parentElement.querySelector('input[type="radio"]:checked')?.getAttribute("data-matchtype")?this.parentElement.querySelector('input[type="radio"]:checked')?.getAttribute("data-matchtype"):this.querySelectorAll(".size-type .custom-element")[0].getAttribute("data-value");if(window.sizeTypeObj[initmatchtype]=this.parentElement.querySelector('input[type="radio"]:checked')?.getAttribute("value")?this.parentElement.querySelector('input[type="radio"]:checked')?.getAttribute("value"):this.querySelectorAll(".size-type .custom-element")[0].getAttribute("value"),initmatchtype){let tempEl=this.querySelector(`.size-type .custom-element[data-value="${initmatchtype}"]`);tempEl?.parentElement?.querySelectorAll(`.custom-element:not([data-value="${initmatchtype}"])`)?.forEach(element=>{this.setAttributes(element?.querySelector("button"),{tabindex:"-1","aria-current":"false"}),element.classList.remove("active")}),tempEl.classList.add("active"),this.setAttributes(tempEl?.querySelector("button"),{tabindex:"0","aria-current":"true"}),this.hideElements(`.swatch-label:not([data-matchtype="${initmatchtype}"])`,this.parentElement),this.showElements(`.swatch-label[data-matchtype="${initmatchtype}"]`,this.parentElement),this.querySelectorAll(".size-type .custom-element")?.forEach(el=>{el.addEventListener("click",e=>{let customEl=e.target.closest(".custom-element"),value=customEl?.getAttribute("data-value");customEl?.parentElement?.querySelectorAll(`.custom-element:not([data-value="${value}"])`)?.forEach(element=>{this.setAttributes(customEl?.querySelector("button"),{tabindex:"-1","aria-current":"false"}),element.classList.remove("active")}),customEl?.classList.add("active"),this.setAttributes(customEl?.querySelector("button"),{tabindex:"0","aria-current":"true"}),this.hideElements(`.swatch-label:not([data-matchtype="${value}"])`,this.parentElement),this.showElements(`.swatch-label[data-matchtype="${value}"]`,this.parentElement),document.querySelector("product-info")?.getAttribute("data-deselect-size")!=="true"&&this.handleSizeType(value,this.parentElement)})}),this.querySelectorAll(".size-type .custom-element")?.forEach(el=>{el.addEventListener("keydown",e=>{let element=e.target.closest(".custom-element"),index=parseInt(Array.prototype.indexOf.call(element.parentNode.children,element)),total_size=parseInt(this.querySelectorAll(".size-type .custom-element").length),next_index=index+1,prev_index=index-1;if(next_index>total_size&&(next_index=0),prev_index<0&&(prev_index=total_size-1),e.key=="ArrowRight"||e.key=="ArrowDown"){let nextEl=this.querySelectorAll(".custom-element")[next_index];nextEl&&(this.querySelectorAll(".custom-element")?.forEach(el2=>{this.setAttributes(el2?.querySelector("button"),{tabindex:"-1","aria-current":"false"})}),this.setAttributes(nextEl.querySelector("button"),{tabindex:"0","aria-current":"true"}),nextEl.click(),nextEl.focus())}if(e.key=="ArrowLeft"||e.key=="ArrowUp"){let prevEl=this.querySelectorAll(".custom-element")[prev_index];prevEl&&(this.querySelectorAll(".custom-element")?.forEach(el2=>{this.setAttributes(el2?.querySelector("button"),{tabindex:"-1","aria-current":"false"})}),this.setAttributes(prevEl.querySelector("button"),{tabindex:"0","aria-current":"true"}),prevEl.click(),prevEl.focus())}})})}}}hideElements(selector,context=document){context.querySelectorAll(selector).forEach(element=>{element.style.display="none"})}showElements(selector,context=document){context.querySelectorAll(selector).forEach(element=>{element.style.display="block"})}handleSizeType(type,context=document){let activeType=context.querySelector('input[type="radio"]:checked')?.getAttribute("data-matchtype"),originalValue=window.sizeTypeObj[type];if(type!=activeType&&originalValue&&!context.querySelector(`input[type="radio"][value="${originalValue}"]`)?.classList?.contains("disabled"))context.querySelector(`input[type="radio"][value="${originalValue}"]`)?.nextElementSibling?.click();else if(type!=activeType){for(let el of context.querySelectorAll(`.swatch-label[data-matchtype="${type}"]`))if(el.previousElementSibling&&el.previousElementSibling?.tagName.toLowerCase()==="input"&&!el.previousElementSibling?.classList?.contains("disabled")){el.click();break}}}setAttributes(element,attributes){if(element)for(let key in attributes)element.setAttribute(key,attributes[key])}}); //# sourceMappingURL=/cdn/shop/t/106/assets/global.js.map?v=28605327423882829761752133286