(30*30cm)DIY Stained Glass Dragonfly Diamond Painting Stickers
(30*30cm)DIY Stained Glass Dragonfly Diamond Painting Stickers
(30*30cm)DIY Stained Glass Dragonfly Diamond Painting Stickers
(30*30cm)DIY Stained Glass Dragonfly Diamond Painting Stickers
(30*30cm)DIY Stained Glass Dragonfly Diamond Painting Stickers
(30*30cm)DIY Stained Glass Dragonfly Diamond Painting Stickers
(30*30cm)DIY Stained Glass Dragonfly Diamond Painting Stickers
(30*30cm)DIY Stained Glass Dragonfly Diamond Painting Stickers
(30*30cm)DIY Stained Glass Dragonfly Diamond Painting Stickers
1 / 9
(30*30cm)DIY Stained Glass Dragonfly Diamond Painting Stickers
(30*30cm)DIY Stained Glass Dragonfly Diamond Painting Stickers
(30*30cm)DIY Stained Glass Dragonfly Diamond Painting Stickers
(30*30cm)DIY Stained Glass Dragonfly Diamond Painting Stickers
(30*30cm)DIY Stained Glass Dragonfly Diamond Painting Stickers
(30*30cm)DIY Stained Glass Dragonfly Diamond Painting Stickers
(30*30cm)DIY Stained Glass Dragonfly Diamond Painting Stickers
(30*30cm)DIY Stained Glass Dragonfly Diamond Painting Stickers
(30*30cm)DIY Stained Glass Dragonfly Diamond Painting Stickers
0% OFF

(30*30cm)DIY Stained Glass Dragonfly Diamond Painting Stickers

999048.05

$7.99
1 sold
Qty 3 in stock
Specification:
Origin: Mainland China
Use: Paintings
Pasting Area: Partial
Product size: 30x30cm/11.81x11.81in

Sticker DIY diamond painting production steps.
1.Open the bag and check the diamond painting special tools
2.Check the resin diamond colour, arrange the order of coding
3. As shown in the picture, uncover the tape above the painting, you will see a large number of symbols corresponding to the colour code
4. As shown in the picture, according to the corresponding line of the colour of the corresponding resin inlay diamonds
5. Suggest a set of resin diamonds for faster completion
6. In order to create a perfect diamond painting, the drawings are put together and the diamonds are pasted line by line.
7. As shown in the picture, install the materials in order to the top

Note:
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-2cm measuring deviation due to manual measurement.



1 set x Sticker
1 set x Dotting Toolkit


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