Extra 5% Off For All Orders: 2024OP | Free Shipping Over $79
9pcs Cat Paw Double Sided DIY Diamond Keychain
9pcs Cat Paw Double Sided DIY Diamond Keychain
9pcs Cat Paw Double Sided DIY Diamond Keychain
9pcs Cat Paw Double Sided DIY Diamond Keychain
9pcs Cat Paw Double Sided DIY Diamond Keychain
9pcs Cat Paw Double Sided DIY Diamond Keychain
9pcs Cat Paw Double Sided DIY Diamond Keychain
9pcs Cat Paw Double Sided DIY Diamond Keychain
9pcs Cat Paw Double Sided DIY Diamond Keychain
9pcs Cat Paw Double Sided DIY Diamond Keychain
9pcs Cat Paw Double Sided DIY Diamond Keychain
9pcs Cat Paw Double Sided DIY Diamond Keychain
9pcs Cat Paw Double Sided DIY Diamond Keychain
9pcs Cat Paw Double Sided DIY Diamond Keychain
9pcs Cat Paw Double Sided DIY Diamond Keychain
9pcs Cat Paw Double Sided DIY Diamond Keychain
9pcs Cat Paw Double Sided DIY Diamond Keychain
5 / 17
9pcs Cat Paw Double Sided DIY Diamond Keychain
9pcs Cat Paw Double Sided DIY Diamond Keychain
9pcs Cat Paw Double Sided DIY Diamond Keychain
9pcs Cat Paw Double Sided DIY Diamond Keychain
9pcs Cat Paw Double Sided DIY Diamond Keychain
9pcs Cat Paw Double Sided DIY Diamond Keychain
9pcs Cat Paw Double Sided DIY Diamond Keychain
9pcs Cat Paw Double Sided DIY Diamond Keychain
9pcs Cat Paw Double Sided DIY Diamond Keychain
9pcs Cat Paw Double Sided DIY Diamond Keychain
9pcs Cat Paw Double Sided DIY Diamond Keychain
9pcs Cat Paw Double Sided DIY Diamond Keychain
9pcs Cat Paw Double Sided DIY Diamond Keychain
9pcs Cat Paw Double Sided DIY Diamond Keychain
9pcs Cat Paw Double Sided DIY Diamond Keychain
9pcs Cat Paw Double Sided DIY Diamond Keychain
9pcs Cat Paw Double Sided DIY Diamond Keychain
You May Also Like Don't Like These?
0% OFF
Mydiamonpainting

9pcs Cat Paw Double Sided DIY Diamond Keychain

965725.01

$18.98
1 sold
Style - PT06
Qty 1000 in stock
Specification:
Origin: Mainland China
Use: Car Pendant
Diamond Shape: Special-shaped
Product: DIY Diamond Painting Keychain
Material: Keychain+special-shaped Bright Diamond
Size: 7.2x6.7cm/2.83x2.64in
Pattern: PT06/PT10/PT11/pt17(optional)

DIY Diamond Painting Keychain Production Steps:
1. Open the packaging box and check the special tools for diamond painting.
2. Check the color of resin diamonds and arrange them in coding order.
3. Uncover the tape image above and you will see many symbols corresponding to the color coding.
4. According to the corresponding color coding fixture, the resin is embedded with diamonds.
5. Suggest a resin diamond set to complete faster.
6. In order to create a perfect diamond painting, place the pattern in one place without leaving diamonds on each line of symbols.
7. To cut a good figure on the drawing, please install the classification array on the plane of the material above.
8. Splicing needs to be flat, neat, and free from cracks.
9. After good hard work, the remaining glue gaps match the symbols of diamonds.

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 painted keychain, not completed. You need to complete it yourself.

