Beige Drawstring Waist Utility Jacket
Beige Drawstring Waist Utility Jacket
${function() {
const variantData = data.variant || {"id":"30c1a720-1dc7-4b51-b4fe-61e60230cb09","product_id":"c6462b24-b162-47f1-9bda-3e27b724af93","title":"khaki-XS(US 4)","weight_unit":"kg","inventory_quantity":1000,"sku":"DJHH26042703-khaki-XS(US 4)-A00210941","barcode":"","position":1,"option1":"khaki","option2":"XS(US 4)","option3":"","note":"","image":{"src":"\/\/imgpro.staticdj.com\/4f57e8f3494f07b43fb295c4553552c0.jpg","path":"4f57e8f3494f07b43fb295c4553552c0.jpg","width":720,"height":1280,"alt":"","aspect_ratio":0.5625},"wholesale_price":[{"price":19.99,"min_quantity":1}],"weight":"0","compare_at_price":"49.99","price":"19.99","retail_price":"49.99","available":true,"url":"\/products\/beige-drawstring-waist-utility-jacket?variant=30c1a720-1dc7-4b51-b4fe-61e60230cb09","available_quantity":999999999,"options":[{"name":"Color","value":"khaki"},{"name":"Size","value":"XS(US 4)"}],"off_ratio":"60","flashsale_info":{"variant_id":"30c1a720-1dc7-4b51-b4fe-61e60230cb09","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":"19.99","compare_at_price":"","discount_price":"19.99","customary_saved_price":"","customary_off_ratio":"","discount_saved_price":"","discount_off_ratio":"60","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: | DJHH26042703 |
| 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 | 55 | 22.0 | 100 | 40.0 | 65 | 60.0 |
| S | 56 | 22.0 | 104 | 40.9 | 66 | 26.0 |
| M | 57 | 22.4 | 108 | 42.5 | 67 | 26.4 |
| L | 58 | 22.8 | 112 | 44.1 | 68 | 26.8 |
| XL | 59 | 23.2 | 116 | 45.7 | 69 | 27.2 |
| 2XL | 60 | 23.6 | 120 | 47.2 | 70 | 27.6 |
| 3XL | 61 | 24.0 | 124 | 48.8 | 71 | 28.0 |
*This data was obtained from manually measuring the product, it may be off by 1-2 CM.
Main Features:
Material: Sturdy yet lightweight cotton-blend twill fabric, durable and structured, comfortable for everyday wear
Design: Stand collar, gold button details, front zip closure, cinched drawstring waist, roll-up sleeves with button tabs, utility-inspired casual-chic style
Version: Cropped relaxed fit, the drawstring waist adds definition while the oversized sleeves keep it casual
Occasion: Daily casual wear, transitional season styling, street fashion, weekend outings, everyday versatile layering
Care Instruction: Cold water gentle machine wash, tumble dry low, no bleach, cool iron on reverse if needed
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.