2022/23-H-RYD-LS-FAN-A07281
               
            
        
          
          
              
              
                
                  2022-2023 Al-Nassr Home  Long Sleeve Jersey
                
              
            
        
          
          
              
                
  
  
    ${function() {
      const variantData = data.variant || {"id":"de41ecf0-311a-4980-b61d-41a32153cb3a","product_id":"9d433985-d4ef-430b-9a6c-dcce02d3f733","title":"S-No","weight_unit":"kg","inventory_quantity":0,"sku":"\u7537\u58eb\u6b3e-2022\/23-H-LS-FAN-A07682","barcode":"2022-2023 \u5229\u96c5\u5f97\u4e3b\u573a\u957f\u8896\u7403\u8863","position":1,"option1":"S","option2":"No","option3":"","note":"","image":null,"wholesale_price":[{"price":22.9,"min_quantity":1}],"weight":"0","compare_at_price":"47.9","price":"22.9","retail_price":"47.9","available":true,"url":"\/products\/2022-2023-riyadh-home-long-sleeve-jersey?variant=de41ecf0-311a-4980-b61d-41a32153cb3a","available_quantity":999999999,"options":[{"name":"Size","value":"S"},{"name":"Custom Items","value":"No"}],"off_ratio":52,"flashsale_info":[],"sales":0};
      const saveType = "percentage";
      const productLabelDiscountOn = true;
      return `
        
          
            
              -
               
            
          
          
            
              ${saveType == 'percentage'
                ? `-${variantData.off_ratio}% `
                : `- 
            
           
         
      `;
    }()}
   
 
              
              
              
            
        
          
          
              
                
              
          
        
          
          
              
              
              
            
        
          
          
              
   
  
  
  
  
    
      
      
      
      
      
      
        
          
            Size:  
            
              
                
                  ${function(){
                    return `${data.value} `;
                  }()}
                 
               
            
           
          
         
      
      
        
          ${function(){
            const tipText = "Please select a {{ name }}".replace(/\{\{\s+name\s+\}\}/g, data);
            return `${tipText}
`
          }()}
         
       
    
      
      
      
      
      
      
        
          
            Custom Items:  
            
              
                
                  ${function(){
                    return `${data.value} `;
                  }()}
                 
               
            
           
          
         
      
      
        
          ${function(){
            const tipText = "Please select a {{ name }}".replace(/\{\{\s+name\s+\}\}/g, data);
            return `${tipText}
`
          }()}
         
       
    
   
            
        
          
          
              
                
              
          
        
          
          
              
            
        
          
          
              
  
    
   
   
            
        
          
          
              
  
    
      ${function() {
        const minInventory = parseInt('10');
        const maxInventory = parseInt('50');
        const randomInventory = Math.round(Math.random() * (maxInventory - minInventory)) + minInventory;
        const customText = "Only {stock} item(s) left in stock!".replace(/\{stock\}/g, '' + randomInventory + ' ');
        const barWidth = (randomInventory / maxInventory) * 100 + '%';
        return `
          
        `;
      }()}
     
   
            
        
          
          
              
  
  
    
    
      
  
    ${function() {
      const minDays = parseInt('7');
      const maxDays = parseInt('15');
      const customText = "Estimated Delivery\uff1a{min_date} - {max_date}";
      const minDate = new Date(Date.now() + (minDays * 86400000));
      const maxDate = new Date(Date.now() + (maxDays * 86400000));
      const formatDate = (minDate.getFullYear() == maxDate.getFullYear() && minDate.getFullYear() == new Date().getFullYear())
      ? new Intl.DateTimeFormat('en', { month: 'short', day: '2-digit' })
      : new Intl.DateTimeFormat('en', { month: 'short', day: '2-digit', year: 'numeric' });
      const tipText = customText.replace(/\{min_date\}/g, '' + formatDate.format(minDate) + ' ')
        .replace(/\{max_date\}/g, '' + formatDate.format(maxDate) + ' ');
      return `
        ${tipText}
      `;
    }()}
   
 
    
    
   
            
        
          
          
              
  
  
    
      
    
  
  
    
      
        Add to cart 
        
          
            
           
          
  ${function(){
    const wholesale_enabled = false;
    const qty = data.quantity || 1;
    
    const currentSelectVariant = data.variant;
    
    const defaultVariant = (data.product && data.product.variants && data.product.variants[0]);
    
    const productVariant = {"id":"de41ecf0-311a-4980-b61d-41a32153cb3a","product_id":"9d433985-d4ef-430b-9a6c-dcce02d3f733","title":"S-No","weight_unit":"kg","inventory_quantity":0,"sku":"\u7537\u58eb\u6b3e-2022\/23-H-LS-FAN-A07682","barcode":"2022-2023 \u5229\u96c5\u5f97\u4e3b\u573a\u957f\u8896\u7403\u8863","position":1,"option1":"S","option2":"No","option3":"","note":"","image":null,"wholesale_price":[{"price":22.9,"min_quantity":1}],"weight":"0","compare_at_price":"47.9","price":"22.9","retail_price":"47.9","available":true,"url":"\/products\/2022-2023-riyadh-home-long-sleeve-jersey?variant=de41ecf0-311a-4980-b61d-41a32153cb3a","available_quantity":999999999,"options":[{"name":"Size","value":"S"},{"name":"Custom Items","value":"No"}],"off_ratio":52,"flashsale_info":[],"sales":0};
    const variantData = currentSelectVariant || defaultVariant || productVariant;
    const wholesale_price = variantData.wholesale_price || [];
    if(wholesale_enabled && wholesale_price.length > 0) {
      let wholesaleIndex = wholesale_price.findIndex(item => {
        return item.min_quantity > qty;
      });
      if(wholesaleIndex < 0){
        wholesaleIndex = wholesale_price.length - 1;
      }else if(wholesaleIndex > 0){
        wholesaleIndex = wholesaleIndex - 1;
      }
      const wholesalePrice = wholesale_price[wholesaleIndex] || '';
      return `
        
          
      `
    }else {
      const price = variantData && variantData.price;
      return price != undefined ? `
` : ' 
        
        
       
    
    
      
        Buy now 
        
       
    
    
    
      Product was out of stock.
    
    
      Product is unavailable.
    
   
            
        
          
          
              
                
  
  /** @private {string} */
  class SpzCustomAnchorScroll extends SPZ.BaseElement {
    static deferredMount() {
      return false;
    }
    constructor(element) {
      super(element);
      /** @private {Element} */
      this.scrollableContainer_ = null;
    }
    isLayoutSupported(layout) {
      return layout == SPZCore.Layout.LOGIC;
    }
    buildCallback() {
      this.viewport_ = this.getViewport();
      this.initActions_();
    }
    setTarget(containerId, targetId) {
      this.containerId = '#' + containerId;
      this.targetId = '#' + targetId;
    }
    scrollToTarget() {
      const container = document.querySelector(this.containerId);
      const target = container.querySelector(this.targetId);
      const {scrollTop} = container;
      const eleOffsetTop = this.getOffsetTop_(target, container);
      this.viewport_
        .interpolateScrollIntoView_(
          container,
          scrollTop,
          scrollTop + eleOffsetTop
        );
    }
    initActions_() {
      this.registerAction(
        'scrollToTarget',
        (invocation) => this.scrollToTarget(invocation?.caller)
      );
      this.registerAction(
        'setTarget',
        (invocation) => this.setTarget(invocation?.args?.containerId, invocation?.args?.targetId)
      );
    }
    /**
    * @param {Element} element
    * @param {Element} container
    * @return {number}
    * @private
    */
    getOffsetTop_(element, container) {
      if (!element./*OK*/ getClientRects().length) {
        return 0;
      }
      const rect = element./*OK*/ getBoundingClientRect();
      if (rect.width || rect.height) {
        return rect.top - container./*OK*/ getBoundingClientRect().top;
      }
      return rect.top;
    }
  }
  SPZ.defineElement('spz-custom-anchor-scroll', SpzCustomAnchorScroll);
 
  const STRENGTHEN_TRUST_URL = "/api/strengthen_trust/settings";
  class SpzCustomStrengthenTrust extends SPZ.BaseElement {
    constructor(element) {
      super(element);
      this.renderElement_ = null;
    }
    isLayoutSupported(layout) {
      return layout == SPZCore.Layout.CONTAINER;
    }
    buildCallback() {
      this.xhr_ = SPZServices.xhrFor(this.win);
      const renderId = this.element.getAttribute('render-id');
      SPZCore.Dom.waitForChild(
        document.body,
        () => !!document.getElementById(renderId),
        () => {
          this.renderElement_ = SPZCore.Dom.scopedQuerySelector(
            document.body,
            `#${renderId}`
          );
          if (this.renderElement_) {
            this.render_();
          }
          this.registerAction('track', (invocation) => {
            this.track_(invocation.args);
          });
        }
      );
    }
    render_() {
      this.fetchData_().then((data) => {
        if (!data) {
          return;
        }
        SPZ.whenApiDefined(this.renderElement_).then((apis) => {
          apis?.render(data);
          document.querySelector('#strengthen-trust-render-1539149753700').addEventListener('click',(event)=>{
            if(event.target.nodeName == 'A'){
              this.track_({type: 'trust_content_click'});
            }
          })
        });
      });
    }
    track_(data = {}) {
      const track = window.sa && window.sa.track;
      if (!track) {
        return;
      }
      track('trust_enhancement_event', data);
    }
    parseJSON_(string) {
      let result = {};
      try {
        result = JSON.parse(string);
      } catch (e) {}
      return result;
    }
    fetchData_() {
      return this.xhr_
        .fetchJson(STRENGTHEN_TRUST_URL)
        .then((responseData) => {
          if (!responseData || !responseData.data) {
            return null;
          }
          const data = responseData.data;
          const moduleSettings = (data.module_settings || []).reduce((result, moduleSetting) => {
            return result.concat(Object.assign(moduleSetting, {
              logos: (moduleSetting.logos || []).map((item) => {
                return moduleSetting.logos_type == 'custom' ? this.parseJSON_(item) : item;
              })
            }));
          }, []);
          return Object.assign(data, {
            module_settings: moduleSettings,
            isEditor: window.self !== window.top,
          });
        });
    }
  }
  SPZ.defineElement('spz-custom-strengthen-trust', SpzCustomStrengthenTrust);
 
  
    
      
        
          ${data.module_title}
        
        
          
  
     
  
    
       
   
 
          
            To display this card to customers, you need to go to "Booster & Store Conversion" to turn on the trust enhancement feature.
           
         
        
          
            
            
  
    
    
      ${item.content.replaceAll("{store_name}","ZORABALL")}
    
    
      
    
      
   
 
           
         
       
      
  
    
  
     
  
    
       
   
 
    
      To display this card to customers, you need to go to "Booster & Store Conversion" to turn on the trust enhancement feature.