if(!customElements.get("quick-add-drawer")){class QuickAddDrawer extends SideDrawer{constructor(){super(),this.content=this.querySelector(".js-product-details"),this.footer=this.querySelector(".drawer__footer"),this.form=this.querySelector("product-form"),this.notification=this.querySelector(".js-added-to-cart"),this.backBtn=this.querySelector(".drawer__back-btn"),this.openCartDrawerLinks=this.querySelectorAll(".js-open-cart-drawer"),this.cartDrawer=document.querySelector("cart-drawer"),this.fetch=null,this.fetchedUrls=[],this.quickAddButtonMouseEnterHandler=this.handleQuickAddButtonMouseEnter.bind(this),this.documentClickHandler=this.handleDocumentClick.bind(this),document.addEventListener("click",this.documentClickHandler),this.addEventListener("on:variant:change",this.handleVariantChange.bind(this)),this.openCartDrawerLinks.forEach(link=>{link.addEventListener("click",this.handleOpenCartClick.bind(this))}),theme.device.hasHover&&theme.mediaMatches.md&&(document.querySelectorAll(".js-quick-add").forEach(button=>{this.bindQuickAddButtonMouseEnter(button)}),"MutationObserver"in window&&(this.observer=new MutationObserver(mutations=>{mutations.forEach(mutation=>{mutation.addedNodes.forEach(node=>{node.nodeType===Node.ELEMENT_NODE&&node.querySelectorAll(".js-quick-add").forEach(button=>{this.bindQuickAddButtonMouseEnter(button)})}),mutation.removedNodes.forEach(node=>{node.nodeType===Node.ELEMENT_NODE&&node.querySelectorAll(".js-quick-add").forEach(button=>{button.removeEventListener("mouseenter",this.quickAddButtonMouseEnterHandler)})})})}),this.observer.observe(document.body,{childList:!0,subtree:!0})))}disconnectedCallback(){document.removeEventListener("click",this.documentClickHandler),document.querySelectorAll(".js-quick-add").forEach(button=>{button.removeEventListener("mouseenter",this.quickAddButtonMouseEnterHandler)}),this.observer&&this.observer.disconnect()}bindQuickAddButtonMouseEnter(button){button.dataset.quickAddListenerAdded||(button.dataset.quickAddListenerAdded="true",button.addEventListener("mouseenter",this.quickAddButtonMouseEnterHandler))}handleQuickAddButtonMouseEnter(evt){this.fetchedUrls.includes(evt.target.dataset.productUrl)||(this.fetch={url:evt.target.dataset.productUrl,promise:fetch(evt.target.dataset.productUrl)},this.fetchedUrls.push(evt.target.dataset.productUrl))}handleOpenCartClick(evt){this.cartDrawer?(evt.preventDefault(),this.cartDrawer.open()):window.location.pathname===theme.routes.cart&&(evt.preventDefault(),this.close())}handleDocumentClick(evt){if(evt.target.matches(".js-quick-add"))if(this.cartDrawer&&this.cartDrawer.ariaHidden==="false"){const overlay=document.querySelector(".js-overlay.is-visible");overlay&&(overlay.style.transitionDelay="200ms"),this.cartDrawer.close(),setTimeout(()=>{this.backBtn.hidden=!1,this.open(evt.target),overlay&&(overlay.style.transitionDelay="")},200)}else this.open(evt.target)}handleVariantChange(evt){let url=this.productUrl;if(evt.detail.variant){const separator=this.productUrl.split("?").length>1?"&":"?";url+=`${separator}variant=${evt.detail.variant.id}`}this.querySelectorAll(".js-prod-link").forEach(link=>{link.href=url})}async open(opener){if(opener.setAttribute("aria-disabled","true"),this.notification&&(this.notification.hidden=!0),this.productUrl&&this.productUrl===opener.dataset.productUrl){super.open(opener),opener.dataset.selectedColor&&this.setActiveVariant(opener),opener.removeAttribute("aria-disabled");return}this.productUrl=opener.dataset.productUrl,this.content.innerHTML="",this.classList.add("is-loading"),this.content.classList.add("drawer__content--out"),this.footer.classList.add("drawer__footer--out"),super.open(opener),(!this.fetch||this.fetch.url!==opener.dataset.productUrl)&&(this.fetch={url:opener.dataset.productUrl,promise:fetch(opener.dataset.productUrl)});const response=await this.fetch.promise;if(response.ok){const tmpl=document.createElement("template");tmpl.innerHTML=await response.text(),this.productEl=tmpl.content.querySelector(".js-product"),this.renderProduct(opener)}this.fetch=null,opener.removeAttribute("aria-disabled")}close(){super.close(()=>{this.backBtn.hidden=!0})}renderProduct(opener){const sectionId=this.productEl.dataset.section;this.productEl.innerHTML=this.productEl.innerHTML.replaceAll(sectionId,"quickadd");const variantPicker=this.productEl.querySelector("variant-picker");variantPicker&&(variantPicker.dataset.updateUrl="false");const sizeChartModal=this.productEl.querySelector('[data-modal="size-chart"]');sizeChartModal&&sizeChartModal.remove(),this.updateContent(),this.updateForm();const activeMedia=this.productEl.querySelector(".media-viewer__item.is-current-variant");activeMedia&&this.updateMedia(activeMedia.dataset.mediaId),opener.dataset.selectedColor&&setTimeout(this.setActiveVariant.bind(this,opener),10)}setActiveVariant(opener){if(this.querySelector(`.opt-btn[value="${opener.dataset.selectedColor}"]`))this.querySelector(`.opt-btn[value="${opener.dataset.selectedColor}"]`).click();else{const colorOptionDropdown=this.querySelector(`.custom-select__option[data-value="${opener.dataset.selectedColor}"]`);colorOptionDropdown&&colorOptionDropdown.closest("custom-select").selectOption(colorOptionDropdown)}}updateMedia(mediaId){const img=this.productEl.querySelector(`[data-media-id="${mediaId}"] img`);if(!img)return;const src=img.src?img.src.split("&width=")[0]:img.dataset.src.split("&width=")[0],container=this.querySelector(".quick-add-info__media"),width=container.offsetWidth,aspectRatio=img.width/img.height;container.innerHTML=` ${img.alt} `}updateContent(){this.content.innerHTML=`
${this.getElementHtml(".product-vendor-sku")}

${this.getElementHtml(".product-price")}
${this.getElementHtml(".product-options")}
${this.getElementHtml(".product-backorder")}
`,this.classList.remove("is-loading"),this.content.classList.remove("drawer__content--out")}updateForm(){const productForm=this.productEl.querySelector("product-form");if(this.footer.classList.remove("quick-add__footer-message"),productForm)this.form.innerHTML=productForm.innerHTML,this.form.init(),Shopify&&Shopify.PaymentButton&&Shopify.PaymentButton.init();else{const signUpForm=this.productEl.querySelector(".product-signup");signUpForm?this.form.innerHTML=signUpForm.innerHTML:(this.footer.classList.add("quick-add__footer-message"),this.form.innerHTML=`

${theme.strings.awaitingSale}

${theme.strings.viewDetails}
`)}this.footer.classList.remove("drawer__footer--out")}getElementHtml(selector){const el=this.productEl.querySelector(selector);return el?el.innerHTML:""}addedToCart(){this.notification&&(setTimeout(()=>{this.notification.hidden=!1},300),setTimeout(()=>{this.notification.hidden=!0},this.notification.dataset.visibleFor))}}customElements.define("quick-add-drawer",QuickAddDrawer)} //# sourceMappingURL=/cdn/shop/t/23/assets/quick-add.js.map?v=35731709454182919081737435250