var productImages = [];
// Preloaded image. ID = 118
productImages[118] = new Image();
productImages[118].src="/image/product/medium/serpico_gold_brown.jpg";
productImages[118].alt = "Smith Serpico sunglasses Gold Frame Brown Lens";
// Preloaded image. ID = 119
productImages[119] = new Image();
productImages[119].src="/image/product/medium/serpico_gunmetal_gray.jpg";
productImages[119].alt = "Smith Serpico sunglasses Gunmetal Frame Grey Lens";
// Preloaded image. ID = 120
productImages[120] = new Image();
productImages[120].src="/image/product/medium/serpico_silver_platinum.jpg";
productImages[120].alt = "Smith Serpico sunglasses Silver Frame Platinum Lens";
// Preloaded image. ID = 121
productImages[121] = new Image();
productImages[121].src="/image/product/medium/serpico_silver_platinum2.jpg";
productImages[121].alt = "Smith Serpico sunglasses Silver Frame Polar Platinum Lens";
// Preloaded image. ID = 1066
productImages[1066] = new Image();
productImages[1066].src="/image/product/medium/serpico_gold_brown_large.jpg";
productImages[1066].alt = "Smith Optics Serpico Gold with Polarised Brown lens.";
// Preloaded image. ID = 2421
productImages[2421] = new Image();
productImages[2421].src="/image/product/medium/serpico_pastranaplaid_gray_cmyk_large.jpg";
productImages[2421].alt = "Smith Optics Serpico Pastrana Signature with Grey Lens";
var productData = [];
var fromPrice = new Array();
var fromMemberPrice = new Array();
productData[120] = [{1: 70}, {"price":179.95, "memberPrice":179.95, "exception":'FALSE', "isSpecial":'FALSE', "specialPrice":179.95, "stock":0, "imageId":118} ];
fromPrice[120] = 179.95;
fromMemberPrice[120] = 179.95;
productData[121] = [{1: 73}, {"price":179.95, "memberPrice":179.95, "exception":'FALSE', "isSpecial":'FALSE', "specialPrice":179.95, "stock":0, "imageId":120} ];
fromPrice[121] = 179.95;
fromMemberPrice[121] = 179.95;
productData[122] = [{1: 74}, {"price":179.95, "memberPrice":179.95, "exception":'FALSE', "isSpecial":'FALSE', "specialPrice":179.95, "stock":0, "imageId":119} ];
fromPrice[122] = 179.95;
fromMemberPrice[122] = 179.95;
productData[123] = [{1: 75}, {"price":199.95, "memberPrice":199.95, "exception":'FALSE', "isSpecial":'FALSE', "specialPrice":199.95, "stock":0, "imageId":121} ];
fromPrice[123] = 199.95;
fromMemberPrice[123] = 199.95;
productData[1475] = [{1: 1198}, {"price":199.95, "memberPrice":199.95, "exception":'FALSE', "isSpecial":'FALSE', "specialPrice":199.95, "stock":0, "imageId":1066} ];
fromPrice[1475] = 199.95;
fromMemberPrice[1475] = 199.95;
productData[3283] = [{1: 2049}, {"price":199.95, "memberPrice":199.95, "exception":'FALSE', "isSpecial":'FALSE', "specialPrice":199.95, "stock":0, "imageId":0} ];
fromPrice[3283] = 199.95;
fromMemberPrice[3283] = 199.95;
var attribSets = [1];
// Find the variant selected.
function findVariant()
{
found = false; // Found flag.
variantIndex = 0; // The index of the found variant element.
// This just scans for a match and if found it sets the flags and breaks.
// If one mismatch is detected it just breaks the loop.
for (variant in productData) // Loop through the variant array, called 'productData'.
{
for (set in attribSets) // Now loop through the sets.
{
// Get a refference to a attribute set select box.
attrib = document.getElementById("attributes"+attribSets[set]);
// Check to see if the value of that attribute select box is in the productData attribute array.
if (productData[variant][0][attribSets[set]]==attrib.value) { found = true; } else { found = false; break; }
}
if (found==true) { variantIndex = variant; break; }
}
if (variantIndex!=0)
{
var data = productData[variantIndex][1];
data["var_id"] = variantIndex;
return data;
}
else { return false; }
}
// This enables and disables the submit button.
function submitButtonEnable(enabled)
{
if (enabled==false) { document.getElementById("submitButton").disabled = true; }
else { document.getElementById("submitButton").disabled = false; }
}
function specialRowEnabled(enable) {
if (enable==false) {
document.getElementById("specialRow").style.display="none";
document.getElementById("memberPriceRow").style.display="block";
}
else {
document.getElementById("specialRow").style.display="block";
document.getElementById("memberPriceRow").style.display="none";
}
}
// Display stock indicator
function displayStock() {
// Don't show stock
return true;
// Get the selected variant.
variant = findVariant();
if (variant["stock"] < 0) {
stockString = "Made upon ordering";
}
else if (variant["stock"] ==0) {
stockString = "Out of stock";
}
else if (variant["stock"] > 0) {
stockString = "In stock & ready to ship";
}
document.getElementById("stock").innerHTML = stockString;
}
// This is the function that gets called when the user changes the selection.
function changeVariant() {
var member = false;
// Get the selected variant.
variant = findVariant();
// Not a variant, show a from price and disable add to cart
if(!variant) {
var toprice = getToPrice();
var fromprice = getFromPrice();
if(toprice == fromprice)
{
document.getElementById("price").innerHTML = "RRP from AUD$ " + fromprice;
}
else
{
document.getElementById("price").innerHTML = "RRP from AUD$ " + fromprice + " to AUD$ " + toprice;
}
if(member) {
document.getElementById("memberPrice").innerHTML = "";
}
submitButtonEnable(false);
specialRowEnabled(false);
}
// Check if it is an exception.
else if (variant["exception"]=="FALSE") { // See if it is on special.
if (variant["isSpecial"]=="TRUE")
{ // Display the special price with the old price with strike through font.
document.getElementById("price").innerHTML = "RRP: AUD$ " + variant["price"].toFixed(2) + "";
document.getElementById("specialPrice").innerHTML = variant["specialPrice"].toFixed(2) + getDiscountPercentage(variant["price"], variant["specialPrice"]);
specialRowEnabled(true);
} // Just show the normal price.
else
{
if(member) {
document.getElementById("price").innerHTML = "RRP: AUD$ " + variant["price"].toFixed(2) + "";
}
else {
document.getElementById("price").innerHTML = "RRP: AUD$ " + variant["price"].toFixed(2);
}
specialRowEnabled(false);
}
if(member) {
document.getElementById("memberPrice").innerHTML = "Member's Price: AUD$ " + variant["memberPrice"].toFixed(2) + getDiscountPercentage(variant["price"], variant["memberPrice"]);
}
// Stock
displayStock();
if (variant["imageId"]!=0)
{
// Swapping image was confusing the users
//swapImage(variant["imageId"]);
}
submitButtonEnable(true); // Enable the submit button.
}
else {
// Variant must be an exception so display some text and disable the submit button.
document.getElementById("price").innerHTML = "Not Available";
document.getElementById("memberPrice").innerHTML = "";
submitButtonEnable(false);
specialRowEnabled(false);
}
}
function swapImage(image) {
document.prodImageMain.src = productImages[image].src;
document.getElementById("prodImageMainAlt").innerHTML = productImages[image].alt;
}
/**
* Sort the prices for the product
* @return lowest price
*/
function getFromPrice() {
fromPrice.sort(function(a,b){return a - b});
return fromPrice[0].toFixed(2);
}
/**
* Sort the prices for the product
* @return highest price
*/
function getToPrice() {
fromPrice.sort(function(a,b){return b - a});
return fromPrice[0].toFixed(2);
}
/**
* Percentage off
* @param price Original product price
* @param specialPrice on special/sale price
* @return Str Text string displaying percentage if percentage is greater than 0%
*/
function getDiscountPercentage(price, specialPrice) {
var discount;
// Make sure there is a difference in price
if(price - specialPrice <= 0) {
return ' (No Discount)';
}
discount = ((price - specialPrice)/price)*100;
discount = Math.round(discount);
if(discount > 0) {
return ' (' + discount + '% off)'
}
return '';
}