Diamond Painting Dream Light Catcher Wind Chime Crystal Pendant (DZ3030)
Diamond Painting Dream Light Catcher Wind Chime Crystal Pendant (DZ3030)
Diamond Painting Dream Light Catcher Wind Chime Crystal Pendant (DZ3030)
Diamond Painting Dream Light Catcher Wind Chime Crystal Pendant (DZ3030)
Diamond Painting Dream Light Catcher Wind Chime Crystal Pendant (DZ3030)
Diamond Painting Dream Light Catcher Wind Chime Crystal Pendant (DZ3030)
Diamond Painting Dream Light Catcher Wind Chime Crystal Pendant (DZ3030)
Diamond Painting Dream Light Catcher Wind Chime Crystal Pendant (DZ3030)
Diamond Painting Dream Light Catcher Wind Chime Crystal Pendant (DZ3030)
Diamond Painting Dream Light Catcher Wind Chime Crystal Pendant (DZ3030)
Diamond Painting Dream Light Catcher Wind Chime Crystal Pendant (DZ3030)
Diamond Painting Dream Light Catcher Wind Chime Crystal Pendant (DZ3030)
Diamond Painting Dream Light Catcher Wind Chime Crystal Pendant (DZ3030)
Diamond Painting Dream Light Catcher Wind Chime Crystal Pendant (DZ3030)
Diamond Painting Dream Light Catcher Wind Chime Crystal Pendant (DZ3030)
Diamond Painting Dream Light Catcher Wind Chime Crystal Pendant (DZ3030)
Diamond Painting Dream Light Catcher Wind Chime Crystal Pendant (DZ3030)
Diamond Painting Dream Light Catcher Wind Chime Crystal Pendant (DZ3030)

Diamond Painting Dream Light Catcher Wind Chime Crystal Pendant (DZ3030)

SKU: 591564.05
Price
$5.59
$5.59
Save  0%
Quantity
const TAG = "spz-custom-product-automatic"; class SpzCustomProductAutomatic extends SPZ.BaseElement { constructor(element) { super(element); this.variant_id = 'c185418f-a6b1-4b8a-9462-7b900101f168'; } 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 = 'cb3b4978-41a0-42dd-a13d-0ff7b06a91cd'; 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 == 'cb3b4978-41a0-42dd-a13d-0ff7b06a91cd' && 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 Point Drill Diamond Painting Dream Light Catching Wind Chimes Crystal Craft Mosaic Kit Pendant Hanging Gift Home Wall Door Decor
Feature:
1. Rainbow chain + angel tears: The crystal light trapping jewelry is made of K9 crystal, and the cutting process is crystal clear. The high refractive index crystal light trapping jewelry sparkles in the sun.
2. As a light-catching ornament hung on the window, this kind of light-catching ornament will produce beautiful reflections. When the sun shines from different angles, it will reflect different lighting effects
3. Durable, these light-harvesting decorations seem to be fragile and easily scratched, but they are actually very durable. They hardly become cloudy or tarnished.
4. Crystal light-trapping decoration is suitable for many occasions, very suitable for weddings, baby rooms, Christmas tree decorations, chandeliers, car pendants, window suspensions, outdoor gardens and other decorations.
5. The perfect gift choice, very suitable for any gift-giving occasion, the best gift for mom and your lover, wife, friend, girlfriend.
6. Hanging them on the windows and let the colorful red illuminate your room. Simple collection elements with fresh colors will make your home feel warmer!

Specification:
Product Size:
Hanging chain 90mm/3.54in
The main body length of the pattern is 120 X 120mm/4.72 X 4.72in
Beads and feathers (bottom part) 120mm/4.72in
Product material: Acrylic point drill
Product packaging: bubble bag

DIY point drill diamond production steps:
1. Open the package and check whether the diamond painting tools are complete;
2. According to the color 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 on the canvas and start pasting until it is finished;
4. After finishing, in order to make the diamond stable, you can take some books and press them on the acrylic board 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.

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.

Package Content:
1 X Dream Catcher Accessories
1 set X Diamond Bag
1 set X Point Drilling Tools (Small Wax Block, Point Drill Plate, Point Drill Pen)