Ladies' V-neck Patchwork Top+ Pants Casual Suit

$59.00
const TAG = "spz-custom-product-automatic"; class SpzCustomProductAutomatic extends SPZ.BaseElement { constructor(element) { super(element); this.variant_id = 'd2611b07-863f-48ef-b7a8-e4bb751f9d22'; 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 = '4a0259ca-96df-49c8-9c7c-3fef55412acc'; 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 == '4a0259ca-96df-49c8-9c7c-3fef55412acc' && 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 = '4a0259ca-96df-49c8-9c7c-3fef55412acc'; 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);
Size:  S(US 6-8/UK 10-12/EU 38-40)
Quantity

Description

Embrace Sweet Elegance: Pink Peplum Top & Wide - Leg Pants Co - ord Set

Step into a world of delicate charm with this pink peplum top and wide - leg pants co - ord set—a seamless blend of feminine design, breezy comfort, and versatile style for the modern romantic.

Darling Peplum & V - Neck Design

This set features a sleeveless, V - neck peplum top that exudes sweetness. The peplum hem adds a flirty, feminine flair, while the V - neckline creates a flattering, elongating effect. The single button detail at the neckline brings a touch of vintage - inspired charm.

Flattering Wide - Leg Silhouette

The wide - leg pants complement the peplum top perfectly, creating a balanced, elegant silhouette. The relaxed fit skims your legs, ensuring comfort and ease of movement. Together, the top and pants create a look that’s both polished and playful.

Soft & Breathable Fabric

Crafted from a soft, breathable fabric, this co - ord set is ideal for warm days or casual outings. The material has a light, airy feel, keeping you cool and comfortable. It drapes beautifully, enhancing the set’s feminine design and ensuring a polished appearance.

Versatile Styling Options

This pink co - ord set is a styling gem. Pair it with neutral slides and a brown leather bag (like the chic choice in the pic!) for a laid - back, brunch - ready look—perfect for a weekend getaway or a daytime event. Dress it up with strappy heels and statement earrings for a more elevated vibe at a garden party or a baby shower. It adapts to your style, making it a versatile addition to your wardrobe.

Effortless Care & Durability

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

A Wardrobe Essential for Romantics

This co - ord set isn’t just clothing; it’s a celebration of femininity. Whether you’re a hopeless romantic, a fan of pink hues, or simply someone who loves comfortable, stylish basics, this set delivers. It’s perfect for creating looks that capture the essence of sweet elegance.

Confidence in Every Stitch

Slip into this set, and you’ll instantly feel a surge of confidence. Its feminine design and comfortable fit empower you to embrace your romantic side and shine in any setting. Whether you’re a seasoned pink lover or new to co - ord sets, this piece helps you feel beautiful and at ease.
 
Ready to add a touch of sweet elegance to your wardrobe? Add this pink peplum top and wide - leg pants co - ord set to your cart today. Embrace the blend of femininity, comfort, and versatility—your next brunch (and your closet) will thank you.
 
Don’t wait—click “Add to Cart” now and step into a world where romance meets effortless style. This set is your ticket to looking and feeling unforgettable, no matter the occasion.

 

 

Tops size:
SizeLengthBust
CMinchCMinch
XS6023.69035.4
S6124.09437.0
M6224.49939.0
L6324.810440.9
XL6425.210942.9
2XL6525.611444.9
3XL6626.011946.9

 

Pants Size:

SizeWaistHipsLength
CMinchCMinchCMinch
XS6425.29035.410541.3
S6525.69437.010641.7
M6626.09939.010742.1
L6726.410440.910842.5
XL6826.810942.910942.9
2XL6927.211444.911043.3
3XL7027.611946.911143.7

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