Letters Waterfall Short Sleeve Shirt
Letters Waterfall Short Sleeve Shirt
Letters Waterfall Short Sleeve Shirt
Letters Waterfall Short Sleeve Shirt
Letters Waterfall Short Sleeve Shirt
Letters Waterfall Short Sleeve Shirt
Letters Waterfall Short Sleeve Shirt
Letters Waterfall Short Sleeve Shirt
1/4
Letters Waterfall Short Sleeve Shirt
Letters Waterfall Short Sleeve Shirt
Letters Waterfall Short Sleeve Shirt
Letters Waterfall Short Sleeve Shirt
1/4

Letters Waterfall Short Sleeve Shirt

$28.89
$40.00
ColorBlack
Please select a color
Size
Please select a size
Quantity
Barcode:
  • Style : Street , Casual , Vintage
  • Occasion : Street , Public , Vacation
  • Season : Spring , Autumn , Summer
  • Color : Blue , Black

Size Chart

cm
SizeSMLXL2XL3XL4XL
Shoulder464748.55051.55354.5
Bust104112120128136144152
Length72747678808284
Sleeve Length22.52323.52424.52525.5
inch
Size inchSMLXL2XL3XL4XL
Shoulder18.118.519.119.720.320.921.5
Bust40.944.147.250.453.556.759.8
Length28.329.129.930.731.532.333.1
Sleeve Length8.99.19.39.49.69.810.0
class SpzCustomDiscountFlashsale extends SPZ.BaseElement { constructor(element) { super(element); this.xhr_ = SPZServices.xhrFor(this.win); this.getFlashSaleApi = "\/api\/storefront\/promotion\/flashsale\/display_setting\/product_setting"; this.timer = null; this.variantId = "6babf5a6-9a56-4376-b113-ff3730632484"; // 促销活动数据 this.flashsaleData = {} } isLayoutSupported(layout) { return layout == SPZCore.Layout.CONTAINER; } buildCallback() { this.templates_ = SPZServices.templatesForDoc(); this.viewport_ = this.getViewport(); // 挂载bind函数 解决this指向问题 this.render = this.render.bind(this); this.resize = this.resize.bind(this); this.switchVariant = this.switchVariant.bind(this); } mountCallback() { // 获取数据 this.getData(); this.element.onclick = (e) => { const cur = this.win.document.querySelector(".app_discount_flashsale_desc"); if (this.flashsaleData.product_setting.is_redirection && appDiscountUtils.inProductBody(this.element) && e.target !== cur) { this.win.open(`/promotions/discount-default/${this.flashsaleData.discount_info.id}`); } } // 绑定 this.viewport_.onResize(this.resize); // 监听子款式切换,重新渲染 this.win.document.addEventListener('dj.variantChange', this.switchVariant); } unmountCallback() { // 解绑 this.viewport_.removeResize(this.resize); this.win.document.removeEventListener('dj.variantChange', this.switchVariant); // 清除定时器 if (this.timer) { clearTimeout(this.timer); this.timer = null; } } resize() { if (this.timer) { clearTimeout(this.timer) this.timer = null; } this.timer = setTimeout(() => { this.render(); }, 200) } switchVariant(event) { const variant = event.detail.selected; if (variant.product_id == '1f2e22ec-18e0-489e-a80b-2248ef889e65' && variant.id != this.variantId) { this.variantId = variant.id; this.getData(); } } getData() { const reqBody = { product_id: "1f2e22ec-18e0-489e-a80b-2248ef889e65", product_type: "", variant_id: this.variantId } this.flashsaleData = {}; this.win.fetch(this.getFlashSaleApi, { method: "POST", body: JSON.stringify(reqBody), headers: { "Content-Type": "application/json" } }).then(async (response) => { if (response.ok) { this.flashsaleData = await response.json(); this.render(); } else { this.clearDom(); } }).catch(err => { this.clearDom(); }); } clearDom() { const children = this.element.querySelector('*:not(template)'); children && SPZCore.Dom.removeElement(children); } render() { this.templates_ .findAndRenderTemplate(this.element, { isMobile: appDiscountUtils.judgeMobile(), isRTL: appDiscountUtils.judgeRTL(), inProductDetail: appDiscountUtils.inProductBody(this.element), flashsaleData: this.flashsaleData, image_domain: this.win.SHOPLAZZA.image_domain, }) .then((el) => { this.clearDom(); this.element.appendChild(el); }) } } SPZ.defineElement('spz-custom-discount-flashsale', SpzCustomDiscountFlashsale);