6pcs DIY Mandala Diamond Painting Coaster
6pcs DIY Mandala Diamond Painting Coaster
6pcs DIY Mandala Diamond Painting Coaster
6pcs DIY Mandala Diamond Painting Coaster
6pcs DIY Mandala Diamond Painting Coaster
6pcs DIY Mandala Diamond Painting Coaster
6pcs DIY Mandala Diamond Painting Coaster
6pcs DIY Mandala Diamond Painting Coaster
1 / 8
6pcs DIY Mandala Diamond Painting Coaster
6pcs DIY Mandala Diamond Painting Coaster
6pcs DIY Mandala Diamond Painting Coaster
6pcs DIY Mandala Diamond Painting Coaster
6pcs DIY Mandala Diamond Painting Coaster
6pcs DIY Mandala Diamond Painting Coaster
6pcs DIY Mandala Diamond Painting Coaster
6pcs DIY Mandala Diamond Painting Coaster
0% OFF

6pcs DIY Mandala Diamond Painting Coaster

809271.02

$12.99
2 sold
Qty 3 in stock

Specification:
Name: DIY diamond coaster
Use: Tablemat
Style: Modern
Pattern Type: Animal
Form: Flat
Pasting Area: Full
Set Type: Yes
Material: wood
Size: 10*10*0.5cm/3.94*3.94*0.2''

DIY diamond painting product production steps:
1. Open the package and check whether the tools for diamond painting are complete;
2. According to the resin diamond color code, choose a color on the plate, if the same color is pasted at one time, the speed can be increased;
3. Find the corresponding color code on the product and start pasting until it is finished;
4. After the completion, in order to make the diamond painting stable, you can take some books and put them on the diamond for a while;
5. Finally finished, enjoy decorating your home and adding life to your home.
 
Precautions for DIY Diamond Painting:
1. Refer to previous steps
2. If you don't know what color to use, please refer to the color table

Note:
This is a DIY product. It's not finished. You need to finish it yourself.
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.

Package Content:
1 Set * Coaster
1 Set * Drill Bag + Stick Drill Tool
1 * Shelf

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