Purse Light Heart Shape Bag Light for Handbags Purse Accessories with Automatic Sensor
Purse Light Heart Shape Bag Light for Handbags Purse Accessories with Automatic Sensor

Purse Light Heart Shape Bag Light for Handbags Purse Accessories with Automatic Sensor

$19.99 $39.99 Save 50%
Set:  1
Quantity
Share the love
Free shipping to most countries
Easy returns
Secure payments
Processing time within 7-14 Business Days

Illuminate your handbag with the Heart-Shaped Handbag Light, a convenient and safe accessory powered by batteries. Perfect for any handbag, tote bag, purse, or backpack, these purse accessories provide added convenience to your daily life. With a stylish and charming heart-shaped design, these lights are practical, lightweight, and fashionable, making them an excellent gift for women, girls, and friends. The automatic sensor feature allows for easy activation with a touch, providing quick illumination for up to 12 seconds, while the manual on/off button ensures continuous light until turned off. Light up your purse and easily find your essentials with the bright illumination provided by the handbag lights.

Features:

  • Convenient and Safe: Battery-powered handbag lights that are convenient and safe to use, offering ease of access to your belongings.

  • Perfect Purse Accessories: Designed to fit any handbag, tote bag, purse, or backpack, these lights add a touch of convenience to your daily routine.

  • Stylish and Lovely Design: Unique heart-shaped design measuring only 2.5×2.7 inches and weighing 35g, combining practicality with style. Ideal as a gift for women, girls, and friends.

  • Touch to Light Up:

    • Auto Button: Light turns on with a touch and automatically turns off after about 12 seconds, providing reliable illumination when needed.
    • On Button: Light stays on until manually turned off, ensuring continuous illumination.
  • Light Up Your Purse: The bright purse light allows you to easily locate items at the bottom of your handbag, such as keys, cell phone, or lipstick, eliminating the need to rummage around in the dark.

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.