Men's Black And Brown Ribbed Crew Neck Sweatshirt
               
            
        
          
          
              
              
            
        
          
          
              
  
    
      ${function() {
        const minInventory = parseInt('5');
        const maxInventory = parseInt('20');
        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 variantData = data.variant || {"id":"2a8b22f4-58a6-4dce-b93c-a4ebc6ba85db","product_id":"cb343b56-d925-4e49-a831-e3d30d0791bb","title":"Black-S","weight_unit":"kg","inventory_quantity":999,"sku":"1968871419815800833","barcode":"","position":1,"option1":"Black","option2":"S","option3":"","note":"","image":{"src":"\/\/img.staticdj.com\/be7c6d75c3d0c6bcab2176ca4930a10e.png","path":"be7c6d75c3d0c6bcab2176ca4930a10e.png","width":1024,"height":1024,"alt":"95d45594dbf1aa4e4d5ed5f61678fc91","aspect_ratio":1},"wholesale_price":[{"price":24.99,"min_quantity":1}],"weight":"300","compare_at_price":"44","price":"24.99","retail_price":"44","available":true,"url":"\/products\/mens-black-and-brown-ribbed-crew-neck-sweatshirt?variant=2a8b22f4-58a6-4dce-b93c-a4ebc6ba85db","available_quantity":999999999,"options":[{"name":"Color","value":"Black"},{"name":"Size","value":"S"}],"off_ratio":43,"flashsale_info":[],"sales":2};
      const saveType = "amount";
      const productLabelDiscountOn = false;
      return `
        
          
             -  
            
          
          
            
              ${saveType == 'percentage'
                ? `-${variantData.off_ratio}% `
                : `- 
            
           
         
      `;
    }()}
   
 
              
              
            
        
          
          
              
              
              
                
                  
  
  
    
    Expedited Shipping: 3-7 days delivery (USA)
  
  
                  
  
  
    
    Carbon cycle
  
  
                 
              
            
        
          
          
              
              
   
  
  
  
  
  
  
    
    
    
    
  
    
    
    
    
  
  
    
      
      
      
        
      
      
      
        
        
      
      
        
          
            Color:  
            
              
                Black 
                
                  ${function(){
                    const optName = "Color";
                    const optionValue = data.originData.selectData ? data.originData.selectData[optName].value : data.originData.value;
                    const optionValueText = optionValue ? (optionValue) : '';
                    return `${optionValueText} `;
                  }()}
                 
               
            
           
          
         
      
      
        
          ${function(){
            const tipText = "Please select a {{ name }}".replace(/\{\{\s+name\s+\}\}/g, data);
            return `${tipText}
`
          }()}
         
       
    
      
      
      
        
      
      
      
      
        
          
            Size:  
            
              
                S 
                
                  ${function(){
                    const optName = "Size";
                    const optionValue = data.originData.selectData ? data.originData.selectData[optName].value : data.originData.value;
                    const optionValueText = optionValue ? (optionValue) : '';
                    return `${optionValueText} `;
                  }()}
                 
               
            
           
          
         
      
      
        
          ${function(){
            const tipText = "Please select a {{ name }}".replace(/\{\{\s+name\s+\}\}/g, data);
            return `${tipText}
`
          }()}
         
       
    
   
            
        
          
          
              
            
        
          
          
              
  
  
    
      
    
  
  
    
      
        Add to cart 
        
          
            
              $24.99 
            
           
          
  ${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":"2a8b22f4-58a6-4dce-b93c-a4ebc6ba85db","product_id":"cb343b56-d925-4e49-a831-e3d30d0791bb","title":"Black-S","weight_unit":"kg","inventory_quantity":999,"sku":"1968871419815800833","barcode":"","position":1,"option1":"Black","option2":"S","option3":"","note":"","image":{"src":"\/\/img.staticdj.com\/be7c6d75c3d0c6bcab2176ca4930a10e.png","path":"be7c6d75c3d0c6bcab2176ca4930a10e.png","width":1024,"height":1024,"alt":"95d45594dbf1aa4e4d5ed5f61678fc91","aspect_ratio":1},"wholesale_price":[{"price":24.99,"min_quantity":1}],"weight":"300","compare_at_price":"44","price":"24.99","retail_price":"44","available":true,"url":"\/products\/mens-black-and-brown-ribbed-crew-neck-sweatshirt?variant=2a8b22f4-58a6-4dce-b93c-a4ebc6ba85db","available_quantity":999999999,"options":[{"name":"Color","value":"Black"},{"name":"Size","value":"S"}],"off_ratio":43,"flashsale_info":[],"sales":2};
    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}","expoion")}
    
    
      
    
      
   
 
           
         
       
      
  
    
  
     
  
    
       
   
 
    
      To display this card to customers, you need to go to "Booster & Store Conversion" to turn on the trust enhancement feature.
     
   
  
    
    
    
    
  
 
     
   
 
              
          
        
          
          
              
  
    
      
      
      
      
    
  
  
    ${function(){
      const variantData = data.variant || {"id":"2a8b22f4-58a6-4dce-b93c-a4ebc6ba85db","product_id":"cb343b56-d925-4e49-a831-e3d30d0791bb","title":"Black-S","weight_unit":"kg","inventory_quantity":999,"sku":"1968871419815800833","barcode":"","position":1,"option1":"Black","option2":"S","option3":"","note":"","image":{"src":"\/\/img.staticdj.com\/be7c6d75c3d0c6bcab2176ca4930a10e.png","path":"be7c6d75c3d0c6bcab2176ca4930a10e.png","width":1024,"height":1024,"alt":"95d45594dbf1aa4e4d5ed5f61678fc91","aspect_ratio":1},"wholesale_price":[{"price":24.99,"min_quantity":1}],"weight":"300","compare_at_price":"44","price":"24.99","retail_price":"44","available":true,"url":"\/products\/mens-black-and-brown-ribbed-crew-neck-sweatshirt?variant=2a8b22f4-58a6-4dce-b93c-a4ebc6ba85db","available_quantity":999999999,"options":[{"name":"Color","value":"Black"},{"name":"Size","value":"S"}],"off_ratio":43,"flashsale_info":[],"sales":2};
      return `
        
          
          
          
          
          
        
      `
    }()}
   
 
            
        
          
          
              
  
    
    
    
      
  
    
      ${function() {
        const postageFreeAmount = 89;
        const custom_text = "Buy {amount} more to enjoy FREE Shipping";
        const totalPrice = +data.total_price;
        const diffPrice = postageFreeAmount - totalPrice;
        const percentDiff = (diffPrice > 0 ? (totalPrice / postageFreeAmount * 100) : 100) + '%';
        let tipText = "Your order is free delivery";
        if (diffPrice > 0) {
          tipText = custom_text.replace('{amount}', `
`);
        }
        return `
          
        `;
      }()}
    
 
 
    
   
            
        
          
          
              
  
    
      
          
          
        
      
        
      
    
      
          
          
        
      
        
          
              Up to 5-8 days delivery (USA)
         
      
    
      
          
          
        
      
        
      
    
      
          
          
      
      
        
          
              Premium Cotton Twin Needle Stitching