12 Months Flower Cross Stitch Printed Canvas DIY Needlework Set  July H429
12 Months Flower Cross Stitch Printed Canvas DIY Needlework Set  July H429
12 Months Flower Cross Stitch Printed Canvas DIY Needlework Set  July H429
12 Months Flower Cross Stitch Printed Canvas DIY Needlework Set  July H429
12 Months Flower Cross Stitch Printed Canvas DIY Needlework Set  July H429
12 Months Flower Cross Stitch Printed Canvas DIY Needlework Set  July H429
1 / 6
12 Months Flower Cross Stitch Printed Canvas DIY Needlework Set  July H429
12 Months Flower Cross Stitch Printed Canvas DIY Needlework Set  July H429
12 Months Flower Cross Stitch Printed Canvas DIY Needlework Set  July H429
12 Months Flower Cross Stitch Printed Canvas DIY Needlework Set  July H429
12 Months Flower Cross Stitch Printed Canvas DIY Needlework Set  July H429
12 Months Flower Cross Stitch Printed Canvas DIY Needlework Set  July H429
0% OFF
SO

12 Months Flower Cross Stitch Printed Canvas DIY Needlework Set July H429

429001.02

$4.99
3 sold
Qty 24 in stock
12 Months Flower Cross Stitch Embroidery 14CT Stamped Cotton Thread Painting DIY Needlework Kits Printed Canvas Handmade Crafts Home Decoration 17x17cm
Feature:
1. A guide graphic composed of different numbers and symbols, tells you where to draw the grid and which color line should be used. All you have to do is follow the symbols on the paper. Learn how to get started.
2. The natural ecological cotton used is soft, colorful and durable, making your Cross Stitch silky, vivid and long lasting.
3. The cross-stitched artwork will bring you a pleasant time and a sense of accomplishment when completing. It can be used as a home decoration, or as a unique, meaningful and irreplaceable gift for your loved ones.

Specification:
Material: cotton
Canvas size: as shown
White edge size: 4cm/1.57in
Cross stitch cloth type: 14CT 2 strands (canvas with printing)
Pattern: July H429

Note:
The product does not contain frame.
Due to the different monitor and light effect, the actual color of the item might be slightly different from the color showed on the pictures. Thank you!
Please allow 1-3mm measuring deviation due to manual measurement.

Package Content:
1 x Embroidered Cloth
2 x Embroidery Needles
1 x Embroidery Thread Set
1 x Manual
/** @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-1736477762476').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);