LTGEM Portable Travel Case for Logitech G903 Lightspeed Gaming Mouse
LTGEM Portable Travel Case for Logitech G903 Lightspeed Gaming Mouse
LTGEM Portable Travel Case for Logitech G903 Lightspeed Gaming Mouse
LTGEM Portable Travel Case for Logitech G903 Lightspeed Gaming Mouse
LTGEM Portable Travel Case for Logitech G903 Lightspeed Gaming Mouse
LTGEM Portable Travel Case for Logitech G903 Lightspeed Gaming Mouse
LTGEM Portable Travel Case for Logitech G903 Lightspeed Gaming Mouse
LTGEM Portable Travel Case for Logitech G903 Lightspeed Gaming Mouse
LTGEM Portable Travel Case for Logitech G903 Lightspeed Gaming Mouse
LTGEM Portable Travel Case for Logitech G903 Lightspeed Gaming Mouse

LTGEM Portable Travel Case for Logitech G903 Lightspeed Gaming Mouse

$18.50
$0.00
-$-18.50
Quantity
Free worldwide shipping
Free returns
Sustainably made
Secure payments
Vendor by: LTGEM
SKU: CS233
  • Perfect Fit for Logitech G903 – Custom-designed to fit the Logitech G903 Lightspeed mouse snugly, offering secure and reliable protection.
  • Premium Protection – Built with durable, shockproof, and splash-resistant materials, this case safeguards your mouse from impacts, dust, and moisture.
  • Portable and Lightweight – Designed for convenience, this slim and compact case easily fits into your bag, making it ideal for travel or daily carry.
  • Scratch-Resistant Interior – The soft inner lining prevents scratches, ensuring that your G903 mouse stays in top condition wherever you go.
  • Mouse Not Included – Please note, this is only a carrying case and does not come with the Logitech G903 Lightspeed mouse itself.

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.