$product = {"id":7892694728803,"title":"iPhone 16 Plus Clear Aaron Chang Waiting for","handle":"iphone-16-plus-jellytint-aar08","description":null,"published_at":"2025-10-03T09:38:42+08:00","created_at":"2025-10-02T10:13:28+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":108000,"price_min":108000,"price_max":108000,"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":43756801458275,"title":"Fancy Pink","option1":"Fancy Pink","option2":null,"option3":null,"sku":"CCN013260J-AAR08","requires_shipping":true,"taxable":true,"featured_image":{"id":34543855042659,"product_id":7892694728803,"position":1,"created_at":"2025-10-02T10:13:32+08:00","updated_at":"2025-10-02T10:13:34+08:00","alt":null,"width":2000,"height":2000,"src":"\/\/b2b.rhinoshield.tw\/cdn\/shop\/files\/f6d956f7449fce5c6e3d4c08b04282e799fecf13.webp?v=1759371214","variant_ids":[43756801458275]},"available":true,"name":"iPhone 16 Plus Clear Aaron Chang Waiting for - Fancy Pink","public_title":"Fancy Pink","options":["Fancy Pink"],"price":108000,"weight":0,"compare_at_price":null,"inventory_quantity":0,"inventory_management":null,"inventory_policy":"deny","barcode":"CCN013260J-AAR08","featured_media":{"alt":null,"id":26113609924707,"position":1,"preview_image":{"aspect_ratio":1.0,"height":2000,"width":2000,"src":"\/\/b2b.rhinoshield.tw\/cdn\/shop\/files\/f6d956f7449fce5c6e3d4c08b04282e799fecf13.webp?v=1759371214"}},"requires_selling_plan":false,"selling_plan_allocations":[],"quantity_rule":{"min":1,"max":null,"increment":1}},{"id":43756802801763,"title":"Ash Black","option1":"Ash Black","option2":null,"option3":null,"sku":"CCN013260G-AAR08","requires_shipping":true,"taxable":true,"featured_image":{"id":34543855173731,"product_id":7892694728803,"position":2,"created_at":"2025-10-02T10:13:33+08:00","updated_at":"2025-10-02T10:13:35+08:00","alt":null,"width":2000,"height":2000,"src":"\/\/b2b.rhinoshield.tw\/cdn\/shop\/files\/d7c36010382039070502df3b33718babfc50dfdd.webp?v=1759371215","variant_ids":[43756802801763]},"available":true,"name":"iPhone 16 Plus Clear Aaron Chang Waiting for - Ash Black","public_title":"Ash Black","options":["Ash Black"],"price":108000,"weight":0,"compare_at_price":null,"inventory_quantity":0,"inventory_management":null,"inventory_policy":"deny","barcode":"CCN013260G-AAR08","featured_media":{"alt":null,"id":26113610055779,"position":2,"preview_image":{"aspect_ratio":1.0,"height":2000,"width":2000,"src":"\/\/b2b.rhinoshield.tw\/cdn\/shop\/files\/d7c36010382039070502df3b33718babfc50dfdd.webp?v=1759371215"}},"requires_selling_plan":false,"selling_plan_allocations":[],"quantity_rule":{"min":1,"max":null,"increment":1}}],"images":["\/\/b2b.rhinoshield.tw\/cdn\/shop\/files\/f6d956f7449fce5c6e3d4c08b04282e799fecf13.webp?v=1759371214","\/\/b2b.rhinoshield.tw\/cdn\/shop\/files\/d7c36010382039070502df3b33718babfc50dfdd.webp?v=1759371215"],"featured_image":"\/\/b2b.rhinoshield.tw\/cdn\/shop\/files\/f6d956f7449fce5c6e3d4c08b04282e799fecf13.webp?v=1759371214","options":["color"],"media":[{"alt":null,"id":26113609924707,"position":1,"preview_image":{"aspect_ratio":1.0,"height":2000,"width":2000,"src":"\/\/b2b.rhinoshield.tw\/cdn\/shop\/files\/f6d956f7449fce5c6e3d4c08b04282e799fecf13.webp?v=1759371214"},"aspect_ratio":1.0,"height":2000,"media_type":"image","src":"\/\/b2b.rhinoshield.tw\/cdn\/shop\/files\/f6d956f7449fce5c6e3d4c08b04282e799fecf13.webp?v=1759371214","width":2000},{"alt":null,"id":26113610055779,"position":2,"preview_image":{"aspect_ratio":1.0,"height":2000,"width":2000,"src":"\/\/b2b.rhinoshield.tw\/cdn\/shop\/files\/d7c36010382039070502df3b33718babfc50dfdd.webp?v=1759371215"},"aspect_ratio":1.0,"height":2000,"media_type":"image","src":"\/\/b2b.rhinoshield.tw\/cdn\/shop\/files\/d7c36010382039070502df3b33718babfc50dfdd.webp?v=1759371215","width":2000}],"requires_selling_plan":false,"selling_plan_groups":[],"content":null}; $bumper = null; $variants = [{"id":43756801458275,"title":"Fancy Pink","option1":"Fancy Pink","option2":null,"option3":null,"sku":"CCN013260J-AAR08","requires_shipping":true,"taxable":true,"featured_image":{"id":34543855042659,"product_id":7892694728803,"position":1,"created_at":"2025-10-02T10:13:32+08:00","updated_at":"2025-10-02T10:13:34+08:00","alt":null,"width":2000,"height":2000,"src":"\/\/b2b.rhinoshield.tw\/cdn\/shop\/files\/f6d956f7449fce5c6e3d4c08b04282e799fecf13.webp?v=1759371214","variant_ids":[43756801458275]},"available":true,"name":"iPhone 16 Plus Clear Aaron Chang Waiting for - Fancy Pink","public_title":"Fancy Pink","options":["Fancy Pink"],"price":108000,"weight":0,"compare_at_price":null,"inventory_quantity":0,"inventory_management":null,"inventory_policy":"deny","barcode":"CCN013260J-AAR08","featured_media":{"alt":null,"id":26113609924707,"position":1,"preview_image":{"aspect_ratio":1.0,"height":2000,"width":2000,"src":"\/\/b2b.rhinoshield.tw\/cdn\/shop\/files\/f6d956f7449fce5c6e3d4c08b04282e799fecf13.webp?v=1759371214"}},"requires_selling_plan":false,"selling_plan_allocations":[],"quantity_rule":{"min":1,"max":null,"increment":1}},{"id":43756802801763,"title":"Ash Black","option1":"Ash Black","option2":null,"option3":null,"sku":"CCN013260G-AAR08","requires_shipping":true,"taxable":true,"featured_image":{"id":34543855173731,"product_id":7892694728803,"position":2,"created_at":"2025-10-02T10:13:33+08:00","updated_at":"2025-10-02T10:13:35+08:00","alt":null,"width":2000,"height":2000,"src":"\/\/b2b.rhinoshield.tw\/cdn\/shop\/files\/d7c36010382039070502df3b33718babfc50dfdd.webp?v=1759371215","variant_ids":[43756802801763]},"available":true,"name":"iPhone 16 Plus Clear Aaron Chang Waiting for - Ash Black","public_title":"Ash Black","options":["Ash Black"],"price":108000,"weight":0,"compare_at_price":null,"inventory_quantity":0,"inventory_management":null,"inventory_policy":"deny","barcode":"CCN013260G-AAR08","featured_media":{"alt":null,"id":26113610055779,"position":2,"preview_image":{"aspect_ratio":1.0,"height":2000,"width":2000,"src":"\/\/b2b.rhinoshield.tw\/cdn\/shop\/files\/d7c36010382039070502df3b33718babfc50dfdd.webp?v=1759371215"}},"requires_selling_plan":false,"selling_plan_allocations":[],"quantity_rule":{"min":1,"max":null,"increment":1}}]; $defaultVariant = {"id":43756801458275,"title":"Fancy Pink","option1":"Fancy Pink","option2":null,"option3":null,"sku":"CCN013260J-AAR08","requires_shipping":true,"taxable":true,"featured_image":{"id":34543855042659,"product_id":7892694728803,"position":1,"created_at":"2025-10-02T10:13:32+08:00","updated_at":"2025-10-02T10:13:34+08:00","alt":null,"width":2000,"height":2000,"src":"\/\/b2b.rhinoshield.tw\/cdn\/shop\/files\/f6d956f7449fce5c6e3d4c08b04282e799fecf13.webp?v=1759371214","variant_ids":[43756801458275]},"available":true,"name":"iPhone 16 Plus Clear Aaron Chang Waiting for - Fancy Pink","public_title":"Fancy Pink","options":["Fancy Pink"],"price":108000,"weight":0,"compare_at_price":null,"inventory_quantity":0,"inventory_management":null,"inventory_policy":"deny","barcode":"CCN013260J-AAR08","featured_media":{"alt":null,"id":26113609924707,"position":1,"preview_image":{"aspect_ratio":1.0,"height":2000,"width":2000,"src":"\/\/b2b.rhinoshield.tw\/cdn\/shop\/files\/f6d956f7449fce5c6e3d4c08b04282e799fecf13.webp?v=1759371214"}},"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: "停產" }