Diamond Painting Tool USB Charging Point Drill Pen Kit Luminous Drawing Pen
Diamond Painting Tool USB Charging Point Drill Pen Kit Luminous Drawing Pen
Diamond Painting Tool USB Charging Point Drill Pen Kit Luminous Drawing Pen
Diamond Painting Tool USB Charging Point Drill Pen Kit Luminous Drawing Pen
Diamond Painting Tool USB Charging Point Drill Pen Kit Luminous Drawing Pen
Diamond Painting Tool USB Charging Point Drill Pen Kit Luminous Drawing Pen
Diamond Painting Tool USB Charging Point Drill Pen Kit Luminous Drawing Pen
Diamond Painting Tool USB Charging Point Drill Pen Kit Luminous Drawing Pen
1 / 8
Diamond Painting Tool USB Charging Point Drill Pen Kit Luminous Drawing Pen
Diamond Painting Tool USB Charging Point Drill Pen Kit Luminous Drawing Pen
Diamond Painting Tool USB Charging Point Drill Pen Kit Luminous Drawing Pen
Diamond Painting Tool USB Charging Point Drill Pen Kit Luminous Drawing Pen
Diamond Painting Tool USB Charging Point Drill Pen Kit Luminous Drawing Pen
Diamond Painting Tool USB Charging Point Drill Pen Kit Luminous Drawing Pen
Diamond Painting Tool USB Charging Point Drill Pen Kit Luminous Drawing Pen
Diamond Painting Tool USB Charging Point Drill Pen Kit Luminous Drawing Pen
0% OFF
SOD

Diamond Painting Tool USB Charging Point Drill Pen Kit Luminous Drawing Pen

426109

$7.99
75 sold
Qty 41 in stock

Durable Diamond Painting Tool USB Charging Point Drill Pen Kit Luminous Drawing Pen DIY Craft Home Decor Diamond Embroidery Accessories
Specification:
Type of pen tip: nine bit, six bit, three bit, single bit, elbow head pen
Power mode: USB power
Material: Alloy
Product size: 9cm / 3.5in
Product weight: 26g
Product use: diamond painting accessories

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-3mm measuring deviation due to manual measurement.

Package Content:

1 X Luminous Point Drill Pen
5 X Pen Tip
1 X USB Cable

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