Green Humidifier with Adjustable Ambient Lighting
Green Humidifier with Adjustable Ambient Lighting

Green Humidifier with Adjustable Ambient Lighting

$39.99 $59.99 Save 33%
Quantity
Share the love
Free shipping to most countries
Easy returns
Secure payments
Processing time within 7-14 Business Days

Enhance the ambiance of any space with the Ultrasonic Aromatherapy Humidifier. With intelligent auto-off functionality, ultrasonic aromatherapy diffusion, quiet operation, and smart features, this humidifier is designed to create a soothing and stress-free environment wherever it is used.

Features:

  • Suitable for Any Scene: Ideal for use in homes, living rooms, bedrooms, offices, gyms, and more. Makes a wonderful gift for loved ones.

  • Intelligent Power Off: Features an automatic shut-off function that activates when the water level is low, ensuring safety by preventing accidents.

  • Ultrasonic Aromatherapy: Perfect for use in homes, offices, and during yoga sessions. Simply add 3-5 drops of your preferred essential oils to fill the space with a pleasant aroma, alleviate fatigue, hydrate your skin, reduce stress, and establish a serene environment.

  • Quiet Operation: Designed for minimal noise, operating at a noise level as low as 30 decibels to ensure uninterrupted rest or work.

  • Smart Aroma Humidifier: Offers a range of functions including intelligent auto-off, gentle atomization, night light feature, and more, catering to all your home humidification needs.

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.