Black Cat Bookmarks Magnetic Book Mark Clips Set Book Markers
Black Cat Bookmarks Magnetic Book Mark Clips Set Book Markers

Black Cat Bookmarks Magnetic Book Mark Clips Set Book Markers

$9.99
Color:  Style-a,6 Pcs
Quantity
Share the love
Free shipping to most countries
Easy returns
Secure payments
Processing time within 7-14 Business Days

ADORABLE GIFT - The cool bookmarks look exquisite and are suitable as a gift for book lovers, bookworms, writers, teachers or anyone else who loves cats. In addition, they can be used as gifts for birthday parties, back to school, holidays or other important occasions.

WIDE RANGE APPLICATION - These book markers for women are suitable as bookmarks, easy to clip the pages for further reading next time, or as book decoration, small and light enough to carry around, ideal for home, office, school, lectures, meetings, etc.

EASY TO USE - Each cute bookmarks is light in weight, easy to carry and store, you just need to put it on the page you want to mark and fold the magnets together when using it, it will not fall off the book easily, and bring you a good user experience .

REASSURING MATERIAL - The bookmarks for book lovers is made of high quality coated paper and magnetic material, reliable and durable, clear printing, not easy to fade or break, supports long time use, easy to use and store.

PACKAGE DETAILS - You will receive 6 Pcs magnetic bookmarks for women in six different styles and sizes.

Name: black cat magnetic bookmark color: black Material: paper Product size: as shown Specification: 6pcs Packing list: 6pcs black cat magnetic bookmark

Returns Policy

◆Defective Products: If you receive a defective product, please contact our customer support team at [email protected] within 7 days of purchase to arrange for a return, exchange, or refund. Shelflit will cover all costs associated with a defective product. Our policy lasts 7 days. If 7 days have gone by since you receiving the product, we are sorry to can’t offer you a refund or exchange.

◆General Returns: Shelflit accepts returns for most products within 7 days of the purchase date. To be eligible for a return, the product must be in its original condition, unused, and in the original packaging. The customer should to pay return shipping for the item(s).

2. Refund Process ◆Refund Method: Refunds will be issued to the original payment method used during the purchase.

◆Processing Time: Please allow up to 7 business days for the refund to be processed after we receive the returned product. The time it takes for the refund to reflect on your account may vary depending on your payment provider.

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.