Package Content:
9 X Keychain
1 X Diamond Drawing Tool (point drill pen, speed-up disc)
You May Also Like Don't Like These?
/** @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-1724747683315').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);
Customer Reviews

Here are what our customers say.

Write a Review
Customer Reviews
Wow you reached the bottom
Newest
Most liked
Highest ratings
Lowest ratings
×
class SpzCustomFileUpload extends SPZ.BaseElement { constructor(element) { super(element); this.uploadCount_ = 0; this.fileList_ = []; } buildCallback() { this.action = SPZServices.actionServiceForDoc(this.element); this.registerAction('upload', (data) => { this.handleFileUpload_(data.event?.detail?.data || []); }); this.registerAction('delete', (data) => { this.handleFileDelete_(data?.args?.data); }); this.registerAction('preview', (data) => { this.handleFilePreview_(data?.args?.data); }); this.registerAction('limit', (data) => { this.handleFileLimit_(); }); this.registerAction('sizeLimit', (data) => { this.handleFileSizeLimit_(); }); } isLayoutSupported(layout) { return layout == SPZCore.Layout.LOGIC; } setData_(count, file) { this.uploadCount_ = count; this.fileList_ = file; } handleFileUpload_(data) { data.forEach(i => { if(this.fileList_.some(j => j.url === i.url)) return; this.fileList_.push(i); }) this.uploadCount_++; sessionStorage.setItem('fileList', JSON.stringify(this.fileList_)); this.triggerEvent_("handleFileUpload", { count: this.uploadCount_, files: this.fileList_}); if(this.fileList_.length >= 5){ document.querySelector('#review_upload').style.display = 'none'; } if(this.fileList_.length > 0){ document.querySelector('.apps-reviews-write-anonymous-box').style.marginTop = '8px'; } } handleFileDelete_(index) { this.fileList_.splice(index, 1); this.uploadCount_--; sessionStorage.setItem('fileList', JSON.stringify(this.fileList_)); this.triggerEvent_("handleFileDelete", { count: this.uploadCount_, files: this.fileList_}); document.querySelector('#review_upload').style.display = 'block'; if(this.fileList_?.length === 0){ document.querySelector('.apps-reviews-write-anonymous-box').style.marginTop = '132px'; } } handleFilePreview_(index) { const finalPreviewData = this.fileList_[index]; const filePreviewModal = document.getElementById('filePreviewModal'); const fullScreenVideo = document.getElementById('fullScreenVideo'); const fullScreenImage = document.getElementById('fullScreenImage'); const previewModalClose = document.getElementById('previewModalClose'); const previewLoading = document.getElementById('previewLoading'); filePreviewModal.style.display = 'block'; previewLoading.style.display = 'flex'; if(finalPreviewData?.type === 'video'){ const media = this.mediaParse_(this.fileList_[index]?.url); fullScreenVideo.addEventListener('canplaythrough', function() { previewLoading.style.display = 'none'; }); fullScreenImage.src = ''; fullScreenImage.style.display = 'none'; fullScreenVideo.style.display = 'block'; fullScreenVideo.src = media.mp4 || ''; } else { fullScreenImage.onload = function() { previewLoading.style.display = 'none'; }; fullScreenVideo.src = ''; fullScreenVideo.style.display = 'none'; fullScreenImage.style.display = 'block'; fullScreenImage.src = finalPreviewData.url; } previewModalClose.addEventListener('click', function() { filePreviewModal.style.display = 'none'; }); } handleFileLimit_() { alert(window.AppReviewsLocale.comment_file_limit || 'please do not upload files more than 5'); this.triggerEvent_("handleFileLimit"); } handleFileSizeLimit_() { alert(window.AppReviewsLocale.comment_file_size_limit || 'File size does not exceed 10M'); } clear(){ this.fileList_ = []; this.uploadCount_ = 0; sessionStorage.setItem('fileList', JSON.stringify(this.fileList_)); this.triggerEvent_("handleClear", { count: this.uploadCount_, files: this.fileList_}); document.querySelector('#review_upload').style.display = 'block'; } mediaParse_(url) { var result = {}; try { url.replace(/[?&]+([^=&]+)=([^&]*)/gi, function (str, key, value) { try { result[key] = decodeURIComponent(value); } catch (e) { result[key] = value; } }); result.preview_image = url.split('?')[0]; } catch (e) {}; return result; } triggerEvent_(name, data) { const event = SPZUtils.Event.create(this.win, name, data); this.action.trigger(this.element, name, event); } } SPZ.defineElement('spz-custom-file-upload', SpzCustomFileUpload);
The review would not show in product details on storefront since it does not support to.