$product = {"id":7892708032611,"title":"iPhone 16 Plus AirX Aaron Chang Yin\u0026Yang","handle":"iphone-16-plus-airx-magsafe-aar04","description":null,"published_at":"2025-10-03T09:36:29+08:00","created_at":"2025-10-02T10:16:46+08:00","vendor":"RHINOSHIELD Taiwan B2B","type":"","tags":["10%","20%","30%","40%","50%","brand-Apple","designer","designer-aaronchang","device-iPhone 16 Plus","merge","reseller-aaronchang"],"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":43756848316515,"title":"Flux Gray","option1":"Flux Gray","option2":null,"option3":null,"sku":"MAR013264F-AAR04","requires_shipping":true,"taxable":true,"featured_image":{"id":34543902523491,"product_id":7892708032611,"position":2,"created_at":"2025-10-02T10:16:48+08:00","updated_at":"2025-10-02T10:16:50+08:00","alt":null,"width":2000,"height":2000,"src":"\/\/b2b.rhinoshield.tw\/cdn\/shop\/files\/01f54ee3ceac68172449c9da30d361151f7a95c0.webp?v=1759371410","variant_ids":[43756848316515]},"available":true,"name":"iPhone 16 Plus AirX Aaron Chang Yin\u0026Yang - 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":"MAR013264F-AAR04","featured_media":{"alt":null,"id":26113657405539,"position":2,"preview_image":{"aspect_ratio":1.0,"height":2000,"width":2000,"src":"\/\/b2b.rhinoshield.tw\/cdn\/shop\/files\/01f54ee3ceac68172449c9da30d361151f7a95c0.webp?v=1759371410"}},"requires_selling_plan":false,"selling_plan_allocations":[],"quantity_rule":{"min":1,"max":null,"increment":1}},{"id":43756849299555,"title":"Vero Black","option1":"Vero Black","option2":null,"option3":null,"sku":"MAR013264E-AAR04","requires_shipping":true,"taxable":true,"featured_image":{"id":34543902294115,"product_id":7892708032611,"position":1,"created_at":"2025-10-02T10:16:47+08:00","updated_at":"2025-10-02T10:16:49+08:00","alt":null,"width":2000,"height":2000,"src":"\/\/b2b.rhinoshield.tw\/cdn\/shop\/files\/a8558ac5eac0b8054d0a8b9e2836c42fe34b7133.webp?v=1759371409","variant_ids":[43756849299555]},"available":true,"name":"iPhone 16 Plus AirX Aaron Chang Yin\u0026Yang - 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":"MAR013264E-AAR04","featured_media":{"alt":null,"id":26113657176163,"position":1,"preview_image":{"aspect_ratio":1.0,"height":2000,"width":2000,"src":"\/\/b2b.rhinoshield.tw\/cdn\/shop\/files\/a8558ac5eac0b8054d0a8b9e2836c42fe34b7133.webp?v=1759371409"}},"requires_selling_plan":false,"selling_plan_allocations":[],"quantity_rule":{"min":1,"max":null,"increment":1}}],"images":["\/\/b2b.rhinoshield.tw\/cdn\/shop\/files\/a8558ac5eac0b8054d0a8b9e2836c42fe34b7133.webp?v=1759371409","\/\/b2b.rhinoshield.tw\/cdn\/shop\/files\/01f54ee3ceac68172449c9da30d361151f7a95c0.webp?v=1759371410"],"featured_image":"\/\/b2b.rhinoshield.tw\/cdn\/shop\/files\/a8558ac5eac0b8054d0a8b9e2836c42fe34b7133.webp?v=1759371409","options":["color"],"media":[{"alt":null,"id":26113657176163,"position":1,"preview_image":{"aspect_ratio":1.0,"height":2000,"width":2000,"src":"\/\/b2b.rhinoshield.tw\/cdn\/shop\/files\/a8558ac5eac0b8054d0a8b9e2836c42fe34b7133.webp?v=1759371409"},"aspect_ratio":1.0,"height":2000,"media_type":"image","src":"\/\/b2b.rhinoshield.tw\/cdn\/shop\/files\/a8558ac5eac0b8054d0a8b9e2836c42fe34b7133.webp?v=1759371409","width":2000},{"alt":null,"id":26113657405539,"position":2,"preview_image":{"aspect_ratio":1.0,"height":2000,"width":2000,"src":"\/\/b2b.rhinoshield.tw\/cdn\/shop\/files\/01f54ee3ceac68172449c9da30d361151f7a95c0.webp?v=1759371410"},"aspect_ratio":1.0,"height":2000,"media_type":"image","src":"\/\/b2b.rhinoshield.tw\/cdn\/shop\/files\/01f54ee3ceac68172449c9da30d361151f7a95c0.webp?v=1759371410","width":2000}],"requires_selling_plan":false,"selling_plan_groups":[],"content":null}; $bumper = null; $variants = [{"id":43756848316515,"title":"Flux Gray","option1":"Flux Gray","option2":null,"option3":null,"sku":"MAR013264F-AAR04","requires_shipping":true,"taxable":true,"featured_image":{"id":34543902523491,"product_id":7892708032611,"position":2,"created_at":"2025-10-02T10:16:48+08:00","updated_at":"2025-10-02T10:16:50+08:00","alt":null,"width":2000,"height":2000,"src":"\/\/b2b.rhinoshield.tw\/cdn\/shop\/files\/01f54ee3ceac68172449c9da30d361151f7a95c0.webp?v=1759371410","variant_ids":[43756848316515]},"available":true,"name":"iPhone 16 Plus AirX Aaron Chang Yin\u0026Yang - 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":"MAR013264F-AAR04","featured_media":{"alt":null,"id":26113657405539,"position":2,"preview_image":{"aspect_ratio":1.0,"height":2000,"width":2000,"src":"\/\/b2b.rhinoshield.tw\/cdn\/shop\/files\/01f54ee3ceac68172449c9da30d361151f7a95c0.webp?v=1759371410"}},"requires_selling_plan":false,"selling_plan_allocations":[],"quantity_rule":{"min":1,"max":null,"increment":1}},{"id":43756849299555,"title":"Vero Black","option1":"Vero Black","option2":null,"option3":null,"sku":"MAR013264E-AAR04","requires_shipping":true,"taxable":true,"featured_image":{"id":34543902294115,"product_id":7892708032611,"position":1,"created_at":"2025-10-02T10:16:47+08:00","updated_at":"2025-10-02T10:16:49+08:00","alt":null,"width":2000,"height":2000,"src":"\/\/b2b.rhinoshield.tw\/cdn\/shop\/files\/a8558ac5eac0b8054d0a8b9e2836c42fe34b7133.webp?v=1759371409","variant_ids":[43756849299555]},"available":true,"name":"iPhone 16 Plus AirX Aaron Chang Yin\u0026Yang - 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":"MAR013264E-AAR04","featured_media":{"alt":null,"id":26113657176163,"position":1,"preview_image":{"aspect_ratio":1.0,"height":2000,"width":2000,"src":"\/\/b2b.rhinoshield.tw\/cdn\/shop\/files\/a8558ac5eac0b8054d0a8b9e2836c42fe34b7133.webp?v=1759371409"}},"requires_selling_plan":false,"selling_plan_allocations":[],"quantity_rule":{"min":1,"max":null,"increment":1}}]; $defaultVariant = {"id":43756848316515,"title":"Flux Gray","option1":"Flux Gray","option2":null,"option3":null,"sku":"MAR013264F-AAR04","requires_shipping":true,"taxable":true,"featured_image":{"id":34543902523491,"product_id":7892708032611,"position":2,"created_at":"2025-10-02T10:16:48+08:00","updated_at":"2025-10-02T10:16:50+08:00","alt":null,"width":2000,"height":2000,"src":"\/\/b2b.rhinoshield.tw\/cdn\/shop\/files\/01f54ee3ceac68172449c9da30d361151f7a95c0.webp?v=1759371410","variant_ids":[43756848316515]},"available":true,"name":"iPhone 16 Plus AirX Aaron Chang Yin\u0026Yang - 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":"MAR013264F-AAR04","featured_media":{"alt":null,"id":26113657405539,"position":2,"preview_image":{"aspect_ratio":1.0,"height":2000,"width":2000,"src":"\/\/b2b.rhinoshield.tw\/cdn\/shop\/files\/01f54ee3ceac68172449c9da30d361151f7a95c0.webp?v=1759371410"}},"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: "停產" }