Crew Neck Knitted Comfort Top
Crew Neck Knitted Comfort Top
Crew Neck Knitted Comfort Top
Crew Neck Knitted Comfort Top
Crew Neck Knitted Comfort Top
Crew Neck Knitted Comfort Top
Crew Neck Knitted Comfort Top
Crew Neck Knitted Comfort Top
Crew Neck Knitted Comfort Top
Crew Neck Knitted Comfort Top
Crew Neck Knitted Comfort Top
Crew Neck Knitted Comfort Top
Crew Neck Knitted Comfort Top
Crew Neck Knitted Comfort Top
Crew Neck Knitted Comfort Top
Crew Neck Knitted Comfort Top
Crew Neck Knitted Comfort Top
Crew Neck Knitted Comfort Top

Crew Neck Knitted Comfort Top

Price

$30.99 $18.99
Save $12.00

color

Please select a color

size

Please select a size

Quantity

/** @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);
Sustainably made

SPU: YSHHP240069
Style: leisure
Color: apricot, rose red, green,blue
Season: spring / summer
Neckline: round neck
Sleeve Length: middle sleeves
Material: cotton
Size: S/M/L/XL/2XL/3XL/4XL/5XL

Size Chart Length Sleeve Length Bust
CM inch CM inch CM inch
S 68 26.8  33 13.2  98 38.6 
M 69 27.2  34 13.6  103 40.6 
L 70 27.6  35 13.8  108 42.5 
XL 71 28.0  36 14.2  113 44.5 
2XL 72 28.3  37 14.6  118 46.5 
3XL 73 28.7  38 15.0  123 48.4 
4XL 74 29.1  39 15.4  128 50.4 
5XL 75 29.5  40 15.7  133 52.4 

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