var productImages = [];
// Preloaded image. ID = 1415
productImages[1415] = new Image();
productImages[1415].src="/image/product/medium/black-profile-7.jpg";
productImages[1415].alt = "Otis Bubba Black with Cool Grey Lens";
// Preloaded image. ID = 1416
productImages[1416] = new Image();
productImages[1416].src="/image/product/medium/black-front-7.jpg";
productImages[1416].alt = "Otis Bubba Black with Cool Grey Lens";
// Preloaded image. ID = 1417
productImages[1417] = new Image();
productImages[1417].src="/image/product/medium/black-side-7.jpg";
productImages[1417].alt = "Otis Bubba Black with Cool Grey Lens";
// Preloaded image. ID = 1954
productImages[1954] = new Image();
productImages[1954].src="/image/product/medium/flames-profile.jpg";
productImages[1954].alt = "Otis Bubba Flames with Cool Grey Lens";
// Preloaded image. ID = 1955
productImages[1955] = new Image();
productImages[1955].src="/image/product/medium/flames-front.jpg";
productImages[1955].alt = "Otis Bubba Flames with Cool Grey Lens";
// Preloaded image. ID = 1956
productImages[1956] = new Image();
productImages[1956].src="/image/product/medium/flames-side.jpg";
productImages[1956].alt = "Otis Bubba Flames with Cool Grey Lens";
// Preloaded image. ID = 1957
productImages[1957] = new Image();
productImages[1957].src="/image/product/medium/goldwire-profile.jpg";
productImages[1957].alt = "Otis Bubba Gold Wire with Tropical Brown Lens";
// Preloaded image. ID = 1958
productImages[1958] = new Image();
productImages[1958].src="/image/product/medium/goldwire-front.jpg";
productImages[1958].alt = "Otis Bubba Gold Wire with Tropical Brown Lens";
// Preloaded image. ID = 1959
productImages[1959] = new Image();
productImages[1959].src="/image/product/medium/goldwire-side.jpg";
productImages[1959].alt = "Otis Bubba Gold Wire with Tropical Brown Lens";
// Preloaded image. ID = 1988
productImages[1988] = new Image();
productImages[1988].src="/image/product/medium/black-profile-10.jpg";
productImages[1988].alt = "Otis Bubba Black with Grey Polarised Lens";
// Preloaded image. ID = 1989
productImages[1989] = new Image();
productImages[1989].src="/image/product/medium/black-front-10.jpg";
productImages[1989].alt = "Otis Bubba Black with Grey Polarised Lens";
// Preloaded image. ID = 1990
productImages[1990] = new Image();
productImages[1990].src="/image/product/medium/black-side-10.jpg";
productImages[1990].alt = "Otis Bubba Black with Grey Polarised Lens";
var productData = [];
var fromPrice = new Array();
var fromMemberPrice = new Array();
productData[2192] = [{19: 1396}, {"price":319.95, "memberPrice":319.95, "exception":'FALSE', "isSpecial":'FALSE', "specialPrice":319.95, "stock":0, "imageId":1415} ];
fromPrice[2192] = 319.95;
fromMemberPrice[2192] = 319.95;
productData[2196] = [{19: 1400}, {"price":199.95, "memberPrice":199.95, "exception":'FALSE', "isSpecial":'FALSE', "specialPrice":199.95, "stock":0, "imageId":1954} ];
fromPrice[2196] = 199.95;
fromMemberPrice[2196] = 199.95;
productData[2799] = [{19: 1404}, {"price":199.95, "memberPrice":199.95, "exception":'FALSE', "isSpecial":'FALSE', "specialPrice":199.95, "stock":0, "imageId":1415} ];
fromPrice[2799] = 199.95;
fromMemberPrice[2799] = 199.95;
productData[2800] = [{19: 1783}, {"price":199.95, "memberPrice":199.95, "exception":'FALSE', "isSpecial":'FALSE', "specialPrice":199.95, "stock":0, "imageId":1957} ];
fromPrice[2800] = 199.95;
fromMemberPrice[2800] = 199.95;
var attribSets = [19];
// 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 '';
}