$product = {"id":7829056225379,"title":"iPhone 16 Pro Max AirX Tour de France Mont Ventoux","handle":"iphone-16-pro-max-airx-magsafe-bumper-back-crossover-design-tdf11","description":null,"published_at":"2025-07-14T10:51:34+08:00","created_at":"2025-06-30T15:56:24+08:00","vendor":"RHINOSHIELD Taiwan B2B","type":"","tags":["10%","20%","30%","40%","50%","brand-Apple","designer","designer-tour-de-france","device-iPhone 16 Pro Max","merge","reseller-tour-de-france"],"price":188000,"price_min":188000,"price_max":188000,"available":true,"price_varies":false,"compare_at_price":null,"compare_at_price_min":0,"compare_at_price_max":0,"compare_at_price_varies":false,"variants":[{"id":43502751154275,"title":"Vero Black","option1":"Vero Black","option2":null,"option3":null,"sku":"MAR013284E-TDF11","requires_shipping":true,"taxable":true,"featured_image":{"id":34099452903523,"product_id":7829056225379,"position":2,"created_at":"2025-06-30T15:56:29+08:00","updated_at":"2025-06-30T15:56:31+08:00","alt":null,"width":2000,"height":2000,"src":"\/\/b2b.rhinoshield.tw\/cdn\/shop\/files\/450f8e6be13678f9066b2ec3bfad1567e4bcf2cf.webp?v=1751270191","variant_ids":[43502751154275]},"available":true,"name":"iPhone 16 Pro Max AirX Tour de France Mont Ventoux - Vero Black","public_title":"Vero Black","options":["Vero Black"],"price":188000,"weight":0,"compare_at_price":null,"inventory_quantity":0,"inventory_management":null,"inventory_policy":"deny","barcode":"MAR013284E-TDF11","featured_media":{"alt":null,"id":25756126052451,"position":2,"preview_image":{"aspect_ratio":1.0,"height":2000,"width":2000,"src":"\/\/b2b.rhinoshield.tw\/cdn\/shop\/files\/450f8e6be13678f9066b2ec3bfad1567e4bcf2cf.webp?v=1751270191"}},"requires_selling_plan":false,"selling_plan_allocations":[],"quantity_rule":{"min":1,"max":null,"increment":1}},{"id":43502752530531,"title":"Flux Gray","option1":"Flux Gray","option2":null,"option3":null,"sku":"MAR013284F-TDF11","requires_shipping":true,"taxable":true,"featured_image":{"id":34099452084323,"product_id":7829056225379,"position":1,"created_at":"2025-06-30T15:56:28+08:00","updated_at":"2025-06-30T15:56:30+08:00","alt":null,"width":2000,"height":2000,"src":"\/\/b2b.rhinoshield.tw\/cdn\/shop\/files\/333465198643db4038962f2e454aaf29fd225996.webp?v=1751270190","variant_ids":[43502752530531]},"available":true,"name":"iPhone 16 Pro Max AirX Tour de France Mont Ventoux - Flux Gray","public_title":"Flux Gray","options":["Flux Gray"],"price":188000,"weight":0,"compare_at_price":null,"inventory_quantity":0,"inventory_management":null,"inventory_policy":"deny","barcode":"MAR013284F-TDF11","featured_media":{"alt":null,"id":25756125659235,"position":1,"preview_image":{"aspect_ratio":1.0,"height":2000,"width":2000,"src":"\/\/b2b.rhinoshield.tw\/cdn\/shop\/files\/333465198643db4038962f2e454aaf29fd225996.webp?v=1751270190"}},"requires_selling_plan":false,"selling_plan_allocations":[],"quantity_rule":{"min":1,"max":null,"increment":1}}],"images":["\/\/b2b.rhinoshield.tw\/cdn\/shop\/files\/333465198643db4038962f2e454aaf29fd225996.webp?v=1751270190","\/\/b2b.rhinoshield.tw\/cdn\/shop\/files\/450f8e6be13678f9066b2ec3bfad1567e4bcf2cf.webp?v=1751270191"],"featured_image":"\/\/b2b.rhinoshield.tw\/cdn\/shop\/files\/333465198643db4038962f2e454aaf29fd225996.webp?v=1751270190","options":["color"],"media":[{"alt":null,"id":25756125659235,"position":1,"preview_image":{"aspect_ratio":1.0,"height":2000,"width":2000,"src":"\/\/b2b.rhinoshield.tw\/cdn\/shop\/files\/333465198643db4038962f2e454aaf29fd225996.webp?v=1751270190"},"aspect_ratio":1.0,"height":2000,"media_type":"image","src":"\/\/b2b.rhinoshield.tw\/cdn\/shop\/files\/333465198643db4038962f2e454aaf29fd225996.webp?v=1751270190","width":2000},{"alt":null,"id":25756126052451,"position":2,"preview_image":{"aspect_ratio":1.0,"height":2000,"width":2000,"src":"\/\/b2b.rhinoshield.tw\/cdn\/shop\/files\/450f8e6be13678f9066b2ec3bfad1567e4bcf2cf.webp?v=1751270191"},"aspect_ratio":1.0,"height":2000,"media_type":"image","src":"\/\/b2b.rhinoshield.tw\/cdn\/shop\/files\/450f8e6be13678f9066b2ec3bfad1567e4bcf2cf.webp?v=1751270191","width":2000}],"requires_selling_plan":false,"selling_plan_groups":[],"content":null}; $bumper = null; $variants = [{"id":43502751154275,"title":"Vero Black","option1":"Vero Black","option2":null,"option3":null,"sku":"MAR013284E-TDF11","requires_shipping":true,"taxable":true,"featured_image":{"id":34099452903523,"product_id":7829056225379,"position":2,"created_at":"2025-06-30T15:56:29+08:00","updated_at":"2025-06-30T15:56:31+08:00","alt":null,"width":2000,"height":2000,"src":"\/\/b2b.rhinoshield.tw\/cdn\/shop\/files\/450f8e6be13678f9066b2ec3bfad1567e4bcf2cf.webp?v=1751270191","variant_ids":[43502751154275]},"available":true,"name":"iPhone 16 Pro Max AirX Tour de France Mont Ventoux - Vero Black","public_title":"Vero Black","options":["Vero Black"],"price":188000,"weight":0,"compare_at_price":null,"inventory_quantity":0,"inventory_management":null,"inventory_policy":"deny","barcode":"MAR013284E-TDF11","featured_media":{"alt":null,"id":25756126052451,"position":2,"preview_image":{"aspect_ratio":1.0,"height":2000,"width":2000,"src":"\/\/b2b.rhinoshield.tw\/cdn\/shop\/files\/450f8e6be13678f9066b2ec3bfad1567e4bcf2cf.webp?v=1751270191"}},"requires_selling_plan":false,"selling_plan_allocations":[],"quantity_rule":{"min":1,"max":null,"increment":1}},{"id":43502752530531,"title":"Flux Gray","option1":"Flux Gray","option2":null,"option3":null,"sku":"MAR013284F-TDF11","requires_shipping":true,"taxable":true,"featured_image":{"id":34099452084323,"product_id":7829056225379,"position":1,"created_at":"2025-06-30T15:56:28+08:00","updated_at":"2025-06-30T15:56:30+08:00","alt":null,"width":2000,"height":2000,"src":"\/\/b2b.rhinoshield.tw\/cdn\/shop\/files\/333465198643db4038962f2e454aaf29fd225996.webp?v=1751270190","variant_ids":[43502752530531]},"available":true,"name":"iPhone 16 Pro Max AirX Tour de France Mont Ventoux - Flux Gray","public_title":"Flux Gray","options":["Flux Gray"],"price":188000,"weight":0,"compare_at_price":null,"inventory_quantity":0,"inventory_management":null,"inventory_policy":"deny","barcode":"MAR013284F-TDF11","featured_media":{"alt":null,"id":25756125659235,"position":1,"preview_image":{"aspect_ratio":1.0,"height":2000,"width":2000,"src":"\/\/b2b.rhinoshield.tw\/cdn\/shop\/files\/333465198643db4038962f2e454aaf29fd225996.webp?v=1751270190"}},"requires_selling_plan":false,"selling_plan_allocations":[],"quantity_rule":{"min":1,"max":null,"increment":1}}]; $defaultVariant = {"id":43502751154275,"title":"Vero Black","option1":"Vero Black","option2":null,"option3":null,"sku":"MAR013284E-TDF11","requires_shipping":true,"taxable":true,"featured_image":{"id":34099452903523,"product_id":7829056225379,"position":2,"created_at":"2025-06-30T15:56:29+08:00","updated_at":"2025-06-30T15:56:31+08:00","alt":null,"width":2000,"height":2000,"src":"\/\/b2b.rhinoshield.tw\/cdn\/shop\/files\/450f8e6be13678f9066b2ec3bfad1567e4bcf2cf.webp?v=1751270191","variant_ids":[43502751154275]},"available":true,"name":"iPhone 16 Pro Max AirX Tour de France Mont Ventoux - Vero Black","public_title":"Vero Black","options":["Vero Black"],"price":188000,"weight":0,"compare_at_price":null,"inventory_quantity":0,"inventory_management":null,"inventory_policy":"deny","barcode":"MAR013284E-TDF11","featured_media":{"alt":null,"id":25756126052451,"position":2,"preview_image":{"aspect_ratio":1.0,"height":2000,"width":2000,"src":"\/\/b2b.rhinoshield.tw\/cdn\/shop\/files\/450f8e6be13678f9066b2ec3bfad1567e4bcf2cf.webp?v=1751270191"}},"requires_selling_plan":false,"selling_plan_allocations":[],"quantity_rule":{"min":1,"max":null,"increment":1}}; $device_handle = null var sellingStatus if ($bumper) { $(document).ready(function() { var productImg = $product.images[0] var bumperVariants = $bumper.variants; var bumperColors = new Object(); var currentVariant = ''; var productType = ''; bumperVariants.forEach(variant => { bumperColors[`${variant.title.split(' (')[0].toLowerCase()}`] = variant.featured_image.src; }); if (productType === 'mod-nx-backplate' || productType === 'mod-backplate') { mergeImages( [productImg, bumperColors[currentVariant]], { crossOrigin: 'anonymous' } ).then(mergedImg => { $('.merged-img').attr('src', mergedImg); }); } else { mergeImages( [bumperColors[currentVariant], productImg], { crossOrigin: 'anonymous' } ).then(mergedImg => { $('.merged-img').attr('src', mergedImg); }); } }); }; var sellingStatusData window.fetchSellingStatus().then(data => { try { sellingStatusData = data; } catch (error) { sellingStatusData = null console.error('Unable to parse selling status', error) } $(document).ready(function() { handleSellingStatus($defaultVariant.sku); }); }) function handleSellingStatus(currentSku) { if (!sellingStatusData) { console.error('No selling status available!') return } const sellingStatusElement = document.getElementById('selling-status') const addToCartButton = document.getElementById('AddToCart-product-template') const currentProductSku = currentSku.replace(/-(.*)$/, '-') if ($variants) { const flattenedSellingStatus = [...sellingStatusData.pending, ...sellingStatusData.preorder] const matchSellingStatusProduct = flattenedSellingStatus.filter(product => currentProductSku === product.sku) if (matchSellingStatusProduct.length > 0) { const isProductPending = matchSellingStatusProduct[0].status === 'pending' const matchDate = matchSellingStatusProduct[0].date sellingStatus = isProductPending ? "缺貨中" : "預購完成出貨日:" + matchDate sellingStatusElement.textContent = sellingStatus if (sellingStatus.includes("缺貨中")){ addToCartButton.disabled ='true'; addToCartButton.textContent = "缺貨中無法加入購物車" } else { addToCartButton.textContent = "加到購物車" } } else { sellingStatusElement.textContent = '' addToCartButton.textContent = "加到購物車" }; }; }; document.addEventListener('DOMContentLoaded', function () { var currentVariantSelect = document.getElementById('SingleOptionSelector-0') currentVariantSelect.addEventListener('change', function() { var currentSku = $('#current_sku').text() var skuElement = document.getElementById('current-sku') skuElement.textContent = currentSku handleSellingStatus(currentSku) }); });
// Override default values of shop.strings for each template. // Alternate product templates can change values of // add to cart button, sold out, and unavailable states here. theme.productStrings = { addToCart: "加到購物車", soldOut: "售完", unavailable: "停產" }