DIY Spot Drill Garland 5D Crystal Diamond Painting Art Wreath Gift (DZ630)
DIY Spot Drill Garland 5D Crystal Diamond Painting Art Wreath Gift (DZ630)
DIY Spot Drill Garland 5D Crystal Diamond Painting Art Wreath Gift (DZ630)
DIY Spot Drill Garland 5D Crystal Diamond Painting Art Wreath Gift (DZ630)
DIY Spot Drill Garland 5D Crystal Diamond Painting Art Wreath Gift (DZ630)
DIY Spot Drill Garland 5D Crystal Diamond Painting Art Wreath Gift (DZ630)
DIY Spot Drill Garland 5D Crystal Diamond Painting Art Wreath Gift (DZ630)
DIY Spot Drill Garland 5D Crystal Diamond Painting Art Wreath Gift (DZ630)
DIY Spot Drill Garland 5D Crystal Diamond Painting Art Wreath Gift (DZ630)
DIY Spot Drill Garland 5D Crystal Diamond Painting Art Wreath Gift (DZ630)
DIY Spot Drill Garland 5D Crystal Diamond Painting Art Wreath Gift (DZ630)
DIY Spot Drill Garland 5D Crystal Diamond Painting Art Wreath Gift (DZ630)
DIY Spot Drill Garland 5D Crystal Diamond Painting Art Wreath Gift (DZ630)
DIY Spot Drill Garland 5D Crystal Diamond Painting Art Wreath Gift (DZ630)
DIY Spot Drill Garland 5D Crystal Diamond Painting Art Wreath Gift (DZ630)
DIY Spot Drill Garland 5D Crystal Diamond Painting Art Wreath Gift (DZ630)
DIY Spot Drill Garland 5D Crystal Diamond Painting Art Wreath Gift (DZ630)
DIY Spot Drill Garland 5D Crystal Diamond Painting Art Wreath Gift (DZ630)

DIY Spot Drill Garland 5D Crystal Diamond Painting Art Wreath Gift (DZ630)

