Ladies' Collar Solid Color Loose Casual Dress

$49.00
const TAG = "spz-custom-product-automatic"; class SpzCustomProductAutomatic extends SPZ.BaseElement { constructor(element) { super(element); this.variant_id = '7f959536-beb8-44fd-a739-07d227e7b5d5'; this.isRTL = SPZ.win.document.dir === 'rtl'; this.isAddingToCart_ = false; // 加购中状态 } static deferredMount() { return false; } buildCallback() { this.action_ = SPZServices.actionServiceForDoc(this.element); this.templates_ = SPZServices.templatesForDoc(this.element); this.xhr_ = SPZServices.xhrFor(this.win); this.setupAction_(); this.viewport_ = this.getViewport(); } mountCallback() { this.init(); // 监听事件 this.bindEvent_(); } async init() { this.handleFitTheme(); const data = await this.getDiscountList(); this.renderApiData_(data); } async getDiscountList() { const productId = '7ff2c43f-d699-4abb-b08e-15e509c7b264'; const variantId = this.variant_id; const productType = 'default'; const reqBody = { product_id: productId, variant_id: variantId, discount_method: "DM_AUTOMATIC", customer: { customer_id: window.C_SETTINGS.customer.customer_id, email: window.C_SETTINGS.customer.customer_email }, product_type: productType } const url = `/api/storefront/promotion/display_setting/text/list`; const data = await this.xhr_.fetchJson(url, { method: "post", body: reqBody }).then(res => { return res; }).catch(err => { this.setContainerDisabled(false); }) return data; } async renderDiscountList() { this.setContainerDisabled(true); const data = await this.getDiscountList(); this.setContainerDisabled(false); // 重新渲染 抖动问题处理 this.renderApiData_(data); } clearDom() { const children = this.element.querySelector('*:not(template)'); children && SPZCore.Dom.removeElement(children); } async renderApiData_(data) { const parentDiv = document.querySelector('.automatic_discount_container'); const newTplDom = await this.getRenderTemplate(data); if (parentDiv) { parentDiv.innerHTML = ''; parentDiv.appendChild(newTplDom); } else { console.log('automatic_discount_container is null'); } } doRender_(data) { const renderData = data || {}; return this.templates_ .findAndRenderTemplate(this.element, renderData) .then((el) => { this.clearDom(); this.element.appendChild(el); }); } async getRenderTemplate(data) { const renderData = data || {}; return this.templates_ .findAndRenderTemplate(this.element, { ...renderData, isRTL: this.isRTL }) .then((el) => { this.clearDom(); return el; }); } setContainerDisabled(isDisable) { const automaticDiscountEl = document.querySelector('.automatic_discount_container_outer'); if(isDisable) { automaticDiscountEl.setAttribute('disabled', ''); } else { automaticDiscountEl.removeAttribute('disabled'); } } // 绑定事件 bindEvent_() { window.addEventListener('click', (e) => { let containerNodes = document.querySelectorAll(".automatic-container .panel"); let bool; Array.from(containerNodes).forEach((node) => { if(node.contains(e.target)){ bool = true; } }) // 是否popover面板点击范围 if (bool) { return; } if(e.target.classList.contains('drowdown-icon') || e.target.parentNode.classList.contains('drowdown-icon')){ return; } const nodes = document.querySelectorAll('.automatic-container'); Array.from(nodes).forEach((node) => { node.classList.remove('open-dropdown'); }) // 兼容主题 this.toggleProductSticky(true); }) // 监听变体变化 document.addEventListener('dj.variantChange', async(event) => { // 重新渲染 const variant = event.detail.selected; if (variant.product_id == '7ff2c43f-d699-4abb-b08e-15e509c7b264' && variant.id != this.variant_id) { this.variant_id = variant.id; this.renderDiscountList(); } }); } // 兼容主题 handleFitTheme() { // top 属性影响抖动 let productInfoEl = null; if (window.SHOPLAZZA.theme.merchant_theme_name === 'Wind' || window.SHOPLAZZA.theme.merchant_theme_name === 'Flash') { productInfoEl = document.querySelector('.product-info-body .product-sticky-container'); } else if (window.SHOPLAZZA.theme.merchant_theme_name === 'Hero') { productInfoEl = document.querySelector('.product__info-wrapper .properties-content'); } if(productInfoEl){ productInfoEl.classList.add('force-top-auto'); } } // 兼容 wind/flash /hero 主题 (sticky属性影响 popover 层级展示, 会被其他元素覆盖) toggleProductSticky(isSticky) { let productInfoEl = null; if (window.SHOPLAZZA.theme.merchant_theme_name === 'Wind' || window.SHOPLAZZA.theme.merchant_theme_name === 'Flash') { productInfoEl = document.querySelector('.product-info-body .product-sticky-container'); } else if (window.SHOPLAZZA.theme.merchant_theme_name === 'Hero') { productInfoEl = document.querySelector('.product__info-wrapper .properties-content'); } if(productInfoEl){ if(isSticky) { // 还原该主题原有的sticky属性值 productInfoEl.classList.remove('force-position-static'); return; } productInfoEl.classList.toggle('force-position-static'); } } setupAction_() { this.registerAction('handleDropdown', (invocation) => { const discount_id = invocation.args.discount_id; const nodes = document.querySelectorAll('.automatic-container'); Array.from(nodes).forEach((node) => { if(node.getAttribute('id') != `automatic-${discount_id}`) { node.classList.remove('open-dropdown'); } }) const $discount_item = document.querySelector(`#automatic-${discount_id}`); $discount_item && $discount_item.classList.toggle('open-dropdown'); // 兼容主题 this.toggleProductSticky(); }); // 加购事件 this.registerAction('handleAddToCart', (invocation) => { // 阻止事件冒泡 const event = invocation.event; if (event) { event.stopPropagation(); event.preventDefault(); } // 如果正在加购中,直接返回 if (this.isAddingToCart_) { return; } const quantity = invocation.args.quantity || 1; this.addToCart(quantity); }); } // 加购方法 async addToCart(quantity) { // 设置加购中状态 this.isAddingToCart_ = true; const productId = '7ff2c43f-d699-4abb-b08e-15e509c7b264'; const variantId = this.variant_id; const url = '/api/cart'; const reqBody = { product_id: productId, variant_id: variantId, quantity: quantity }; try { const data = await this.xhr_.fetchJson(url, { method: 'POST', body: reqBody }); // 触发加购成功提示 this.triggerAddToCartToast_(); return data; } catch (error) { error.then(err=>{ this.showToast_(err?.message || err?.errors?.[0] || 'Unknown error'); }) } finally { // 无论成功失败,都重置加购状态 this.isAddingToCart_ = false; } } showToast_(message) { const toastEl = document.querySelector("#apps-match-drawer-add_to_cart_toast"); if (toastEl) { SPZ.whenApiDefined(toastEl).then((apis) => { apis.showToast(message); }); } } // 触发加购成功提示 triggerAddToCartToast_() { // 如果主题有自己的加购提示,则不显示 const themeAddToCartToastEl = document.querySelector('#add-cart-event-proxy'); if (themeAddToCartToastEl) return; // 显示应用的加购成功提示 this.showToast_("Added successfully"); } triggerEvent_(name, data) { const event = SPZUtils.Event.create(this.win, `${ TAG }.${ name }`, data || {}); this.action_.trigger(this.element, name, event); } isLayoutSupported(layout) { return layout == SPZCore.Layout.CONTAINER; } } SPZ.defineElement(TAG, SpzCustomProductAutomatic);
class SpzCustomDiscountBundle extends SPZ.BaseElement { constructor(element) { super(element); } isLayoutSupported(layout) { return layout == SPZCore.Layout.LOGIC; } mountCallback() {} unmountCallback() {} setupAction_() { this.registerAction('showAddToCartToast', () => { const themeAddToCartToastEl = document.querySelector('#add-cart-event-proxy') if(themeAddToCartToastEl) return const toastEl = document.querySelector('#apps-match-drawer-add_to_cart_toast') SPZ.whenApiDefined(toastEl).then((apis) => { apis.showToast("Added successfully"); }); }); } buildCallback() { this.setupAction_(); }; } SPZ.defineElement('spz-custom-discount-toast', SpzCustomDiscountBundle);
Color:  dark blue
Size:  S(US 6-8/UK 10-12/EU 38-40)
Quantity

Description

Embrace Timeless Urban Chic: Black Shirt Dress

Step into a world of understated sophistication with this black shirt dress—a seamless blend of minimalist design, versatile style, and effortless elegance for the modern city dweller.

Classic Shirt Dress Silhouette

This dress features a timeless shirt dress design, complete with a collared neckline, half - button placket, and a relaxed, A - line silhouette. The 3/4 sleeves add a touch of polish, while the knee - length cut keeps it practical for everyday wear. It’s a style that transcends trends, perfect for those who appreciate enduring fashion.

Flattering A - Line Fit

The A - line fit skims your body, creating a flattering shape that suits all figures. It offers comfort and freedom of movement, making it ideal for busy urban days. Whether you’re rushing to meetings or strolling through the city, this dress ensures you look effortlessly put - together.

Crisp & Breathable Fabric

Crafted from a crisp, breathable fabric, this dress feels as good as it looks. The material holds its shape, giving the dress a structured appearance, while allowing air to circulate, keeping you cool. It’s perfect for transitioning from day to night, adapting to any weather.

Versatile Styling Options

This black shirt dress is a styling chameleon. Pair it with nude pumps and a woven clutch (like the chic combo in the pic!) for a polished, office - ready look—ideal for workdays or business lunches. Dress it down with white sneakers and a denim jacket for a casual, weekend - friendly vibe. Add a belt to cinch the waist for a more defined silhouette, or leave it loose for relaxed elegance. It adapts to your style, making it a versatile addition to your wardrobe.

Effortless Care & Durability

Don’t let the dress’s crisp appearance fool you—it’s designed for easy care. Machine washable (gentle cycle recommended), it retains its shape, color, and structure wash after wash. The fabric resists wrinkling, ensuring you always look sharp, no matter how busy your day gets.

A Wardrobe Essential for the Urbanite

This dress isn’t just clothing; it’s a city - ready staple. Whether you’re a busy professional, a fashion - forward urbanite, or simply someone who loves minimalist, versatile fashion, this dress delivers. It’s perfect for creating looks that blend functionality and style, no matter your schedule.

Confidence in Every Stitch

Slip into this dress, and you’ll instantly feel a surge of confidence. Its timeless design and comfortable fit empower you to navigate the city with poise. Whether you’re a seasoned city dweller or new to urban fashion, this dress helps you stand out with understated elegance.
 
Ready to elevate your urban wardrobe? Add this black shirt dress to your cart today. Embrace the blend of sophistication, comfort, and versatility—your daily commute (and your closet) will thank you.
 
Don’t wait—click “Add to Cart” now and step into a world where timeless style meets urban practicality. This dress is your ticket to looking and feeling unforgettable, no matter the occasion.

 

 

Dress size:
SizeLengthBustSleeve Length
CMinchCMinchCMinch
XS9738.29035.43513.8
S9838.69437.03614.2
M9939.09939.03714.6
L10039.410440.93815.0
XL10139.810942.93915.4
2XL10240.211444.94015.7
3XL10340.611946.94116.1

*This data was obtained from manually measuring the product, it may be off by 1-2 CM.