White Lace Button-Front Midi Dress
White Lace Button-Front Midi Dress
${function() {
const variantData = data.variant || {"id":"1d92569c-b1cf-48f8-9182-075458cde13d","product_id":"b0132e18-e405-484d-a358-e1e2b758cd93","title":"white-XS(US 4)","weight_unit":"kg","inventory_quantity":1000,"sku":"DJHH2604301920-white-XS(US 4)-A00213072","barcode":"","position":1,"option1":"white","option2":"XS(US 4)","option3":"","note":"","image":{"src":"\/\/imgpro.staticdj.com\/13b39bf1bbb0cc620c3dd00b8a4646e3.jpg","path":"13b39bf1bbb0cc620c3dd00b8a4646e3.jpg","width":720,"height":1280,"alt":"","aspect_ratio":0.5625},"wholesale_price":[{"price":22.99,"min_quantity":1}],"weight":"0.65","compare_at_price":"55.99","price":"22.99","retail_price":"55.99","available":true,"url":"\/products\/white-lace-button-front-midi-dress?variant=1d92569c-b1cf-48f8-9182-075458cde13d","available_quantity":999999999,"options":[{"name":"Color","value":"white"},{"name":"Size","value":"XS(US 4)"}],"off_ratio":"59","flashsale_info":{"variant_id":"1d92569c-b1cf-48f8-9182-075458cde13d","product_id":"","quantity":0,"discount_id":"","limit_time":0,"limit_buy":0,"user_limit_buy":0,"discount_sales":0,"discount_sales_rate":"","discount_stock":0,"ends_at":0,"starts_at":0,"allow_oversold":"","allocation_method":"","price":"22.99","compare_at_price":"","discount_price":"22.99","customary_saved_price":"","customary_off_ratio":"","discount_saved_price":"","discount_off_ratio":"59","use_before_price":false,"before_price":"","title":"","properties":"","color_setting_promotional_copy":"","discount_quantity":0,"is_need_split":false},"sales":0};
const saveType = null;
const productSaveLabel = null;
return `
-
${ variantData.off_ratio }%
`; }()}
${function() {
const minInventory = parseInt('7');
const maxInventory = parseInt('10');
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 `
`;
}()}
people are viewing this right now
${function(){
return `
Please select a Color
`;
}()}
Please select a Size
${function(){
return `
Please select a Size
`;
}()}
Product was out of stock.
Enjoy free shipping on every order, delivered to your doorstep no matter where you are in the world.
Shop with confidence with our hassle-free returns policy, ensuring you love what you buy.
Designed with the planet in mind, all our products are committed to sustainable practices.
Your payment information is always protected with our advanced, encrypted checkout security.
| SPU: |
DJHH26043020 |
| Season: |
Spring /Summer |
| Material: |
Blended |
| Style: |
Casual |
| Size: |
XS/S/M/L/XL/2XL/3XL |
| Size |
Length |
Bust |
Sleeve Length |
| CM |
inch |
CM |
inch |
CM |
inch |
| XS |
135 |
54.0 |
92 |
36.8 |
30 |
60.0 |
| S |
136 |
53.5 |
96 |
37.8 |
31 |
12.2 |
| M |
137 |
53.9 |
100 |
39.4 |
32 |
12.6 |
| L |
138 |
54.3 |
104 |
40.9 |
33 |
13.0 |
| XL |
139 |
54.7 |
108 |
42.5 |
34 |
13.4 |
| 2XL |
140 |
55.1 |
112 |
44.1 |
35 |
13.8 |
| 3XL |
141 |
55.5 |
116 |
45.7 |
36 |
14.2 |
*This data was obtained from manually measuring the product, it may be off by 1-2 CM.
Main Features:
- Material: Semi-sheer floral lace with a soft, airy drape
- Design: Mandarin collar, short puffed sleeves, full button placket, and ruffled tiered hem
- Fit: Relaxed, flowy fit with a loose silhouette that falls below the knee
- Occasion: Bridal showers, beach weddings, and casual summer events
- Care: Hand wash cold; hang to dry, avoid direct sunlight
Available Sizes: XS, S, M, L, XL, 2XL, 3XL (consistent with the size range you provided)
${function(){
const variantData = data.variant || null;
return `
` }()}
/** @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}","myestyle")}
To display this card to customers, you need to go to "Booster & Store Conversion" to turn on the trust enhancement feature.