LTGEM Portable Travel Case for Logitech MX Vertical Mouse
LTGEM Portable Travel Case for Logitech MX Vertical Mouse
LTGEM Portable Travel Case for Logitech MX Vertical Mouse
LTGEM Portable Travel Case for Logitech MX Vertical Mouse
LTGEM Portable Travel Case for Logitech MX Vertical Mouse
LTGEM Portable Travel Case for Logitech MX Vertical Mouse
LTGEM Portable Travel Case for Logitech MX Vertical Mouse

LTGEM Portable Travel Case for Logitech MX Vertical Mouse

$13.50
$0.00
-$-13.50
Quantity
Free worldwide shipping
Free returns
Sustainably made
Secure payments
Vendor by: LTGEM
SKU: CS347
  • Custom Fit for Logitech MX Vertical – Designed specifically for the unique shape of the Logitech MX Vertical, providing a snug and secure fit for safe storage.
  • Protective and Durable Design – Crafted from high-quality, shockproof, and splash-resistant materials to protect your mouse from impacts, dust, and moisture.
  • Compact and Easy to Carry – Slim and lightweight, this case easily fits into bags or backpacks, making it ideal for travel or daily commutes.
  • Soft, Scratch-Free Interior – The inner lining is made of soft material to prevent scratches, keeping your MX Vertical in excellent condition.
  • Mouse Not Included – Please note, this is a carrying case only and does not include the Logitech MX Vertical mouse.

From our customers

Add customer reviews and testimonials to showcase your store’s happy customers.
Author's name
Los Angeles, CA
Add customer reviews and testimonials to showcase your store’s happy customers.
Author's name
Los Angeles, CA
Add customer reviews and testimonials to showcase your store’s happy customers.
Author's name
Los Angeles, CA
Add customer reviews and testimonials to showcase your store’s happy customers.
Author's name
Los Angeles, CA
Add customer reviews and testimonials to showcase your store’s happy customers.
Author's name
Los Angeles, CA
Add customer reviews and testimonials to showcase your store’s happy customers.
Author's name
Los Angeles, CA
Add customer reviews and testimonials to showcase your store’s happy customers.
Author's name
Los Angeles, CA
Add customer reviews and testimonials to showcase your store’s happy customers.
Author's name
Los Angeles, CA
Add customer reviews and testimonials to showcase your store’s happy customers.
Author's name
Los Angeles, CA
Add customer reviews and testimonials to showcase your store’s happy customers.
Author's name
Los Angeles, CA
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.