SKU: 559653.04
Price
$16.65
$9.99
Save  40%
1 sold
Quantity
const TAG = "spz-custom-product-automatic"; class SpzCustomProductAutomatic extends SPZ.BaseElement { constructor(element) { super(element); this.variant_id = 'b1b54d76-4350-46a7-88e8-70d76912a609'; } static deferredMount() { return false; } buildCallback() { this.action_ = SPZServices.actionServiceForDoc(this.element); this.templates_ = SPZServices.templatesForDoc(this.element); this.xhr_ = SPZServices.xhrFor(this.win); this.setupAction_(); this.viewport_ = this.getViewport(); } mountCallback() { console.log('自动折扣直出数据',{"downgrade":false,"automatic_discount_list":[],"hash":""}); this.init(); // 监听事件 this.bindEvent_(); } async init() { this.handleFitTheme(); const promotionComplex = {"downgrade":false,"automatic_discount_list":[],"hash":""}; let data = await this.getDiscountList(); if (data.hash && (data.hash !== promotionComplex.hash)) { // 兜底方案, downgrade == true; 需要降级 则要请求接口, // 但是直出数据可能存在缓存,一定会调用一次接口,直接判断hash版本,不一致就用接口的,一致就没必要重新渲染一模一样的数据了 console.log('%c 自动折扣hash不一致, 使用接口数据 ', 'background:#ffe3f4;border: 1px solid #ff4395; color: #ff4395;', data.hash); this.renderApiData_(data); } } async getDiscountList() { const productId = 'cbda45fa-4895-483d-a42f-3c8c114d9c67'; const variantId = this.variant_id; const productType = ''; const reqBody = { product_id: productId, variant_id: variantId, discount_method: "DM_AUTOMATIC", customer: { customer_id: window.C_SETTINGS.customer.customer_id, email: window.C_SETTINGS.customer.customer_email }, product_type: productType } const url = `/api/storefront/promotion/display_setting/text/list`; const data = await this.xhr_.fetchJson(url, { method: "post", body: reqBody }).then(res => { return res; }).catch(err => { this.setContainerDisabled(false); }) return data; } async renderApiData_(data) { const parentDiv = document.querySelector('.automatic_discount_container'); const newTplDom = await this.getRenderTemplate(data); if(parentDiv){ parentDiv.innerHTML = ''; parentDiv.appendChild(newTplDom); } } async renderDiscountList() { this.setContainerDisabled(true); const data = await this.getDiscountList(); this.setContainerDisabled(false); // 重新渲染 抖动问题处理 this.renderApiData_(data); } clearDom() { const children = this.element.querySelector('*:not(template)'); children && SPZCore.Dom.removeElement(children); } doRender_(data) { const renderData = data || {}; return this.templates_ .findAndRenderTemplate(this.element, renderData) .then((el) => { this.clearDom(); this.element.appendChild(el); }); } async getRenderTemplate(data) { const renderData = data || {}; return this.templates_ .findAndRenderTemplate(this.element, renderData) .then((el) => { this.clearDom(); return el; }); } setContainerDisabled(isDisable) { const automaticDiscountEl = document.querySelector('.automatic_discount_container'); if(isDisable) { automaticDiscountEl.setAttribute('disabled', ''); } else { automaticDiscountEl.removeAttribute('disabled'); } } // 绑定事件 bindEvent_() { window.addEventListener('click', (e) => { let containerNodes = document.querySelectorAll(".automatic-container .panel"); let bool; Array.from(containerNodes).forEach((node) => { if(node.contains(e.target)){ bool = true; } }) // 是否popover面板点击范围 if (bool) { return; } if(e.target.classList.contains('drowdown-icon') || e.target.parentNode.classList.contains('drowdown-icon')){ return; } const nodes = document.querySelectorAll('.automatic-container'); Array.from(nodes).forEach((node) => { node.classList.remove('open-dropdown'); }) // 兼容主题 this.toggleProductSticky(true); }) // 监听变体变化 document.addEventListener('dj.variantChange', async(event) => { // 重新渲染 const variant = event.detail.selected; if (variant.product_id == 'cbda45fa-4895-483d-a42f-3c8c114d9c67' && variant.id != this.variant_id) { this.variant_id = variant.id; this.renderDiscountList(); } }); } // 兼容主题 handleFitTheme() { // top 属性影响抖动 let productInfoEl = null; if (window.SHOPLAZZA.theme.merchant_theme_name === 'Wind' || window.SHOPLAZZA.theme.merchant_theme_name === 'Flash') { productInfoEl = document.querySelector('.product-info-body .product-sticky-container'); } else if (window.SHOPLAZZA.theme.merchant_theme_name === 'Hero') { productInfoEl = document.querySelector('.product__info-wrapper .properties-content'); } if(productInfoEl){ productInfoEl.classList.add('force-top-auto'); } } // 兼容 wind/flash /hero 主题 (sticky属性影响 popover 层级展示, 会被其他元素覆盖) toggleProductSticky(isSticky) { let productInfoEl = null; if (window.SHOPLAZZA.theme.merchant_theme_name === 'Wind' || window.SHOPLAZZA.theme.merchant_theme_name === 'Flash') { productInfoEl = document.querySelector('.product-info-body .product-sticky-container'); } else if (window.SHOPLAZZA.theme.merchant_theme_name === 'Hero') { productInfoEl = document.querySelector('.product__info-wrapper .properties-content'); } if(productInfoEl){ if(isSticky) { // 还原该主题原有的sticky属性值 productInfoEl.classList.remove('force-position-static'); return; } productInfoEl.classList.toggle('force-position-static'); } } setupAction_() { this.registerAction('handleDropdown', (invocation) => { const discount_id = invocation.args.discount_id; const nodes = document.querySelectorAll('.automatic-container'); Array.from(nodes).forEach((node) => { if(node.getAttribute('id') != `automatic-${discount_id}`) { node.classList.remove('open-dropdown'); } }) const $discount_item = document.querySelector(`#automatic-${discount_id}`); $discount_item && $discount_item.classList.toggle('open-dropdown'); // 兼容主题 this.toggleProductSticky(); }); } triggerEvent_(name, data) { const event = SPZUtils.Event.create(this.win, `${ TAG }.${ name }`, data || {}); this.action_.trigger(this.element, name, event); } isLayoutSupported(layout) { return layout == SPZCore.Layout.CONTAINER; } } SPZ.defineElement(TAG, SpzCustomProductAutomatic);
DIY Spot Drill Garland 5D Crystal Diamond Painting Art Flower Wreath Gift Handwork Hanging Mosaic Wall Decoration
Feature:
Our art garland kit takes our crystal card concept a step further, enabling you to create exquisite artwork to decorate your house or give it as a handmade gift.
The concept is similar to digital painting, also known as 5D diamond painting.
Each design has a numbered sticky template.
Use this tool to lift the colored resin gemstone and place it on the corresponding numbered point.
This technique is a relaxing and therapeutic handicraft activity, suitable for adults and children (over 6 years old).
The result is an amazing work of rhinestone art that you can install on the wall or give it as a gift to your loved ones.
This beautiful wreath is perfect for adding some color and luster to your front door or wall.
The garland is about 23 cm, made of PC material, very suitable for hanging around the house.

Specification:
Material: Chevron board material
Item type: 5d diamond painting
Color: as shown
Style: DZ626-Fairy, DZ628-Butterfly DZ629-Bee DZ630-LOVE DZ631-Bird Bee DZ632-Peace Dove DZ633-Cat DZ636-Hedgehog DZ638-Dragonfly
Garland size: Approx.23*23cm/(1cm=0.39 inch)
Space: living room/bedroom/classroom/entrance

DIY diamond painting production steps:
1. Open the package and check whether the diamond painting tools are complete;
2. According to the color code of the resin diamond, choose a color on the plate. If the same color is pasted at a time, the speed can be increased;
3. Find the corresponding color code on the canvas, start pasting until it is finished;
4. After finishing, in order to make the diamond painting stable, you can put some books on the canvas for a while;
5. Finally finished, you can hang up your results, decorate your home as much as you want, and add vitality to your home.

Precautions for DIY diamond painting:
1. Refer to the previous steps.
2. If you don\'t know what color to use, please refer to the color table.

Note:
1. 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!
2. Please allow 1-2cm measuring deviation due to manual measurement.
3. This is a diy diamond painting, it is not completed, you need to complete it yourself.

Package Content:
1 X Diamond Painting Chevron Board (Rhinestone Needs To Be Pasted)
1set X Diamond Painting Tool