//=====================================================================||
//               NOP Design JavaScript Shopping Cart                   ||
//                                                                     ||
// For more information on SmartSystems, or how NOPDesign can help you ||
// Please visit us on the WWW at http://www.nopdesign.com              ||
//                                                                     ||
// Javascript portions of this shopping cart software are available as ||
// freeware from NOP Design.  You must keep this comment unchanged in  ||
// your code.  For more information contact FreeCart@NopDesign.com.    ||
//                                                                     ||
// JavaScript Shop Module, V.4.4.0                                     ||
//=====================================================================||

//---------------------------------------------------------------------||
//                       Global Options                                ||
//                      ----------------                               ||
// Shopping Cart Options, you can modify these options to change the   ||
// the way the cart functions.                                         ||
//                                                                     ||
// Language Packs                                                      ||
// ==============                                                      ||
// You may include any language pack before nopcart.js in your HTML    ||
// pages to change the language.  Simply include a language pack with  ||
// a script src BEFORE the <SCRIPT SRC="nopcart.js">... line.          ||
//  For example: <SCRIPT SRC="language-en.js"></SCRIPT>                ||
//                                                                     ||
// Options For Everyone:                                               ||
// =====================                                               ||
// * MonetarySymbol: string, the symbol which represents dollars/euro, ||
//   in your locale.                                                   ||
// * DisplayNotice: true/false, controls whether the user is provided  ||
//   with a popup letting them know their product is added to the cart ||
// * DisplayShippingColumn: true/false, controls whether the managecart||
//   and checkout pages display shipping cost column.                  ||
// * DisplayShippingRow: true/false, controls whether the managecart   ||
//   and checkout pages display shipping cost total row.               ||
// * DisplayTaxRow: true/false, controls whether the managecart        ||
//   and checkout pages display tax cost total row.                    ||
// * TaxRate: number, your area's current tax rate, ie: if your tax    ||
//   rate was 7.5%, you would set TaxRate = 0.075                      ||
// * TaxByRegion: true/false, when set to true, the user is prompted   ||
//   with TaxablePrompt to determine if they should be charged tax.    ||
//   In the USA, this is useful to charge tax to those people who live ||
//   in a particular state, but no one else.                           ||
// * TaxPrompt: string, popup message if user has not selected either  ||
//   taxable or nontaxable when TaxByRegion is set to true.            ||
// * TaxablePrompt: string, the message the user is prompted with to   ||
//   select if they are taxable.  If TaxByRegion is set to false, this ||
//   has no effect. Example: 'Arizona Residents'                       ||
// * NonTaxablePrompt: string, same as above, but the choice for non-  ||
//   taxable people.  Example: 'Other States'                          ||
// * MinimumOrder: number, the minium dollar amount that must be       ||
//   purchased before a user is allowed to checkout.  Set to 0.00      ||
//   to disable.                                                       ||
// * MinimumOrderPrompt: string, Message to prompt users with when     ||
//   they have not met the minimum order amount.                       ||
//                                                                     ||
// Payment Processor Options:                                          ||
// ==========================                                          ||
// * PaymentProcessor: string, the two digit payment processor code    ||
//   for support payment processor gateways.  Setting this field to    ||
//   anything other than an empty string will override your OutputItem ||
//   settings -- so please be careful when receiving any form data.    ||
//   Support payment processor gateways are:                           ||
//    * Authorize.net (an)                                             ||
//    * Worldpay      (wp)                                             ||
//    * LinkPoint     (lp)
//                                                                     ||
// Options For Programmers:                                            ||
// ========================                                            ||
// * OutputItem<..>: string, the name of the pair value passed at      ||
//   checkouttime.  Change these only if you are connecting to a CGI   ||
//   script and need other field names, or are using a secure service  ||
//   that requires specific field names.                               ||
// * AppendItemNumToOutput: true/false, if set to true, the number of  ||
//   each ordered item will be appended to the output string.  For     ||
//   example if OutputItemId is 'ID_' and this is set to true, the     ||
//   output field name will be 'ID_1', 'ID_2' ... for each item.       ||
// * HiddenFieldsToCheckout: true/false, if set to true, hidden fields ||
//   for the cart items will be passed TO the checkout page, from the  ||
//   ManageCart page.  This is set to true for CGI/PHP/Script based    ||
//   checkout pages, but should be left false if you are using an      ||
//   HTML/Javascript Checkout Page. Hidden fields will ALWAYS be       ||
//   passed FROM the checkout page to the Checkout CGI/PHP/ASP/Script  ||
//---------------------------------------------------------------------||

//-------------Revision History (added 1/23/2010)----------------------||
// 1/23/2010 - Rev 6 - set cookie domain to "weddingveil.com"
//    * Previous version (rev 5): nopcart_2010_0123.js
//	  * Author: Paul Huang
//	  * Changes made in this revision:  hard-coded domain value to all
//			cookie methods.  This will allow items added to the shopping
//			cart from www.weddingveil.com and weddingveil.com to use the
//			same cookie.  This resolves the problem of having different
//			cart contents when coming in from one vs the other server name
//			* methods affected: SetCookie, DeleteCookie
//			* Notes: changes to cookies methods may take a little while
//					 to update on server-cache.  Or perhaps it's the 
//					 browser caching (of the js files) that take some time 
//					 to expire.
//					 Tested on Firefox 3 and IE6			
//---------------------------------------------------------------------||

//Options for Everyone:
MonetarySymbol        = '$';
DisplayNotice         = true;
DisplayShippingColumn = false;
DisplayShippingRow    = true; //Changed 1/17/05 9:06pm. To add the shipping row.
DisplayTaxRow         = true;
TaxRate               = 0.00;
TaxByRegion           = false;
TaxPrompt             = 'For tax purposes, please select if you are an Arizona resident before continuing';
TaxablePrompt         = 'Arizona Residents';
NonTaxablePrompt      = 'Other States';
MinimumOrder          = 0.00;
MinimumOrderPrompt    = 'Your order is below our minimum order, please order more before checking out.';

//Payment Processor Options:
PaymentProcessor      = '';

//Options for Programmers:
OutputItemId          = 'ID_';
OutputItemQuantity    = 'QUANTITY_';
OutputItemPrice       = 'PRICE_';
OutputItemName        = 'NAME_';
OutputItemShipping    = 'SHIPPING_';
OutputItemAddtlInfo   = 'ADDTLINFO_';
OutputOrderSubtotal   = 'SUBTOTAL';
OutputOrderShipping   = 'SHIPPING';
OutputOrderTax        = 'TAX';
OutputOrderTotal      = 'TOTAL';

AppendItemNumToOutput = true;
HiddenFieldsToCheckout = false;


//=====================================================================||
//---------------------------------------------------------------------||
//    YOU DO NOT NEED TO MAKE ANY MODIFICATIONS BELOW THIS LINE        ||
//---------------------------------------------------------------------||
//=====================================================================||


//---------------------------------------------------------------------||
//                      Language Strings                               ||
//                     ------------------                              ||
// These strings will not be used unless you have not included a       ||
// language pack already.  You should NOT modify these, but instead    ||
// modify the strings in language-**.js where ** is the language pack  ||
// you are using.                                                      ||
//---------------------------------------------------------------------||
if ( !bLanguageDefined ) {
   strSorry  = "I'm Sorry, your cart is full, please proceed to checkout.";
   strAdded  = " added to your shopping cart.";
   strRemove = "Click 'Ok' to remove this product from your shopping cart.";
   strILabel = "Product Id";
   strDLabel = "Product Name/Description";
   strColorLabel= "Color";
   //strPersonalized="Personalized";
   strStoreLabel="Store";
   strQLabel = "Quantity";
   strPLabel = "Price";
   strSLabel = "Shipping";
   strRLabel = "Remove From Cart";
   strRButton= "Remove";
   strSUB    = "SUBTOTAL";
   strSHIP   = "SHIPPING";
   strTAX    = "TAX";
   strTOT    = "TOTAL";
   strErrQty = "Invalid Quantity.";
   strNewQty = 'Please enter new quantity:';
   bLanguageDefined = true;
}

//---------------------------------------------------------------------||
// FUNCTION:    ReplaceStr                                             ||
// PARAMETERS:  StrSource,StrFind,StrReplace                           ||
// RETURNS:     String with the Str replaced			               ||
// PURPOSE:     Got from the web 9/2/04 to replace double quotes with  ||
//				html equivalent &quot;						           ||
//---------------------------------------------------------------------||
function ReplaceStr(StrSource,StrFind,StrReplace)
	{
		//alert ('calling paul');
		var StrReplacedContent="";
		var FindPos;
		var StrOriginal=new String(StrSource).toString();
		var StrOriginalSource=new String(StrSource);
		var FindPos=StrOriginalSource.toString().indexOf(StrFind);
		while(FindPos>-1)
			{

				StrReplacedContent+= StrOriginal.substring(0,FindPos) + StrReplace;
				StrOriginalSource=StrOriginalSource.substring(FindPos+StrFind.length);
				StrOriginal=StrOriginal.substring(FindPos+StrFind.length);
				FindPos=StrOriginalSource.indexOf(StrFind);
			}
		StrReplacedContent+=StrOriginalSource;
		return StrReplacedContent;
	}
	
//---------------------------------------------------------------------||
// FUNCTION:    CKquantity                                             ||
// PARAMETERS:  Quantity to                                            ||
// RETURNS:     Quantity as a number, and possible alert               ||
// PURPOSE:     Make sure quantity is represented as a number          ||
//---------------------------------------------------------------------||
function CKquantity(checkString) {
   var strNewQuantity = "";

   for ( i = 0; i < checkString.length; i++ ) {
      ch = checkString.substring(i, i+1);
      if ( (ch >= "0" && ch <= "9") || (ch == '.') )
         strNewQuantity += ch;
   }

   if ( strNewQuantity.length < 1 )
      strNewQuantity = "1";

   return(strNewQuantity);
}


//---------------------------------------------------------------------||
// FUNCTION:    AddToCart                                              ||
// PARAMETERS:  Form Object                                            ||
// RETURNS:     Cookie to user's browser, with prompt                  ||
// PURPOSE:     Adds a product to the user's shopping cart             ||
//---------------------------------------------------------------------||
function AddToCart(thisForm) {
  strAdded  = " added to your shopping cart.";
   var iNumberOrdered = 0;
   var bAlreadyInCart = false;
   var notice = "";
   iNumberOrdered = GetCookie("NumberOrdered");
   strStoreName="Wedding Veil";
   if ( iNumberOrdered == null )
      iNumberOrdered = 0;

   if ( thisForm.ID_NUM == null )
      strID_NUM    = "";
   else
      strID_NUM    = thisForm.ID_NUM.value;

   if ( thisForm.QUANTITY == null )
      strQUANTITY  = "1";
   else
      strQUANTITY  = thisForm.QUANTITY.value;

   if ( thisForm.PRICE == null )
      strPRICE     = "0.00";
   else
      strPRICE     = thisForm.PRICE.value;

   if ( thisForm.NAME == null )
      strNAME      = "";
   else
      strNAME      = "";

   if ( thisForm.SHIPPING == null )
      strSHIPPING  = "0.00";
   else
      strSHIPPING  = thisForm.SHIPPING.value;
 
	
   if ( thisForm.ADDITIONALINFO == null ) {
      strColor= "";
   } else {
      strColor= thisForm.ADDITIONALINFO.value;
   }
   if ( thisForm.ADDITIONALINFO2 != null ) {
		strADDTLINFO =thisForm.ADDITIONALINFO2.value;
   }
	if ( thisForm.ADDITIONALINFO5 != null ) {
      	strADDTLINFO += " " + thisForm.ADDITIONALINFO5.value;
   }   
if ( thisForm.ADDITIONALINFO3 != null ) {
	if( thisForm.ADDITIONALINFO3.value != "None") {
	      strADDTLINFO += " " + thisForm.ADDITIONALINFO3.value;
	}
   }
   if ( thisForm.ADDITIONALINFO4 != null ) {
	if( thisForm.ADDITIONALINFO4.value != "None") {
	      strADDTLINFO += " " + thisForm.ADDITIONALINFO4.value;
	}
   }
  
strNAME=strADDTLINFO;

   //Is this product already in the cart?  If so, increment quantity instead of adding another.
   for ( i = 1; i <= iNumberOrdered; i++ ) {
      NewOrder = "Order." + i;
	  database = "";
      database = GetCookie(NewOrder);
	 
	  Token0 = database.indexOf("|", 0);
      Token1 = database.indexOf("|", Token0+1);
      Token2 = database.indexOf("|", Token1+1);
      Token3 = database.indexOf("|", Token2+1);
      Token4 = database.indexOf("|", Token3+1);
	Token5 = database.indexOf("|", Token4+1);
	Token6 = database.indexOf("|", Token5+1);


      fields = new Array;
      fields[0] = database.substring( 0, Token0 );
      fields[1] = database.substring( Token0+1, Token1 );
      fields[2] = database.substring( Token1+1, Token2 );
      fields[3] = database.substring( Token2+1, Token3 );
      fields[4] = database.substring( Token3+1, Token4 );
      fields[5] = database.substring( Token4+1, Token5 );
	fields[6]=  database.substring( Token5+1, Token6);
	fields[7]=  database.substring( Token6+1,database.length);

      if ( fields[0] == strID_NUM &&
           fields[2] == strPRICE  &&
           fields[3] == strNAME   &&
           fields[5] == strADDTLINFO   &&	
	     fields[6] == strColor &&
           fields[7] == strStoreName	
         ) {
         bAlreadyInCart = true;
         dbUpdatedOrder = strID_NUM    + "|" +
                          (parseInt(strQUANTITY)+parseInt(fields[1]))  + "|" +
                          strPRICE     + "|" +
                          strNAME      + "|" +
                          strSHIPPING  + "|" +
                          strADDTLINFO + "|" +
				  strColor	   + "|" +
                          strStoreName;
         strNewOrder = "Order." + i;
         DeleteCookie(strNewOrder, "/");
         SetCookie(strNewOrder, dbUpdatedOrder, null, "/");
         notice = strQUANTITY + " " +  strNAME + strAdded;
         break;
      }
   }


   if ( !bAlreadyInCart ) {
      iNumberOrdered++;

      if ( iNumberOrdered > 12 )
         alert( strSorry );
      else {
         dbUpdatedOrder = strID_NUM    + "|" + 
                          strQUANTITY  + "|" +
                          strPRICE     + "|" +
                          strNAME      + "|" +
                          strSHIPPING  + "|" +
                          strADDTLINFO + "|" +
                          strColor	   + "|" +
                          strStoreName;

         strNewOrder = "Order." + iNumberOrdered;
         SetCookie(strNewOrder, dbUpdatedOrder, null, "/");
         SetCookie("NumberOrdered", iNumberOrdered, null, "/");
         notice = strQUANTITY + " " + strNAME+ strAdded;
      }
   }

   if ( DisplayNotice )
	{
		notice = ReplaceStr(notice, '&quot;', '"'); //added 9/8/04 so the pop-up message shows
													//the inch symbol " correctly.	
         alert(notice);
	}
}


//---------------------------------------------------------------------||
// FUNCTION:    getCookieVal                                           ||
// PARAMETERS:  offset                                                 ||
// RETURNS:     URL unescaped Cookie Value                             ||
// PURPOSE:     Get a specific value from a cookie                     ||
//---------------------------------------------------------------------||
function getCookieVal (offset) {
   var endstr = document.cookie.indexOf (";", offset);

   if ( endstr == -1 )
      endstr = document.cookie.length;
   return(unescape(document.cookie.substring(offset, endstr)));
}


//---------------------------------------------------------------------||
// FUNCTION:    FixCookieDate                                          ||
// PARAMETERS:  date                                                   ||
// RETURNS:     date                                                   ||
// PURPOSE:     Fixes cookie date, stores back in date                 ||
//---------------------------------------------------------------------||
function FixCookieDate (date) {
   var base = new Date(0);
   var skew = base.getTime();

   date.setTime (date.getTime() - skew);
}


//---------------------------------------------------------------------||
// FUNCTION:    GetCookie                                              ||
// PARAMETERS:  Name                                                   ||
// RETURNS:     Value in Cookie                                        ||
// PURPOSE:     Retrieves cookie from users browser                    ||
//---------------------------------------------------------------------||
function GetCookie (name) {
   var arg = name + "=";
   var alen = arg.length;
   var clen = document.cookie.length;
   var i = 0;
   while ( i < clen ) {
      var j = i + alen;
      if ( document.cookie.substring(i, j) == arg ) return(getCookieVal (j));
      i = document.cookie.indexOf(" ", i) + 1;
      if ( i == 0 ) break;
   }

   return(null);
}


//---------------------------------------------------------------------||
// FUNCTION:    SetCookie                                              ||
// PARAMETERS:  name, value, expiration date, path, domain, security   ||
// RETURNS:     Null                                                   ||
// PURPOSE:     Stores a cookie in the users browser                   ||
//---------------------------------------------------------------------||
function SetCookie (name,value,expires,path,domain,secure) {
	domain = "weddingveil.com"; //PH, added 1/23/2010
   document.cookie = name + "=" + escape (value) +
                     ((expires) ? "; expires=" + expires.toGMTString() : "") +
                     ((path) ? "; path=" + path : "") +
                     ((domain) ? "; domain=" + domain : "") +
                     ((secure) ? "; secure" : "");
}


//---------------------------------------------------------------------||
// FUNCTION:    DeleteCookie                                           ||
// PARAMETERS:  Cookie name, path, domain                              ||
// RETURNS:     null                                                   ||
// PURPOSE:     Removes a cookie from users browser.                   ||
//---------------------------------------------------------------------||
function DeleteCookie (name,path,domain) {
	domain = "weddingveil.com"; //PH, added 1/23/2010
   if ( GetCookie(name) ) {
      document.cookie = name + "=" +
                        ((path) ? "; path=" + path : "") +
                        ((domain) ? "; domain=" + domain : "") +
                        "; expires=Thu, 01-Jan-70 00:00:01 GMT";
   }
}


//---------------------------------------------------------------------||
// FUNCTION:    MoneyFormat                                            ||
// PARAMETERS:  Number to be formatted                                 ||
// RETURNS:     Formatted Number                                       ||
// PURPOSE:     Reformats Dollar Amount to #.## format                 ||
//---------------------------------------------------------------------||
function moneyFormat(input) {
   var dollars = Math.floor(input);
   var tmp = new String(input);

   for ( var decimalAt = 0; decimalAt < tmp.length; decimalAt++ ) {
      if ( tmp.charAt(decimalAt)=="." )
         break;
   }

   var cents  = "" + Math.round(input * 100);
   cents = cents.substring(cents.length-2, cents.length)
           dollars += ((tmp.charAt(decimalAt+2)=="9")&&(cents=="00"))? 1 : 0;

   if ( cents == "0" )
      cents = "00";

   return(dollars + "." + cents);
}


//---------------------------------------------------------------------||
// FUNCTION:    RemoveFromCart                                         ||
// PARAMETERS:  Order Number to Remove                                 ||
// RETURNS:     Null                                                   ||
// PURPOSE:     Removes an item from a users shopping cart             ||
//---------------------------------------------------------------------||
function RemoveFromCart(RemOrder) {
   if ( confirm( strRemove ) ) {
      NumberOrdered = GetCookie("NumberOrdered");
      for ( i=RemOrder; i < NumberOrdered; i++ ) {
         NewOrder1 = "Order." + (i+1);
         NewOrder2 = "Order." + (i);
         database = GetCookie(NewOrder1);
         SetCookie (NewOrder2, database, null, "/");
      }
      NewOrder = "Order." + NumberOrdered;
      SetCookie ("NumberOrdered", NumberOrdered-1, null, "/");
      DeleteCookie(NewOrder, "/");
      location.href=location.href;
   }
}


//---------------------------------------------------------------------||
// FUNCTION:    ChangeQuantity                                         ||
// PARAMETERS:  Order Number to Change Quantity                        ||
// RETURNS:     Null                                                   ||
// PURPOSE:     Changes quantity of an item in the shopping cart       ||
//---------------------------------------------------------------------||
function ChangeQuantity(OrderItem,NewQuantity) {
   if ( isNaN(NewQuantity) ) {
      alert( strErrQty );
   } else {
      NewOrder = "Order." + OrderItem;
      database = "";
      database = GetCookie(NewOrder);

      Token0 = database.indexOf("|", 0);
      Token1 = database.indexOf("|", Token0+1);
      Token2 = database.indexOf("|", Token1+1);
      Token3 = database.indexOf("|", Token2+1);
      Token4 = database.indexOf("|", Token3+1);
      Token5 = database.indexOf("|", Token4+1);
      Token6 = database.indexOf("|", Token5+1);


      fields = new Array;
      fields[0] = database.substring( 0, Token0 );
      fields[1] = database.substring( Token0+1, Token1 );
      fields[2] = database.substring( Token1+1, Token2 );
      fields[3] = database.substring( Token2+1, Token3 );
      fields[4] = database.substring( Token3+1, Token4 );
      fields[5] = database.substring( Token4+1, Token5 );
      fields[6] = database.substring( Token5+1, Token6 );
      fields[7] = database.substring( Token6+1, database.length );

      dbUpdatedOrder = fields[0] + "|" +
                       NewQuantity + "|" +
                       fields[2] + "|" +
                       fields[3] + "|" +
                       fields[4] + "|" +
                       fields[5] + "|" +
			     fields[6] + "|" +
			     fields[7];
      strNewOrder = "Order." + OrderItem;
      DeleteCookie(strNewOrder, "/");
      SetCookie(strNewOrder, dbUpdatedOrder, null, "/");
      location.href=location.href;      
   }
}


//---------------------------------------------------------------------||
// FUNCTION:    GetFromCart                                            ||
// PARAMETERS:  Null                                                   ||
// RETURNS:     Product Table Written to Document                      ||
// PURPOSE:     Draws current cart product table on HTML page          ||
//              **DEPRECATED FUNCTION, USE ManageCart or Checkout**    ||
//---------------------------------------------------------------------||
function GetFromCart( fShipping ) {
   ManageCart( );
}


//---------------------------------------------------------------------||
// FUNCTION:    RadioChecked                                           ||
// PARAMETERS:  Radio button to check                                  ||
// RETURNS:     True if a radio has been checked                       ||
// PURPOSE:     Form fillin validation                                 ||
//---------------------------------------------------------------------||
function RadioChecked( radiobutton ) {
   var bChecked = false;
   var rlen = radiobutton.length;
   for ( i=0; i < rlen; i++ ) {
      if ( radiobutton[i].checked )
         bChecked = true;
   }    
   return bChecked;
} 


//---------------------------------------------------------------------||
// FUNCTION:    QueryString                                            ||
// PARAMETERS:  Key to read                                            ||
// RETURNS:     value of key                                           ||
// PURPOSE:     Read data passed in via GET mode                       ||
//---------------------------------------------------------------------||
QueryString.keys = new Array();
QueryString.values = new Array();
function QueryString(key) {
   var value = null;
   for (var i=0;i<QueryString.keys.length;i++) {
      if (QueryString.keys[i]==key) {
         value = QueryString.values[i];
         break;
      }
   }
   return value;
} 

//---------------------------------------------------------------------||
// FUNCTION:    QueryString_Parse                                      ||
// PARAMETERS:  (URL string)                                           ||
// RETURNS:     null                                                   ||
// PURPOSE:     Parses query string data, must be called before Q.S.   ||
//---------------------------------------------------------------------||
function QueryString_Parse() {
   var query = window.location.search.substring(1);
   var pairs = query.split("&"); for (var i=0;i<pairs.length;i++) {
      var pos = pairs[i].indexOf('=');
      if (pos >= 0) {
         var argname = pairs[i].substring(0,pos);
         var value = pairs[i].substring(pos+1);
         QueryString.keys[QueryString.keys.length] = argname;
         QueryString.values[QueryString.values.length] = value;
      }
   }
}


//---------------------------------------------------------------------||
// FUNCTION:    To stop temp ManageCart                                             ||
// PARAMETERS:  Null                                                   ||
// RETURNS:     Product Table Written to Document                      ||
// PURPOSE:     Draws current cart product table on HTML page          ||
//---------------------------------------------------------------------||
function to_stop_ManageCart( ) {
   var iNumberOrdered = 0;    //Number of products ordered
   var fTotal         = 0;    //Total cost of order
   var fTax           = 0;    //Tax amount
   var fShipping      = 7.95;    //Shipping amount. Changed to 5.95 from 4 on 11/1/05 changed to 6.95 from 5.95 on 02/01/2008.  (PH) Changed to 7.95 from 6.95 on 1/20/2010.
   var strTotal       = "";   //Total cost formatted as money
   var strTax         = "";   //Total tax formatted as money
   var strShipping    = "";   //Total shipping formatted as money
   var strOutput      = "";   //String to be written to page
   var bDisplay       = true; //Whether to write string to the page (here for programmers)
   strColorLabel="Color";
   strStoreLabel="Store";
   iNumberOrdered = GetCookie("NumberOrdered");
   if ( iNumberOrdered == null )
      iNumberOrdered = 0;

   if ( bDisplay )
      strOutput = "<TABLE CLASS=\"nopcart\"><TR>" +
                  "<TD CLASS=\"nopheader\"><B>"+strILabel+"</B></TD>" +
                  "<TD CLASS=\"nopheader\"><B>"+strDLabel+"</B></TD>" +
                  "<TD CLASS=\"nopheader\"><B>"+strColorLabel+"</B></TD>" +
                  "<TD CLASS=\"nopheader\"><B>"+strQLabel+"</B></TD>" +
                  "<TD CLASS=\"nopheader\"><B>"+strPLabel+"</B></TD>" +
                  (DisplayShippingColumn?"<TD CLASS=\"nopheader\"><B>"+strSLabel+"</B></TD>":"") +
                  "<TD CLASS=\"nopheader\"><B>"+strRLabel+"</B></TD></TR>";
				  //                  "<TD CLASS=\"nopheader\"><B>"+strStoreLabel+"</B></TD>" +

   if ( iNumberOrdered == 0 ) {
      strOutput += "<TR><TD COLSPAN=6 CLASS=\"nopentry\"><CENTER><BR><B>Your cart is empty</B><BR><BR></CENTER></TD></TR>";
   }

   for ( i = 1; i <= iNumberOrdered; i++ ) {
      NewOrder = "Order." + i;
      database = "";
      database = GetCookie(NewOrder);

      Token0 = database.indexOf("|", 0);
      Token1 = database.indexOf("|", Token0+1);
      Token2 = database.indexOf("|", Token1+1);
      Token3 = database.indexOf("|", Token2+1);
      Token4 = database.indexOf("|", Token3+1);
	Token5=  database.indexOf("|", Token4+1);
	Token6=  database.indexOf("|", Token5+1);

      fields = new Array;
      fields[0] = database.substring( 0, Token0 );                 // Product ID
      fields[1] = database.substring( Token0+1, Token1 );          // Quantity
      fields[2] = database.substring( Token1+1, Token2 );          // Price
      fields[3] = database.substring( Token2+1, Token3 );          // Product Name/Description
      fields[4] = database.substring( Token3+1, Token4 );          // Shipping Cost
      fields[5] = database.substring( Token4+1, Token5 ); 		 //Additional Information
      fields[6] = database.substring( Token5+1, Token6 ); 		 //Color
      fields[7] = database.substring( Token6+1, database.length ); //Store Name

      fTotal     += (parseInt(fields[1]) * parseFloat(fields[2]) );
      fShipping  += (parseInt(fields[1]) * parseFloat(fields[4]) );
      fTax        = (fTotal * TaxRate);
      strTotal    = moneyFormat(fTotal);
      strTax      = moneyFormat(fTax);
      strShipping = moneyFormat(fShipping);

      if ( bDisplay ) {
         strOutput += "<TR><TD CLASS=\"nopentry\">"  + fields[0] + "</TD>";

         //if ( fields[5] == "" )
            strOutput += "<TD CLASS=\"nopentry\">"  + fields[3] + "</TD>";
         //else
           // strOutput += "<TD CLASS=\"nopentry\">"  + fields[3] + " - <I>"+ fields[5] + "</I></TD>";
         strOutput += "<TD CLASS=\"nopentry\">"  + fields[6] + "</TD>";
         strOutput += "<TD CLASS=\"nopentry\"><INPUT TYPE=TEXT NAME=Q SIZE=2 VALUE=\"" + fields[1] + "\" onChange=\"ChangeQuantity("+i+", this.value);\"></TD>";
         strOutput += "<TD CLASS=\"nopentry\">"+ MonetarySymbol + moneyFormat(fields[2]) + "</TD>";
         if ( DisplayShippingColumn ) {
            if ( parseFloat(fields[4]) > 0 )
               strOutput += "<TD CLASS=\"nopentry\">"+ MonetarySymbol + moneyFormat(fields[4]) + "</TD>";
            else
               strOutput += "<TD CLASS=\"nopentry\">N/A</TD>";
         }
        //strOutput += "<TD CLASS=\"nopentry\">" +"<a href='http://www.weddingveil.com'>"  + fields[7]  +"</a>"+ "</TD>";
         strOutput += "<TD CLASS=\"nopentry\" ALIGN=CENTER><input type=button value=\" "+strRButton+" \" onClick=\"RemoveFromCart("+i+")\" class=\"nopbutton\"></TD></TR>";
      }

      if ( AppendItemNumToOutput ) {
         strFooter = i;
      } else {
         strFooter = "";
      }
      if ( HiddenFieldsToCheckout ) {
         strOutput += "<input type=hidden name=\"" + OutputItemId        + strFooter + "\" value=\"" + fields[0] + "\">";
         strOutput += "<input type=hidden name=\"" + OutputItemQuantity  + strFooter + "\" value=\"" + fields[1] + "\">";
         strOutput += "<input type=hidden name=\"" + OutputItemPrice     + strFooter + "\" value=\"" + fields[2] + "\">";
         strOutput += "<input type=hidden name=\"" + OutputItemName      + strFooter + "\" value=\"" + fields[3] + "\">";
         strOutput += "<input type=hidden name=\"" + OutputItemShipping  + strFooter + "\" value=\"" + fields[4] + "\">";
         strOutput += "<input type=hidden name=\"" + OutputItemAddtlInfo + strFooter + "\" value=\"" + fields[5] + "\">";
      }

   }

   if ( bDisplay ) {
      strOutput += "<TR><TD CLASS=\"noptotal\" COLSPAN=4><B>"+strSUB+"</B></TD>";
      strOutput += "<TD CLASS=\"noptotal\" COLSPAN=2><B>" + MonetarySymbol + strTotal + "</B></TD>";
      strOutput += "</TR>";

      if ( DisplayShippingRow ) {
         strOutput += "<TR><TD CLASS=\"noptotal\" COLSPAN=4><B>"+strSHIP+"</B></TD>";
         strOutput += "<TD CLASS=\"noptotal\" COLSPAN=2><B>" + MonetarySymbol + strShipping + "</B></TD>";
         strOutput += "</TR>";
      }

      if ( DisplayTaxRow || TaxByRegion ) {
         if ( TaxByRegion ) {
            strOutput += "<TR><TD CLASS=\"noptotal\" COLSPAN=4><B>"+strTAX+"</B></TD>";
            strOutput += "<TD CLASS=\"noptotal\" COLSPAN=2><B>";
            strOutput += "<input type=radio name=\""+OutputOrderTax+"\" value=\"" + strTax + "\">";
            strOutput += TaxablePrompt + ": " + MonetarySymbol + strTax;
            strOutput += "<BR><input type=radio name=\""+OutputOrderTax+"\" value=\"0.00\">";
            strOutput += NonTaxablePrompt + ": " + MonetarySymbol + "0.00";
            strOutput += "</B></TD>";
            strOutput += "</TR>";
         } else {
            strOutput += "<TR><TD CLASS=\"noptotal\" COLSPAN=4><B>"+strTAX+"</B></TD>";
            strOutput += "<TD CLASS=\"noptotal\" COLSPAN=2><B>" + MonetarySymbol + strTax + "</B></TD>";
            strOutput += "</TR>";
         }
      }

      if ( !TaxByRegion ) {
         strOutput += "<TR><TD CLASS=\"noptotal\" COLSPAN=4><B>"+strTOT+"</B></TD>";
         strOutput += "<TD CLASS=\"noptotal\" COLSPAN=2><B>" + MonetarySymbol + moneyFormat((fTotal + fShipping + fTax)) + "</B></TD>";
         strOutput += "</TR>";
      }
      strOutput += "</TABLE>";


      if ( HiddenFieldsToCheckout ) {
         strOutput += "<input type=hidden name=\""+OutputOrderSubtotal+"\" value=\""+ MonetarySymbol + strTotal + "\">";
         strOutput += "<input type=hidden name=\""+OutputOrderShipping+"\" value=\""+ MonetarySymbol + strShipping + "\">";
         strOutput += "<input type=hidden name=\""+OutputOrderTax+"\"      value=\""+ MonetarySymbol + strTax + "\">";
         strOutput += "<input type=hidden name=\""+OutputOrderTotal+"\"    value=\""+ MonetarySymbol + moneyFormat((fTotal + fShipping + fTax)) + "\">";
      }
   }
   g_TotalCost = (fTotal + fShipping + fTax);

   document.write(strOutput);
   document.close();
}

//---------------------------------------------------------------------||
// FUNCTION:    ValidateCart                                           ||
// PARAMETERS:  Form to validate                                       ||
// RETURNS:     true/false                                             ||
// PURPOSE:     Validates the managecart form                          ||
//---------------------------------------------------------------------||
var g_TotalCost = 0;
function ValidateCart( theForm ) {
   if ( TaxByRegion ) {
      if ( !RadioChecked(eval("theForm."+OutputOrderTax)) ) {
         alert( TaxPrompt );
         return false;
      }
   }

   if ( MinimumOrder >= 0.01 ) {
      if ( g_TotalCost < MinimumOrder ) {
         alert( MinimumOrderPrompt );
         return false;
      }
   }

   return true;
}

//---------------------------------------------------------------------||
// FUNCTION:    CheckoutCart                                           ||
// PARAMETERS:  Null                                                   ||
// RETURNS:     Product Table Written to Document                      ||
// PURPOSE:     Draws current cart product table on HTML page for      ||
//              checkout.                                              ||
//---------------------------------------------------------------------||
function Tostop_CheckoutCart( ) {
   var iNumberOrdered = 0;    //Number of products ordered
   var fTotal         = 0;    //Total cost of order
   var fTax           = 0;    //Tax amount
   var fShipping      = 5.95;    //Shipping amount
   var strTotal       = "";   //Total cost formatted as money
   var strTax         = "";   //Total tax formatted as money
   var strShipping    = "";   //Total shipping formatted as money
   var strOutput      = "";   //String to be written to page
   var bDisplay       = true; //Whether to write string to the page (here for programmers)
   var strPP          = "";   //Payment Processor Description Field
   strColorLabel="Color";
   strStoreLabel="Store";
   iNumberOrdered = GetCookie("NumberOrdered");
   if ( iNumberOrdered == null )
      iNumberOrdered = 0;

   if ( TaxByRegion ) {
      QueryString_Parse();
      fTax = parseFloat( QueryString( OutputOrderTax ) );
      strTax = moneyFormat(fTax);
   }

   if ( bDisplay )
      strOutput = "<TABLE CLASS=\"nopcart\"><TR>" +
                  "<TD CLASS=\"nopheader\"><B>"+strILabel+"</B></TD>" +
                  "<TD CLASS=\"nopheader\"><B>"+strDLabel+"</B></TD>" +
                  "<TD CLASS=\"nopheader\"><B>"+strColorLabel+"</B></TD>" +
                  "<TD CLASS=\"nopheader\"><B>"+strQLabel+"</B></TD>" +
                  "<TD CLASS=\"nopheader\"><B>"+strPLabel+"</B></TD>" +
                  (DisplayShippingColumn?"<TD CLASS=\"nopheader\"><B>"+strSLabel+"</B></TD>":"") +
			"</TR>";
	//                   "<TD CLASS=\"nopheader\"><B>"+strStoreLabel+"</B></TD>" +

   for ( i = 1; i <= iNumberOrdered; i++ ) {
      NewOrder = "Order." + i;
      database = "";
      database = GetCookie(NewOrder);
	   database=ReplaceStr(database,'"','&quot;');

      Token0 = database.indexOf("|", 0);
      Token1 = database.indexOf("|", Token0+1);
      Token2 = database.indexOf("|", Token1+1);
      Token3 = database.indexOf("|", Token2+1);
      Token4 = database.indexOf("|", Token3+1);
	Token5 = database.indexOf("|", Token4+1);
	Token6 = database.indexOf("|", Token5+1);


      fields = new Array;
      fields[0] = database.substring( 0, Token0 );                 // Product ID
      fields[1] = database.substring( Token0+1, Token1 );          // Quantity
      fields[2] = database.substring( Token1+1, Token2 );          // Price
      fields[3] = database.substring( Token2+1, Token3 );          // Product Name/Description
      fields[4] = database.substring( Token3+1, Token4 );          // Shipping Cost
      fields[5] = database.substring( Token4+1, Token5 ); 		 //Additional Information
      fields[6] = database.substring( Token5+1, Token6 ); 		 //Color
      fields[7] = database.substring( Token6+1, database.length ); //Store Name



      fTotal     += (parseInt(fields[1]) * parseFloat(fields[2]) );
      fShipping  += (parseInt(fields[1]) * parseFloat(fields[4]) );
      if ( !TaxByRegion ) fTax = (fTotal * TaxRate);
      strTotal    = moneyFormat(fTotal);
      if ( !TaxByRegion ) strTax = moneyFormat(fTax);
      strShipping = moneyFormat(fShipping);

      if ( bDisplay ) {
         strOutput += "<TR><TD CLASS=\"nopentry\">"  + fields[0] + "</TD>";

         //if ( fields[5] == "" )
            strOutput += "<TD CLASS=\"nopentry\">"  + fields[3] + "</TD>";
         //else
           // strOutput += "<TD CLASS=\"nopentry\">"  + fields[3] + " - <I>"+ fields[5] + "</I></TD>";
         strOutput += "<TD CLASS=\"nopentry\">"  + fields[6] + "</TD>";
         strOutput += "<TD CLASS=\"nopentry\">" + fields[1] + "</TD>";
         strOutput += "<TD CLASS=\"nopentry\">"+ MonetarySymbol + moneyFormat(fields[2]) + "</TD>";

         if ( DisplayShippingColumn ) {
            if ( parseFloat(fields[4]) > 0 )
               strOutput += "<TD CLASS=\"nopentry\">"+ MonetarySymbol + moneyFormat(fields[4]) + "</TD>";
            else
               strOutput += "<TD CLASS=\"nopentry\">N/A</TD>";
         }
         //strOutput += "<TD CLASS=\"nopentry\">"  +"<a href='http://www.weddingveil.com'>"+ fields[7] + "</a>"+"</TD>";
         strOutput += "</TR>";
      }

      if ( AppendItemNumToOutput ) {
         strFooter = i;
      } else {
         strFooter = "";
      }
      if ( PaymentProcessor != '' ) {
         //Process description field for payment processors instead of hidden values.
         //Format Description of product as:
         // ID, Name, Qty X
         strPP += fields[0] + ", " + fields[3];
         if ( fields[5] != "" )
            strPP += " - " + fields[5];
         strPP += ", Qty. " + fields[1] + "\n";

      } else {
         strOutput += "<input type=hidden name=\"" + OutputItemId        + strFooter + "\" value=\"" + fields[0] + "\">";
         strOutput += "<input type=hidden name=\"" + OutputItemQuantity  + strFooter + "\" value=\"" + fields[1] + "\">";
         strOutput += "<input type=hidden name=\"" + OutputItemPrice     + strFooter + "\" value=\"" + fields[2] + "\">";
         strOutput += "<input type=hidden name=\"" + OutputItemName      + strFooter + "\" value=\"" + fields[3] + "\">";
		 //2/15/05 - following 2 lines commented out so that Shipping and additional info for each
		 //product will not show up in the order email
         //strOutput += "<input type=hidden name=\"" + OutputItemShipping  + strFooter + "\" value=\"" + fields[4] + "\">";
         //strOutput += "<input type=hidden name=\"" + OutputItemAddtlInfo + strFooter + "\" value=\"" + fields[5] + "\">";
      } 

   }

   if ( bDisplay ) {
      strOutput += "<TR><TD CLASS=\"noptotal\" COLSPAN=3><B>"+strSUB+"</B></TD>";
      strOutput += "<TD CLASS=\"noptotal\" COLSPAN=2 ALIGN=RIGHT><B><span id=\"SUBTOTALCELL\" name=\"SUBTOTALCELL\">" + MonetarySymbol + strTotal + "</span></B></TD>";
      strOutput += "</TR>";

      if ( DisplayShippingRow ) {
         strOutput += "<TR><TD CLASS=\"noptotal\" COLSPAN=3><B>"+strSHIP+"</B></TD>";
         strOutput += "<TD CLASS=\"noptotal\" COLSPAN=2 ALIGN=RIGHT><B><span id=\"SHIPPINGCELL\" name=\"SHIPPINGCELL\">" + MonetarySymbol + strShipping + "</span></B></TD>";
         strOutput += "</TR>";
      }

      if ( DisplayTaxRow || TaxByRegion ) {
         strOutput += "<TR><TD CLASS=\"noptotal\" COLSPAN=3><B>"+strTAX+"</B></TD>";
         strOutput += "<TD CLASS=\"noptotal\" COLSPAN=2 ALIGN=RIGHT><B><span id=\"TAXCELL\" name=\"TAXCELL\">" + MonetarySymbol + strTax + "</span></B></TD>";
         strOutput += "</TR>";
      }

      strOutput += "<TR><TD CLASS=\"noptotal\" COLSPAN=3><B>"+strTOT+"</B></TD>";
      strOutput += "<TD CLASS=\"noptotal\" COLSPAN=2 ALIGN=RIGHT><B><span id=\"TOTALCELL\" name=\"TOTALCELL\">" + MonetarySymbol + moneyFormat((fTotal + fShipping + fTax)) + "</span></B></TD>";
      strOutput += "</TR>";

      strOutput += "</TABLE>";

      
      if ( PaymentProcessor == 'an') {
         //Process this for Authorize.net WebConnect
         strOutput += "<input type=hidden name=\"x_Version\" value=\"3.0\">";
         strOutput += "<input type=hidden name=\"x_Show_Form\" value=\"PAYMENT_FORM\">";
         strOutput += "<input type=hidden name=\"x_Description\" value=\""+ strPP + "\">";
         strOutput += "<input type=hidden name=\"x_Amount\" value=\""+ moneyFormat((fTotal + fShipping + fTax)) + "\">";
      } else if ( PaymentProcessor == 'wp') {
         //Process this for WorldPay
         strOutput += "<input type=hidden name=\"desc\" value=\""+ strPP + "\">";
         strOutput += "<input type=hidden name=\"amount\" value=\""+ moneyFormat((fTotal + fShipping + fTax)) + "\">";
      } else if ( PaymentProcessor == 'lp') {
         //Process this for LinkPoint         
         strOutput += "<input type=hidden name=\"mode\" value=\"fullpay\">";
         strOutput += "<input type=hidden name=\"chargetotal\" value=\""+ moneyFormat((fTotal + fShipping + fTax)) + "\">";
         strOutput += "<input type=hidden name=\"tax\" value=\""+ MonetarySymbol + strTax + "\">";
         strOutput += "<input type=hidden name=\"subtotal\" value=\""+ MonetarySymbol + strTotal + "\">";
         strOutput += "<input type=hidden name=\"shipping\" value=\""+ MonetarySymbol + strShipping + "\">";
         strOutput += "<input type=hidden name=\"desc\" value=\""+ strPP + "\">";
      } else {
         strOutput += "<input type=hidden name=\""+OutputOrderSubtotal+"\" value=\""+ MonetarySymbol + strTotal + "\">";
         strOutput += "<input type=hidden name=\""+OutputOrderShipping+"\" value=\""+ MonetarySymbol + strShipping + "\">";
         strOutput += "<input type=hidden name=\""+OutputOrderTax+"\"      value=\""+ MonetarySymbol + strTax + "\">";
         strOutput += "<input type=hidden name=\""+OutputOrderTotal+"\"    value=\""+ MonetarySymbol + moneyFormat((fTotal + fShipping + fTax)) + "\">";
      }
   }

   document.write(strOutput);
   document.close();
}


//=====================================================================||
//====================This Scripts for favor===========================||
//---------------------------------------------------------------------||
// FUNCTION:    FavorAddToCart                                         ||
// PARAMETERS:  Form Object                                            ||
// RETURNS:     Cookie to user's browser, with prompt                  ||
// PURPOSE:     Adds a product to the user's shopping cart             ||
//---------------------------------------------------------------------||
function FavorAddToCart(thisForm) {
  strAdded  = " added to your shopping cart.";
   var iNumberOrdered = 0;
   var bAlreadyInCart = false;
   var notice = "";
   iNumberOrdered = GetCookie("NumberOrdered");
   strStoreName="Wedding Veil";
   //Added by Achutha
   centscount="0";
if (thisForm.CheckBoxPersonalizedTag.checked == true)
	{
		   mim=thisForm.Minimum.value
	   	if ( thisForm.QUANTITY.value >= parseInt(mim) )
	{
		centscount="0.35"
	}
	else
		{
		alert("Minimum quantity is " + mim);
		return
		}
	}

//if (thisForm.cents != null)
//{
//	cents=0
//		alert(cents);
//}

if (thisForm.firstquantity != null)
{
   	strFirstQuanty = thisForm.firstquantity.value
}

if (thisForm.firstquantity1 != null)
{
	strFirstQuanty1 =thisForm.firstquantity1.value
}
	
if (thisForm.secondquantity != null)
{
	strSecondQuanty = thisForm.secondquantity.value
}

if (thisForm.secondquantity1 != null)
{
		strSecondQuanty1 =thisForm.secondquantity1.value
}
	
if (thisForm.thirdquantity != null)
{
	strThirdQuanty = thisForm.thirdquantity.value
}

if (thisForm.thirdquantity1 != null)
{
	strThirdQuanty1 =thisForm.thirdquantity1.value
}
	
if (thisForm.fourquantity != null)
{
	strFourQuanty = thisForm.fourquantity.value
}

if (thisForm.firstlist != null)
{
	strFirstList=thisForm.firstlist.value
}

if (thisForm.secondlist != null)
{
	strSecondList=thisForm.secondlist.value
}

if (thisForm.thirdlist != null)
{
	strThirdList=thisForm.thirdlist.value
}

if (thisForm.fourlist != null)
{
	strFourList=thisForm.fourlist.value
}
//END

	
   if ( iNumberOrdered == null )
      iNumberOrdered = 0;

   if ( thisForm.NAME == null )
      strNAME    = "";
   else
      strNAME    = thisForm.NAME.value;
	  
   if ( thisForm.ID_NUM == null )
      strID_NUM    = "";
   else
      strID_NUM    = thisForm.ID_NUM.value;

   if ( thisForm.QUANTITY == null )
	{
      strQUANTITY  = "1";
	}
   else
	{
       strQUANTITY  = thisForm.QUANTITY.value;
	}
//Add by Achutha
	if ( thisForm.QUANTITY.value == "" )
	{
      alert("Quantity empty");
	  return
	}
	if ( thisForm.QUANTITY.value == "0" )
	{
      alert("Quantity should be greater than 0");
	  return
	}
//End
	

   if ( thisForm.PRICE == null )
      strPRICE     = "0.00";
   else
      strPRICE     = thisForm.PRICE.value;

   if ( thisForm.NAME == null )
      strNAME      = "";
   else
      strNAME      = "";

   if ( thisForm.SHIPPING == null )
      strSHIPPING  = "0.00";
   else
      strSHIPPING  = thisForm.SHIPPING.value;

	
   if ( thisForm.ADDITIONALINFO == null ) {
      strColor= "";
   } else {
      strColor= thisForm.ADDITIONALINFO.value;
   }
   if ( thisForm.ADDITIONALINFO2 != null ) {
		strADDTLINFO =thisForm.ADDITIONALINFO2.value;
   }
	if ( thisForm.ADDITIONALINFO5 != null ) {
      	strADDTLINFO += "; " + thisForm.ADDITIONALINFO5.value;
   }   
if ( thisForm.ADDITIONALINFO3 != null ) {
	if( thisForm.ADDITIONALINFO3.value != "None") {
	      strADDTLINFO += " " + thisForm.ADDITIONALINFO3.value;
	}
   }
//alert(thisForm.URLGET.value);
   
   if (thisForm.URLGET != null)
   {
	   if (thisForm.URLGET.value != "None")
	   {
	   strADDTLINFO += "; " + thisForm.URLGET.value;
	   }
   }

	
   if ( thisForm.ADDITIONALINFO4 != null ) {
	if( thisForm.ADDITIONALINFO4.value != "None") {
	      strADDTLINFO += "; " + thisForm.ADDITIONALINFO4.value;
		}
   }
 
 //user form entry added  (start)
   if ( thisForm.TEXTLINE1 != null ) {
strADDTLINFO += "; " + thisForm.TEXTLINE1.value;
}
if ( thisForm.TEXTLINE2 != null ) {
strADDTLINFO += "; " + thisForm.TEXTLINE2.value;
}
if ( thisForm.TEXTLINE3 != null ) {
strADDTLINFO += "; " + thisForm.TEXTLINE3.value;
}
//user form entry (end)
  
strNAME=strADDTLINFO;

   //Is this product already in the cart?  If so, increment quantity instead of adding another.
   for ( i = 1; i <= iNumberOrdered; i++ ) {
      NewOrder = "Order." + i;
      database = "";
      database = GetCookie(NewOrder);
	Token0 = database.indexOf("|", 0);
    Token1 = database.indexOf("|", Token0+1);
    Token2 = database.indexOf("|", Token1+1);
    Token3 = database.indexOf("|", Token2+1);
    Token4 = database.indexOf("|", Token3+1);
	Token5 = database.indexOf("|", Token4+1);
	Token6 = database.indexOf("|", Token5+1);
	//Added by Achutha
	Token7 = database.indexOf("|", Token6+1);
	Token8 = database.indexOf("|", Token7+1);
	Token9 = database.indexOf("|", Token8+1);
	Token10 = database.indexOf("|", Token9+1);
	Token11 = database.indexOf("|", Token10+1);
	Token12 = database.indexOf("|", Token11+1);
	Token13 = database.indexOf("|", Token12+1);
	Token14 = database.indexOf("|", Token13+1);
	Token15 = database.indexOf("|", Token14+1);
	Token16 = database.indexOf("|", Token15+1);
	Token17 = database.indexOf("|", Token16+1);
	Token18 = database.indexOf("|", Token17+1);
	//End

      fields = new Array;
      fields[0] = database.substring( 0, Token0 );
      fields[1] = database.substring( Token0+1, Token1 );
      fields[2] = database.substring( Token1+1, Token2 );
      fields[3] = database.substring( Token2+1, Token3 );
      fields[4] = database.substring( Token3+1, Token4 );
      fields[5] = database.substring( Token4+1, Token5 );
	  fields[6]=  database.substring( Token5+1, Token6);
	//fields[7]=  database.substring( Token6+1,database.length);
	//Added by Achutha
	  fields[7]=  database.substring( Token6+1, Token7);
      fields[8]=  database.substring( Token7+1, Token8);
	  fields[9]=  database.substring( Token8+1, Token9);
	  fields[10]=  database.substring( Token9+1, Token10);
	  fields[11]=  database.substring( Token10+1, Token11);
	  fields[12]=  database.substring( Token11+1, Token12);
	  fields[13]=  database.substring( Token12+1, Token13);
	  fields[14]=  database.substring( Token13+1, Token14);
	  fields[15]=  database.substring( Token14+1, Token15);
	  fields[16]=  database.substring( Token15+1, Token16);
	  fields[17]=  database.substring( Token16+1, Token17);
	  fields[18]=  database.substring( Token17+1, Token18);
  	  fields[19]=  database.substring( Token18+1, database.length);
	//End 

      if ( fields[0] == strID_NUM &&
           fields[2] == strPRICE  &&
           fields[3] == strNAME   &&
           fields[5] == strADDTLINFO   &&	
		   fields[6] == strColor &&
           fields[7] == strStoreName &&
		  //Added by Achutha
		   fields[8] == strFirstList &&
		   fields[9] == strSecondList &&
		   fields[10] == strThirdList	 &&
		   fields[11] == strFourList &&
		   fields[12] == strFirstQuanty &&
 		   fields[13] == strFirstQuanty1 &&
  		   fields[14] == strSecondQuanty &&
  		   fields[15] == strSecondQuanty1 &&
  		   fields[16] == strThirdQuanty &&
  		   fields[17] == strThirdQuanty1 &&
		   fields[18] == strFourQuanty &&
     	   fields[19] == centscount

//End
         ) {
         bAlreadyInCart = true;
         dbUpdatedOrder = strID_NUM    + "|" +
                          (parseInt(strQUANTITY)+parseInt(fields[1]))  + "|" +
                          strPRICE     + "|" +
                          strNAME      + "|" +
                          strSHIPPING  + "|" +
                          strADDTLINFO + "|" +
						  strColor	   + "|" +
						  strStoreName + "|" +
			 //Added by Achutha
						  strFirstList + "|" +
						  strSecondList + "|" +
						  strThirdList + "|" +
						  strFourList + "|" +
						  strFirstQuanty + "|" +
						  strFirstQuanty1 + "|" +
						  strSecondQuanty + "|" +
						  strSecondQuanty1 + "|" +
						  strThirdQuanty + "|" +
						  strThirdQuanty1 + "|" +
						  strFourQuanty + "|" +
						  centscount;
						  //End
						  strNewOrder = "Order." + i;
						  
         DeleteCookie(strNewOrder, "/");
         SetCookie(strNewOrder, dbUpdatedOrder, null, "/");
         notice = strQUANTITY + " " +  strNAME + strAdded;
         break;
      }
   }


   if ( !bAlreadyInCart ) {
      iNumberOrdered++;

      if ( iNumberOrdered > 12 )
         alert( strSorry );
      else {
         dbUpdatedOrder = strID_NUM    + "|" + 
                          strQUANTITY  + "|" +
                          strPRICE     + "|" +
                          strNAME      + "|" +
                          strSHIPPING  + "|" +
                          strADDTLINFO + "|" +
                          strColor	   + "|" +
                          strStoreName + "|" +
			 			 //Added by Achutha
 						  strFirstList + "|" +
						  strSecondList + "|" +
						  strThirdList + "|" +
						  strFourList + "|" +
				   		  strFirstQuanty + "|" +
						  strFirstQuanty1 + "|" +
						  strSecondQuanty + "|" +
						  strSecondQuanty1 + "|" +
						  strThirdQuanty + "|" +
						  strThirdQuanty1 + "|" +
						  strFourQuanty + "|" +
						  centscount;

			// End


         strNewOrder = "Order." + iNumberOrdered;
         SetCookie(strNewOrder, dbUpdatedOrder, null, "/");
         SetCookie("NumberOrdered", iNumberOrdered, null, "/");
         notice = strQUANTITY + " " + strNAME+ strAdded;
      }
   }

   if ( DisplayNotice )
	{
		notice = ReplaceStr(notice, '&quot;', '"'); //added 9/8/04 so the pop-up message shows
													//the inch symbol " correctly.	
         alert(notice);
	}
}


//---------------------------------------------------------------------||
// FUNCTION:    FavorChangeQuantity                                         ||
// PARAMETERS:  Order Number to Change Quantity                        ||
// RETURNS:     Null                                                   ||
// PURPOSE:     Changes quantity of an item in the shopping cart       ||
//---------------------------------------------------------------------||
function FavorChangeQuantity(OrderItem,NewQuantity) {
   if ( isNaN(NewQuantity) ) {
      alert( strErrQty );
   } else {
      NewOrder = "Order." + OrderItem;
      database = "";
      database = GetCookie(NewOrder);

      Token0 = database.indexOf("|", 0);
      Token1 = database.indexOf("|", Token0+1);
      Token2 = database.indexOf("|", Token1+1);
      Token3 = database.indexOf("|", Token2+1);
      Token4 = database.indexOf("|", Token3+1);
      Token5 = database.indexOf("|", Token4+1);
      Token6 = database.indexOf("|", Token5+1);
	  //Added by Achutha
	  Token7 = database.indexOf("|", Token6+1);
	  Token8 = database.indexOf("|", Token7+1);
	  Token9 = database.indexOf("|", Token8+1);
	  Token10 = database.indexOf("|", Token9+1);
	  Token11 = database.indexOf("|", Token10+1);
	  Token12 = database.indexOf("|", Token11+1);
	  Token13 = database.indexOf("|", Token12+1);
	  Token14 = database.indexOf("|", Token13+1);
  	  Token15 = database.indexOf("|", Token14+1);
  	  Token16 = database.indexOf("|", Token15+1);
  	  Token17 = database.indexOf("|", Token16+1);
   	  Token18 = database.indexOf("|", Token17+1);
	  //END


      fields = new Array;
      fields[0] = database.substring( 0, Token0 );
      fields[1] = database.substring( Token0+1, Token1 );
      fields[2] = database.substring( Token1+1, Token2 );
      fields[3] = database.substring( Token2+1, Token3 );
      fields[4] = database.substring( Token3+1, Token4 );
      fields[5] = database.substring( Token4+1, Token5 );
      fields[6] = database.substring( Token5+1, Token6 );
      //fields[7] = database.substring( Token6+1, database.length );
	  //Added by Achutha
	  fields[7] = database.substring( Token6+1, Token7 );
	  fields[8] = database.substring( Token7+1, Token8 );
	  fields[9] = database.substring( Token8+1, Token9 );
	  fields[10] = database.substring( Token9+1, Token10 );
	  fields[11] = database.substring( Token10+1, Token11 );
	  fields[12] = database.substring( Token11+1, Token12 );
	  fields[13] = database.substring( Token12+1, Token13 );
  	  fields[14] = database.substring( Token13+1, Token14 );
	  fields[15] = database.substring( Token14+1, Token15 );
	  fields[16] = database.substring( Token15+1, Token16 );
	  fields[17] = database.substring( Token16+1, Token17 );
	  fields[18] = database.substring( Token17+1, Token18 );
	  fields[19] = database.substring( Token18+1, database.length );
	  // END

      dbUpdatedOrder = fields[0] + "|" +
                       NewQuantity + "|" +
                       fields[2] + "|" +
                       fields[3] + "|" +
                       fields[4] + "|" +
                       fields[5] + "|" +
					   fields[6] + "|" +
		  //Added by Achutha
					   fields[7] + "|" +
					   fields[8] + "|" +
					   fields[9] + "|" +
					   fields[10] + "|" +
					   fields[11] + "|" +
					   fields[12] + "|" +
					   fields[13] + "|" +
   					   fields[14] + "|" +
					   fields[15] + "|" +
					   fields[16] + "|" +
					   fields[17] + "|" +
					   fields[18] + "|" +
					   fields[19];
		  //END
      strNewOrder = "Order." + OrderItem;
      DeleteCookie(strNewOrder, "/");
      SetCookie(strNewOrder, dbUpdatedOrder, null, "/");
      location.href=location.href;      
   }
}


//---------------------------------------------------------------------||
// FUNCTION:    ManageCart                                             ||
// PARAMETERS:  Null                                                   ||
// RETURNS:     Product Table Written to Document                      ||
// PURPOSE:     Draws current cart product table on HTML page          ||
//---------------------------------------------------------------------||
function ManageCart( ) {
   var iNumberOrdered = 0;    //Number of products ordered
   var fTotal         = 0;    //Total cost of order
   var fTax           = 0;    //Tax amount
   var fShipping      = 7.95;    //Shipping amount. Changed to 5.95 from 4 on 11/1/05 changed to 6.95 from 5.95 on 02/01/2008. (PH) Changed to 7.95 from 6.95 on 1/20/2010.
   var strTotal       = "";   //Total cost formatted as money
   var strTax         = "";   //Total tax formatted as money
   var strShipping    = "";   //Total shipping formatted as money
   var strOutput      = "";   //String to be written to page
   var bDisplay       = true; //Whether to write string to the page (here for programmers)
   var testing =""
   var centcount1 =0;
   var fcheckp =0;
   strColorLabel="Color";
   strStoreLabel="Store";
   iNumberOrdered = GetCookie("NumberOrdered");

   if ( iNumberOrdered == null )
      iNumberOrdered = 0;

   if ( bDisplay )
      strOutput = "<TABLE CLASS=\"nopcart\"><TR>" +
                  "<TD CLASS=\"nopheader\"><B>"+strILabel+"</B></TD>" +
                  "<TD CLASS=\"nopheader\"><B>"+strDLabel+"</B></TD>" +
                  "<TD CLASS=\"nopheader\"><B>"+strColorLabel+"</B></TD>" +
				  //"<TD CLASS=\"nopheader\"><B>"+ strPersonalized +"</B></TD>" +
                  "<TD CLASS=\"nopheader\"><B>"+strQLabel+"</B></TD>" +
                  "<TD CLASS=\"nopheader\"><B>"+strPLabel+"</B></TD>" +
                  (DisplayShippingColumn?"<TD CLASS=\"nopheader\"><B>"+strSLabel+"</B></TD>":"") +
                  "<TD CLASS=\"nopheader\"><B>"+strRLabel+"</B></TD></TR>";
				  //                  "<TD CLASS=\"nopheader\"><B>"+strStoreLabel+"</B></TD>" +

   if ( iNumberOrdered == 0 ) {
      strOutput += "<TR><TD COLSPAN=8 CLASS=\"nopentry\"><CENTER><BR><B>Your cart is empty</B><BR><BR></CENTER></TD></TR>";
   }

   for ( i = 1; i <= iNumberOrdered; i++ ) {
      NewOrder = "Order." + i;
	        database = "";
	        database = GetCookie(NewOrder);

     Token0 = database.indexOf("|", 0);
     Token1 = database.indexOf("|", Token0+1);
     Token2 = database.indexOf("|", Token1+1);
     Token3 = database.indexOf("|", Token2+1);
     Token4 = database.indexOf("|", Token3+1);
     Token5=  database.indexOf("|", Token4+1);
	 Token6=  database.indexOf("|", Token5+1);
	 Token7= database.indexOf("|", Token6+1);
	 //Added by Achutha
	 Token8 =database.indexOf("|", Token7+1);
	 Token9 =database.indexOf("|", Token8+1);
	 Token10 =database.indexOf("|", Token9+1);
	 Token11 =database.indexOf("|", Token10+1);
	 Token12 =database.indexOf("|", Token11+1);
	 Token13 =database.indexOf("|", Token12+1);
	 Token14 =database.indexOf("|", Token13+1);
	 Token15 =database.indexOf("|", Token14+1);
	 Token16 =database.indexOf("|", Token15+1);
	 Token17 =database.indexOf("|", Token16+1);
 	 Token18 =database.indexOf("|", Token17+1);
	 //Token14 =database.indexOf("|", Token13+1);
	 //END

      fields = new Array;
      fields[0] = database.substring( 0, Token0 );                 // Product ID
      fields[1] = database.substring( Token0+1, Token1 );          // Quantity
      fields[2] = database.substring( Token1+1, Token2 );          // Price
      fields[3] = database.substring( Token2+1, Token3 );          // Product Name/Description
      fields[4] = database.substring( Token3+1, Token4 );          // Shipping Cost
      fields[5] = database.substring( Token4+1, Token5 ); 		 //Additional Information
      fields[6] = database.substring( Token5+1, Token6 ); 		 //Color
      //fields[7] = database.substring( Token6+1, database.length ); //Store Name
	  //Added by Achutha
	  fields[7] = database.substring( Token6+1, Token7 ); // Storename
	  fields[8] = database.substring( Token7+1, Token8 ); //firtlist
	  fields[9] = database.substring( Token8+1, Token9 ); //secondlist
	  fields[10] = database.substring( Token9+1, Token10 ); //thirdlist
	  fields[11] = database.substring( Token10+1, Token11 ); //fourthlist
	  fields[12] = database.substring( Token11+1, Token12 ); //fristquanty
	  fields[13] = database.substring( Token12+1, Token13 ); //firstquanty1
  	  fields[14] = database.substring( Token13+1, Token14 ); //secondquanty
  	  fields[15] = database.substring( Token14+1, Token15 ); //secondquanty1
  	  fields[16] = database.substring( Token15+1, Token16 ); //thirdquanty
  	  fields[17] = database.substring( Token16+1, Token17 ); //thirdquanty1
  	  fields[18] = database.substring( Token17+1, Token18 ); //fourquanty
  	  fields[19] = database.substring( Token18+1, database.length ); //fourquanty
	  // END
//	  alert (fields[2]);
//	  alert ("Firstlist" + fields[8]);
//	  alert ("SecondList" + fields[9]);
//	  alert ("Thirdlist" + fields[10]);
//	  alert ("Fourlist" +fields[11]);
//	  alert ("Fisrt----" + fields[12]);
//	  alert ("Fisrt1---" + fields[13]);
//	  alert ("SEcond---" + fields[14]);
//	  alert ("SEcond1---" + fields[15]);
//	  alert ("Third---" + fields[16]);
//	  alert ("Third1---" + fields[17]);
//	  alert ("nighteen---" + fields[19]);

	  //alert(fields[8]);
//Added by Achutha

if (fields[19] != "" && fields[19] !=0 && fields[19] > 0)
{
centcount1 = Math.round((parseInt(fields[1]) * parseFloat(fields[19]))*100)/100;
}
else
	   {
	centcount1=0;
	   }

if (parseInt(fields[12]) == "0" && parseInt(fields[13]) == "0" && parseInt(fields[14]) == "0" && parseInt(fields[15]) == "0" && parseInt(fields[16]) == "0" && parseInt(fields[17]) == "0" && parseInt(fields[18]) == "0")
{
			fcheckp=1;
	fTotal     += (parseInt(fields[1]) * parseFloat(fields[2]) + centcount1 );
}
else
{
	if (parseInt(fields[1]) >= parseInt(fields[12]) && parseInt(fields[1]) <= parseInt(fields[13]) && parseInt(fields[13]) > 0 && parseInt(fields[1]) > 0 && parseInt(fields[12]) > 0 && parseFloat(fields[11]) >= 0)
	{
				fcheckp=1;
	      fTotal     += (parseInt(fields[1]) * parseFloat(fields[8]) + centcount1);
	}else if (parseInt(fields[1]) >= parseInt(fields[14]) && parseInt(fields[1]) <= parseInt(fields[15]) && parseInt(fields[1]) > 0 && parseInt(fields[14]) >0 && parseInt(fields[15]) > 0 && parseFloat(fields[11]) >= 0)
	{
				fcheckp=1;
		      fTotal     += (parseInt(fields[1]) * parseFloat(fields[9]) + centcount1);
	}else if (parseInt(fields[1]) >= parseInt(fields[16]) && parseInt(fields[1]) <= parseInt(fields[17]) && parseInt(fields[1]) >0 && parseInt(fields[16])> 0 && parseInt(fields[17]) > 0 && parseFloat(fields[11]) >= 0)
	{
				fcheckp=1;
		      fTotal     += (parseInt(fields[1]) * parseFloat(fields[10]) + centcount1);
	}else if (parseInt(fields[1]) >= parseInt(fields[18]) && parseInt(fields[1]) >= 0 && parseInt(fields[18]) >= 0 && parseFloat(fields[11]) >= 0)
	{
				fcheckp=1;
		fTotal     += (parseInt(fields[1]) * parseFloat(fields[11]) + centcount1);
		//alert(fTotal);
		//alert(parseFloat(fields[11]));
	}

}

//alert(fTotal);

      //fTotal     += (parseInt(fields[1]) * parseFloat(fields[2]) );
	  //END

      fShipping  += (parseInt(fields[1]) * parseFloat(fields[4]) );
      fTax        = (fTotal * TaxRate);
      strTotal    = moneyFormat(fTotal);
      strTax      = moneyFormat(fTax);
      strShipping = moneyFormat(fShipping);

      if ( bDisplay ) {
         strOutput += "<TR><TD CLASS=\"nopentry\">"  + fields[0] + "</TD>";

         //if ( fields[5] == "" )
		 if (centcount1 > 0)
		 {
			 strOutput += "<TD CLASS=\"nopentry\">"  + fields[3] + "<br><b><font color=red>Personalized Amount: $" + centcount1 + "</font></b></TD>";
		 }
		 else
		  {
			 strOutput += "<TD CLASS=\"nopentry\">"  + fields[3] + "</TD>";
		  }
            
         //else
           // strOutput += "<TD CLASS=\"nopentry\">"  + fields[3] + " - <I>"+ fields[5] + "</I></TD>";
         strOutput += "<TD CLASS=\"nopentry\">"  + fields[6] + "</TD>";
		 //strOutput += "<TD CLASS=\"nopentry\">"  + centcount1 + "</TD>";
         strOutput += "<TD CLASS=\"nopentry\"><INPUT TYPE=TEXT NAME=Q SIZE=2 VALUE=\"" + fields[1] + "\" onChange=\"FavorChangeQuantity("+i+", this.value);\"></TD>";
		 //Added by Achutha
         //strOutput += "<TD CLASS=\"nopentry\">"+ MonetarySymbol + moneyFormat(fields[2]) + "</TD>";
//alert(fTotal);
if (parseInt(fields[12]) == "0" && parseInt(fields[13]) == "0" && parseInt(fields[14]) == "0" && parseInt(fields[15]) == "0" && parseInt(fields[16]) == "0" && parseInt(fields[17]) == "0" && parseInt(fields[18]) == "0") //&& parseFloat(fields[11]) >= 0
{
//	alert(fTotal);
strOutput += "<TD CLASS=\"nopentry\">"+ MonetarySymbol + moneyFormat(fields[2]) + "</TD>";	
}
else
{
	if (parseInt(fields[1]) >= parseInt(fields[12]) && parseInt(fields[1]) <= parseInt(fields[13]) && parseFloat(fields[1]) > 0 && parseFloat(fields[13]) > 0 && parseFloat(fields[12]) > 0 && parseFloat(fields[11]) >= 0)
	{
	strOutput += "<TD CLASS=\"nopentry\">"+ MonetarySymbol + moneyFormat(fields[8]) + "</TD>";
	}else if (parseInt(fields[1]) >= parseInt(fields[14]) && parseInt(fields[1]) <= parseInt(fields[15]) && parseFloat(fields[1]) > 0 && parseFloat(fields[14]) > 0 && parseFloat(fields[15]) > 0 && parseFloat(fields[11]) >= 0)
	{
	strOutput += "<TD CLASS=\"nopentry\">"+ MonetarySymbol + moneyFormat(fields[9]) + "</TD>";
	}else if (parseInt(fields[1]) >= parseInt(fields[16]) && parseInt(fields[1]) <= parseInt(fields[17]) && parseInt(fields[1]) > 0 && parseInt(fields[16]) > 0 && parseInt(fields[17]) > 0 && parseInt(fields[11]) >= 0)
	{
	strOutput += "<TD CLASS=\"nopentry\">"+ MonetarySymbol + moneyFormat(fields[10]) + "</TD>";
	}else if (parseInt(fields[1]) >= parseInt(fields[18]) && parseFloat(fields[1]) > 0 && parseFloat(fields[18]) > 0 && parseFloat(fields[11]) >= 0)
	{
	strOutput += "<TD CLASS=\"nopentry\">"+ MonetarySymbol + moneyFormat(fields[11]) + "</TD>";
	}
}	
//END
//alert (fTotal);
if(fTotal == 0 | fTotal == "")
		  {
	   strOutput += "<TD CLASS=\"nopentry\">"+ MonetarySymbol + moneyFormat(fields[2]) + "</TD>";
	   fTotal     += (parseInt(fields[1]) * parseFloat(fields[2]) + centcount1 );
	   strTotal    = moneyFormat(fTotal);
	   	//alert("Achutha--8")
			fcheckp=1;
		  }
		  //fTotal=0;

	if (fcheckp == "0")
	{
    strOutput += "<TD CLASS=\"nopentry\">"+ MonetarySymbol + moneyFormat(fields[2]) + "</TD>";
	   fTotal     += (parseInt(fields[1]) * parseFloat(fields[2]) + centcount1 );
	   strTotal    = moneyFormat(fTotal);
	}
	fcheckp=0;

         if ( DisplayShippingColumn ) {
            if ( parseFloat(fields[4]) > 0 )
               strOutput += "<TD CLASS=\"nopentry\">"+ MonetarySymbol + moneyFormat(fields[4]) + "</TD>";
            else
               strOutput += "<TD CLASS=\"nopentry\">N/A</TD>";
         }
        //strOutput += "<TD CLASS=\"nopentry\">" +"<a href='http://www.weddingveil.com'>"  + fields[7]  +"</a>"+ "</TD>";
         strOutput += "<TD CLASS=\"nopentry\" ALIGN=CENTER><input type=button value=\" "+strRButton+" \" onClick=\"RemoveFromCart("+i+")\" class=\"nopbutton\"></TD></TR>";
      }

      if ( AppendItemNumToOutput ) {
         strFooter = i;
      } else {
         strFooter = "";
      }
      if ( HiddenFieldsToCheckout ) {
         strOutput += "<input type=hidden name=\"" + OutputItemId        + strFooter + "\" value=\"" + fields[0] + "\">";
         strOutput += "<input type=hidden name=\"" + OutputItemQuantity  + strFooter + "\" value=\"" + fields[1] + "\">";
         strOutput += "<input type=hidden name=\"" + OutputItemPrice     + strFooter + "\" value=\"" + parseInt(fields[2]) + "\">";
         strOutput += "<input type=hidden name=\"" + OutputItemName      + strFooter + "\" value=\"" + fields[3] + "\">";
         strOutput += "<input type=hidden name=\"" + OutputItemShipping  + strFooter + "\" value=\"" + fields[4] + "\">";
         strOutput += "<input type=hidden name=\"" + OutputItemAddtlInfo + strFooter + "\" value=\"" + fields[5] + "\">";
      }

   }

   if ( bDisplay ) {
      strOutput += "<TR><TD CLASS=\"noptotal\" COLSPAN=5><B>"+strSUB+"</B></TD>";
	  strOutput += "<TD CLASS=\"noptotal\" COLSPAN=3><B>" + MonetarySymbol + strTotal + "</B></TD>";
      strOutput += "</TR>";

      if ( DisplayShippingRow ) {
         strOutput += "<TR><TD CLASS=\"noptotal\" COLSPAN=5><B>"+strSHIP+"</B></TD>";
         strOutput += "<TD CLASS=\"noptotal\" COLSPAN=3><B>" + MonetarySymbol + strShipping + "</B></TD>";
         strOutput += "</TR>";
      }

      if ( DisplayTaxRow || TaxByRegion ) {
         if ( TaxByRegion ) {
            strOutput += "<TR><TD CLASS=\"noptotal\" COLSPAN=5><B>"+strTAX+"</B></TD>";
            strOutput += "<TD CLASS=\"noptotal\" COLSPAN=3><B>";
            strOutput += "<input type=radio name=\""+OutputOrderTax+"\" value=\"" + strTax + "\">";
            strOutput += TaxablePrompt + ": " + MonetarySymbol + strTax;
            strOutput += "<BR><input type=radio name=\""+OutputOrderTax+"\" value=\"0.00\">";
            strOutput += NonTaxablePrompt + ": " + MonetarySymbol + "0.00";
            strOutput += "</B></TD>";
            strOutput += "</TR>";
         } else {
            strOutput += "<TR><TD CLASS=\"noptotal\" COLSPAN=5><B>"+strTAX+"</B></TD>";
            strOutput += "<TD CLASS=\"noptotal\" COLSPAN=3><B>" + MonetarySymbol + strTax + "</B></TD>";
            strOutput += "</TR>";
         }
      }

      if ( !TaxByRegion ) {
         strOutput += "<TR><TD CLASS=\"noptotal\" COLSPAN=5><B>"+strTOT+"</B></TD>";
         strOutput += "<TD CLASS=\"noptotal\" COLSPAN=3><B>" + MonetarySymbol + moneyFormat((fTotal + fShipping + fTax)) + "</B></TD>";
         strOutput += "</TR>";
      }
      strOutput += "</TABLE>";


      if ( HiddenFieldsToCheckout ) {
         strOutput += "<input type=hidden name=\""+OutputOrderSubtotal+"\" value=\""+ MonetarySymbol + strTotal + "\">";
         strOutput += "<input type=hidden name=\""+OutputOrderShipping+"\" value=\""+ MonetarySymbol + strShipping + "\">";
         strOutput += "<input type=hidden name=\""+OutputOrderTax+"\"      value=\""+ MonetarySymbol + strTax + "\">";
         strOutput += "<input type=hidden name=\""+OutputOrderTotal+"\"    value=\""+ MonetarySymbol + moneyFormat((fTotal + fShipping + fTax)) + "\">";
      }
   }
   g_TotalCost = (fTotal + fShipping + fTax);

   document.write(strOutput);
   
   //raj
   if(iNumberOrdered > 0) {
	   document.getElementById('checkoutflag').value = 1;
   }   
   
   document.close();
}


//---------------------------------------------------------------------||
// FUNCTION:    CheckoutCart                                           ||
// PARAMETERS:  Null                                                   ||
// RETURNS:     Product Table Written to Document                      ||
// PURPOSE:     Draws current cart product table on HTML page for      ||
//              checkout.                                              ||
//---------------------------------------------------------------------||
function CheckoutCart( ) {
   var iNumberOrdered = 0;    //Number of products ordered
   var fTotal         = 0;    //Total cost of order
   var fTax           = 0;    //Tax amount
   var fShipping      = 4;    //Shipping amount
   var strTotal       = "";   //Total cost formatted as money
   var strTax         = "";   //Total tax formatted as money
   var strShipping    = "";   //Total shipping formatted as money
   var strOutput      = "";   //String to be written to page
   var bDisplay       = true; //Whether to write string to the page (here for programmers)
   var strPP          = "";   //Payment Processor Description Field
   var centcount1 =0;
   var fcheckp =0;
   strColorLabel="Color";
   strStoreLabel="Store";
   iNumberOrdered = GetCookie("NumberOrdered");
   if ( iNumberOrdered == null )
      iNumberOrdered = 0;

   if ( TaxByRegion ) {
      QueryString_Parse();
      fTax = parseFloat( QueryString( OutputOrderTax ) );
      strTax = moneyFormat(fTax);
   }

   if ( bDisplay )
      strOutput = "<TABLE CLASS=\"nopcart\"><TR>" +
                  "<TD CLASS=\"nopheader\"><B>"+strILabel+"</B></TD>" +
                  "<TD CLASS=\"nopheader\"><B>"+strDLabel+"</B></TD>" +
                  "<TD CLASS=\"nopheader\"><B>"+strColorLabel+"</B></TD>" +
                  //"<TD CLASS=\"nopheader\"><B>"+strPersonalized+"</B></TD>" +
                  "<TD CLASS=\"nopheader\"><B>"+strQLabel+"</B></TD>" +
                  "<TD CLASS=\"nopheader\"><B>"+strPLabel+"</B></TD>" +
                  (DisplayShippingColumn?"<TD CLASS=\"nopheader\"><B>"+strSLabel+"</B></TD>":"") +
			"</TR>";
	//                   "<TD CLASS=\"nopheader\"><B>"+strStoreLabel+"</B></TD>" +

   for ( i = 1; i <= iNumberOrdered; i++ ) {
      NewOrder = "Order." + i;
      database = "";
      database = GetCookie(NewOrder);
	   database=ReplaceStr(database,'"','&quot;');

      Token0 = database.indexOf("|", 0);
      Token1 = database.indexOf("|", Token0+1);
      Token2 = database.indexOf("|", Token1+1);
      Token3 = database.indexOf("|", Token2+1);
      Token4 = database.indexOf("|", Token3+1);
	Token5 = database.indexOf("|", Token4+1);
	Token6 = database.indexOf("|", Token5+1);
	//Added by Achutha
	Token7 = database.indexOf("|", Token6+1);
	Token8 = database.indexOf("|", Token7+1);
	Token9 = database.indexOf("|", Token8+1);
	Token10 = database.indexOf("|", Token9+1);
	Token11 = database.indexOf("|", Token10+1);
	Token12 = database.indexOf("|", Token11+1);
	Token13 = database.indexOf("|", Token12+1);
	Token14 = database.indexOf("|", Token13+1);
	Token15 = database.indexOf("|", Token14+1);
	Token16 = database.indexOf("|", Token15+1);
	Token17 = database.indexOf("|", Token16+1);
	Token18 = database.indexOf("|", Token17+1);
	//END

      fields = new Array;
      fields[0] = database.substring( 0, Token0 );                 // Product ID
      fields[1] = database.substring( Token0+1, Token1 );          // Quantity
      fields[2] = database.substring( Token1+1, Token2 );          // Price
      fields[3] = database.substring( Token2+1, Token3 );          // Product Name/Description
      fields[4] = database.substring( Token3+1, Token4 );          // Shipping Cost
      fields[5] = database.substring( Token4+1, Token5 ); 		 //Additional Information
      fields[6] = database.substring( Token5+1, Token6 ); 		 //Color
      //fields[7] = database.substring( Token6+1, database.length ); //Store Name
	  //Added by Achutha
	  fields[7] = database.substring( Token6+1, Token7 ); // Storename
	  fields[8] = database.substring( Token7+1, Token8 ); //firtlist
	  fields[9] = database.substring( Token8+1, Token9 ); //secondlist
	  fields[10] = database.substring( Token9+1, Token10 ); //thirdlist
	  fields[11] = database.substring( Token10+1, Token11 ); //fourthlist
	  fields[12] = database.substring( Token11+1, Token12 ); //fristquanty
	  fields[13] = database.substring( Token12+1, Token13 ); //firstquanty1
  	  fields[14] = database.substring( Token13+1, Token14 ); //secondquanty
  	  fields[15] = database.substring( Token14+1, Token15 ); //secondquanty1
  	  fields[16] = database.substring( Token15+1, Token16 ); //thirdquanty
  	  fields[17] = database.substring( Token16+1, Token17 ); //thirdquanty1
  	  fields[18] = database.substring( Token17+1, Token18 ); //fourquanty
	  fields[19] = database.substring( Token18+1, database.length ); //fourquanty
//END
//alert("ACHUTHA");
if (fields[19] != "" && fields[19] !=0 && fields[19] > 0)
{
centcount1 = Math.round((parseInt(fields[1]) * parseFloat(fields[19]))*100)/100;
}
else
{
centcount1=0;
}
if (parseInt(fields[12]) == "0" && parseInt(fields[13]) == "0" && parseInt(fields[14]) == "0" && parseInt(fields[15]) == "0" && parseInt(fields[16]) == "0" && parseInt(fields[17]) == "0" && parseInt(fields[18]) == "0")
{
//alert(fTotal);
      fTotal     += (parseInt(fields[1]) * parseFloat(fields[2]) + centcount1 );
	  fcheckp=1;
}
else
{
	if (parseInt(fields[1]) >= parseInt(fields[12]) && parseInt(fields[1]) <= parseInt(fields[13]) && parseInt(fields[13]) > 0 && parseInt(fields[1]) > 0 && parseInt(fields[12]) > 0 && parseFloat(fields[11]) >= 0)
	{
//		alert(fTotal);
	      fTotal     += (parseInt(fields[1]) * parseFloat(fields[8]) + centcount1);
		  		fcheckp=1;
	}else if (parseInt(fields[1]) >= parseInt(fields[14]) && parseInt(fields[1]) <= parseInt(fields[15]) && parseInt(fields[1]) > 0 && parseInt(fields[14]) >0 && parseInt(fields[15]) > 0 && parseFloat(fields[11]) >= 0)
	{
//		alert(fTotal);
		      fTotal     += (parseInt(fields[1]) * parseFloat(fields[9]) + centcount1);
			  		fcheckp=1;
	}else if (parseInt(fields[1]) >= parseInt(fields[16]) && parseInt(fields[1]) <= parseInt(fields[17]) && parseInt(fields[1]) >0 && parseInt(fields[16])> 0 && parseInt(fields[17]) > 0 && parseFloat(fields[11]) >= 0)
	{
//	alert(fTotal);
		      fTotal     += (parseInt(fields[1]) * parseFloat(fields[10]) + centcount1);
			  		fcheckp=1;
	}else if (parseInt(fields[1]) >= parseInt(fields[18]) && parseInt(fields[1]) >= 0 && parseInt(fields[18]) >= 0 && parseFloat(fields[11]) >= 0)
	{
		//alert(fTotal);
		      fTotal     += (parseInt(fields[1]) * parseFloat(fields[11]) + centcount1);
			  		fcheckp=1;
	}
}
      fShipping  += (parseInt(fields[1]) * parseFloat(fields[4]) );
      if ( !TaxByRegion ) fTax = (fTotal * TaxRate);
      strTotal    = moneyFormat(fTotal);
      if ( !TaxByRegion ) strTax = moneyFormat(fTax);
      strShipping = moneyFormat(fShipping);

      if ( bDisplay ) {
         strOutput += "<TR><TD CLASS=\"nopentry\">"  + fields[0] + "</TD>";

         //if ( fields[5] == "" )
		 if (centcount1 > 0)
		 {
            strOutput += "<TD CLASS=\"nopentry\">"  + fields[3] + "<br><b><font color=red>Personalized Amount: $" + centcount1 + "</font></b></TD>";
		 }
		 else
		  {
           strOutput += "<TD CLASS=\"nopentry\">"  + fields[3] + "</TD>";
		  }

         //else
           // strOutput += "<TD CLASS=\"nopentry\">"  + fields[3] + " - <I>"+ fields[5] + "</I></TD>";
         strOutput += "<TD CLASS=\"nopentry\">"  + fields[6] + "</TD>";
		 //strOutput += "<TD CLASS=\"nopentry\">"  + centcount1 + "</TD>";
         strOutput += "<TD CLASS=\"nopentry\">" + fields[1] + "</TD>";
		 if (parseInt(fields[12]) == "0" && parseInt(fields[13]) == "0" && parseInt(fields[14]) == "0" && parseInt(fields[15]) == "0" && parseInt(fields[16]) == "0" && parseInt(fields[17]) == "0" && parseInt(fields[18]) == "0")
		{
         strOutput += "<TD CLASS=\"nopentry\">"+ MonetarySymbol + moneyFormat(fields[2]) + centcount1 +"</TD>";
		}
		else
{
	if (parseInt(fields[1]) >= parseInt(fields[12]) && parseInt(fields[1]) <= parseInt(fields[13]) && parseFloat(fields[1]) > 0 && parseFloat(fields[13]) > 0 && parseFloat(fields[12]) > 0 && parseFloat(fields[11]) >= 0)
	{
	strOutput += "<TD CLASS=\"nopentry\">"+ MonetarySymbol + moneyFormat(fields[8]) + "</TD>";
	}else if (parseInt(fields[1]) >= parseInt(fields[14]) && parseInt(fields[1]) <= parseInt(fields[15]) && parseFloat(fields[1]) > 0 && parseFloat(fields[14]) > 0 && parseFloat(fields[15]) > 0 && parseFloat(fields[11]) >= 0)
	{
	strOutput += "<TD CLASS=\"nopentry\">"+ MonetarySymbol + moneyFormat(fields[9]) + "</TD>";
	}else if (parseInt(fields[1]) >= parseInt(fields[16]) && parseInt(fields[1]) <= parseInt(fields[17]) && parseInt(fields[1]) > 0 && parseInt(fields[16]) > 0 && parseInt(fields[17]) > 0 && parseInt(fields[11]) >= 0)
	{
	strOutput += "<TD CLASS=\"nopentry\">"+ MonetarySymbol + moneyFormat(fields[10]) + "</TD>";
	}else if (parseInt(fields[1]) >= parseInt(fields[18]) && parseFloat(fields[1]) > 0 && parseFloat(fields[18]) > 0 && parseFloat(fields[11]) >= 0)
	{
	strOutput += "<TD CLASS=\"nopentry\">"+ MonetarySymbol + moneyFormat(fields[11]) + "</TD>";
	}
}

if(fTotal == 0 | fTotal == "")
		  {
   strOutput += "<TD CLASS=\"nopentry\">"+ MonetarySymbol + moneyFormat(fields[2]) + "</TD>";
   //alert(centcount1);
	   fTotal     += (parseInt(fields[1]) * parseFloat(fields[2]) + centcount1);
	   strTotal    = moneyFormat(fTotal);
	  // 	alert("Achutha--8")
			fcheckp=1;
		  }
		  //fTotal=0;

	if (fcheckp == "0")
	{
    strOutput += "<TD CLASS=\"nopentry\">"+ MonetarySymbol + moneyFormat(fields[2]) + "</TD>";
	   fTotal     += (parseInt(fields[1]) * parseFloat(fields[2]) + centcount1 );
	   strTotal    = moneyFormat(fTotal);
	}
	fcheckp=0;
//	alert(fTotal);

         if ( DisplayShippingColumn ) {
            if ( parseFloat(fields[4]) > 0 )
               strOutput += "<TD CLASS=\"nopentry\">"+ MonetarySymbol + moneyFormat(fields[4]) + "</TD>";
            else
               strOutput += "<TD CLASS=\"nopentry\">N/A</TD>";
         }
         //strOutput += "<TD CLASS=\"nopentry\">"  +"<a href='http://www.weddingveil.com'>"+ fields[7] + "</a>"+"</TD>";
         strOutput += "</TR>";
      }

      if ( AppendItemNumToOutput ) {
         strFooter = i;
      } else {
         strFooter = "";
      }
      if ( PaymentProcessor != '' ) {
         //Process description field for payment processors instead of hidden values.
         //Format Description of product as:
         // ID, Name, Qty X
         strPP += fields[0] + ", " + fields[3];
         if ( fields[5] != "" )
            strPP += " - " + fields[5];
         strPP += ", Qty. " + fields[1] + "\n";
      } else {
         strOutput += "<input type=hidden name=\"" + OutputItemId        + strFooter + "\" value=\"" + fields[0] + "\">";
         strOutput += "<input type=hidden name=\"" + OutputItemQuantity  + strFooter + "\" value=\"" + fields[1] + "\">";
         strOutput += "<input type=hidden name=\"" + OutputItemPrice     + strFooter + "\" value=\"" + fields[2] + "\">";
         strOutput += "<input type=hidden name=\"" + OutputItemName      + strFooter + "\" value=\"" + fields[3] + "\">";
		 //2/15/05 - following 2 lines commented out so that Shipping and additional info for each
		 //product will not show up in the order email
         //strOutput += "<input type=hidden name=\"" + OutputItemShipping  + strFooter + "\" value=\"" + fields[4] + "\">";
         //strOutput += "<input type=hidden name=\"" + OutputItemAddtlInfo + strFooter + "\" value=\"" + fields[5] + "\">";
      } 

   }

   if ( bDisplay ) {
      strOutput += "<TR><TD CLASS=\"noptotal\" COLSPAN=4><B>"+strSUB+"</B></TD>";
      strOutput += "<TD CLASS=\"noptotal\" COLSPAN=2 ALIGN=RIGHT><B><span id=\"SUBTOTALCELL\" name=\"SUBTOTALCELL\">" + MonetarySymbol + strTotal + "</span></B></TD>";
      strOutput += "</TR>";

      if ( DisplayShippingRow ) {
         strOutput += "<TR><TD CLASS=\"noptotal\" COLSPAN=4><B>"+strSHIP+"</B></TD>";
         strOutput += "<TD CLASS=\"noptotal\" COLSPAN=2 ALIGN=RIGHT><B><span id=\"SHIPPINGCELL\" name=\"SHIPPINGCELL\">" + MonetarySymbol + strShipping + "</span></B></TD>";
         strOutput += "</TR>";
      }

      if ( DisplayTaxRow || TaxByRegion ) {
         strOutput += "<TR><TD CLASS=\"noptotal\" COLSPAN=4><B>"+strTAX+"</B></TD>";
         strOutput += "<TD CLASS=\"noptotal\" COLSPAN=2 ALIGN=RIGHT><B><span id=\"TAXCELL\" name=\"TAXCELL\">" + MonetarySymbol + strTax + "</span></B></TD>";
         strOutput += "</TR>";
      }

      strOutput += "<TR><TD CLASS=\"noptotal\" COLSPAN=4><B>"+strTOT+"</B></TD>";
      strOutput += "<TD CLASS=\"noptotal\" COLSPAN=2 ALIGN=RIGHT><B><span id=\"TOTALCELL\" name=\"TOTALCELL\">" + MonetarySymbol + moneyFormat((fTotal + fShipping + fTax)) + "</span></B></TD>";
      strOutput += "</TR>";

      strOutput += "</TABLE>";

      
      if ( PaymentProcessor == 'an') {
         //Process this for Authorize.net WebConnect
         strOutput += "<input type=hidden name=\"x_Version\" value=\"3.0\">";
         strOutput += "<input type=hidden name=\"x_Show_Form\" value=\"PAYMENT_FORM\">";
         strOutput += "<input type=hidden name=\"x_Description\" value=\""+ strPP + "\">";
         strOutput += "<input type=hidden name=\"x_Amount\" value=\""+ moneyFormat((fTotal + fShipping + fTax)) + "\">";
      } else if ( PaymentProcessor == 'wp') {
         //Process this for WorldPay
         strOutput += "<input type=hidden name=\"desc\" value=\""+ strPP + "\">";
         strOutput += "<input type=hidden name=\"amount\" value=\""+ moneyFormat((fTotal + fShipping + fTax)) + "\">";
      } else if ( PaymentProcessor == 'lp') {
         //Process this for LinkPoint         
         strOutput += "<input type=hidden name=\"mode\" value=\"fullpay\">";
         strOutput += "<input type=hidden name=\"chargetotal\" value=\""+ moneyFormat((fTotal + fShipping + fTax)) + "\">";
         strOutput += "<input type=hidden name=\"tax\" value=\""+ MonetarySymbol + strTax + "\">";
         strOutput += "<input type=hidden name=\"subtotal\" value=\""+ MonetarySymbol + strTotal + "\">";
         strOutput += "<input type=hidden name=\"shipping\" value=\""+ MonetarySymbol + strShipping + "\">";
         strOutput += "<input type=hidden name=\"desc\" value=\""+ strPP + "\">";
      } else {
         strOutput += "<input type=hidden name=\""+OutputOrderSubtotal+"\" id=\""+OutputOrderSubtotal+"\" value=\""+ MonetarySymbol + strTotal + "\">";
         strOutput += "<input type=hidden name=\""+OutputOrderShipping+"\" value=\""+ MonetarySymbol + strShipping + "\">";
         strOutput += "<input type=hidden name=\""+OutputOrderTax+"\"      value=\""+ MonetarySymbol + strTax + "\">";
         strOutput += "<input type=hidden name=\""+OutputOrderTotal+"\"    value=\""+ MonetarySymbol + moneyFormat((fTotal + fShipping + fTax)) + "\">";
      }
   }

   document.write(strOutput);
   document.close();
}

//---------------------------------------------------------------------||
// FUNCTION:    CheckoutCartTemp                                           ||
// PARAMETERS:  Null                                                   ||
// RETURNS:     Product Table Written to Document                      ||
// PURPOSE:     Draws current cart product table on HTML page for      ||
//              checkout.                                              ||
//---------------------------------------------------------------------||
function CheckoutCartTemp() {
	var tCookie = tempCookie;
   var iNumberOrdered = 0;    //Number of products ordered
   var fTotal         = 0;    //Total cost of order
   var fTax           = 0;    //Tax amount
   var fShipping      = 4;    //Shipping amount
   var strTotal       = "";   //Total cost formatted as money
   var strTax         = "";   //Total tax formatted as money
   var strShipping    = "";   //Total shipping formatted as money
   var strOutput      = "";   //String to be written to page
   var bDisplay       = true; //Whether to write string to the page (here for programmers)
   var strPP          = "";   //Payment Processor Description Field
   var centcount1 =0;
   var fcheckp =0;
   strColorLabel="Color";
   strStoreLabel="Store";
   iNumberOrdered = GetCookieTemp(tCookie, "NumberOrdered");
   iNumberOrdered = iNumberOrdered.replace('+', '');
      document.getElementById('divID').innerHTML = "&nbsp;" ; //'j'+iNumberOrdered;
   if ( iNumberOrdered == null )
      iNumberOrdered = 0;

   if ( TaxByRegion ) {
      QueryString_Parse();
      fTax = parseFloat( QueryString( OutputOrderTax ) );
      strTax = moneyFormat(fTax);
   }

   if ( bDisplay )
      strOutput = "<TABLE CLASS=\"nopcart\"><TR>" +
                  "<TD CLASS=\"nopheader\"><B>"+strILabel+"</B></TD>" +
                  "<TD CLASS=\"nopheader\"><B>"+strDLabel+"</B></TD>" +
                  "<TD CLASS=\"nopheader\"><B>"+strColorLabel+"</B></TD>" +
                  //"<TD CLASS=\"nopheader\"><B>"+strPersonalized+"</B></TD>" +
                  "<TD CLASS=\"nopheader\"><B>"+strQLabel+"</B></TD>" +
                  "<TD CLASS=\"nopheader\"><B>"+strPLabel+"</B></TD>" +
                  (DisplayShippingColumn?"<TD CLASS=\"nopheader\"><B>"+strSLabel+"</B></TD>":"") +
			"</TR>";
	//                   "<TD CLASS=\"nopheader\"><B>"+strStoreLabel+"</B></TD>" +

   for ( i = 1; i <= iNumberOrdered; i++ ) {
      NewOrder = "Order." + i;
      database = "";
      database = GetCookieTemp(tCookie, NewOrder);
	   database=ReplaceStr(database,'"','&quot;');

      Token0 = database.indexOf("|", 0);
      Token1 = database.indexOf("|", Token0+1);
      Token2 = database.indexOf("|", Token1+1);
      Token3 = database.indexOf("|", Token2+1);
      Token4 = database.indexOf("|", Token3+1);
	Token5 = database.indexOf("|", Token4+1);
	Token6 = database.indexOf("|", Token5+1);
	//Added by Achutha
	Token7 = database.indexOf("|", Token6+1);
	Token8 = database.indexOf("|", Token7+1);
	Token9 = database.indexOf("|", Token8+1);
	Token10 = database.indexOf("|", Token9+1);
	Token11 = database.indexOf("|", Token10+1);
	Token12 = database.indexOf("|", Token11+1);
	Token13 = database.indexOf("|", Token12+1);
	Token14 = database.indexOf("|", Token13+1);
	Token15 = database.indexOf("|", Token14+1);
	Token16 = database.indexOf("|", Token15+1);
	Token17 = database.indexOf("|", Token16+1);
	Token18 = database.indexOf("|", Token17+1);
	//END

      fields = new Array;
      fields[0] = database.substring( 0, Token0 );                 // Product ID
      fields[1] = database.substring( Token0+1, Token1 );          // Quantity
      fields[2] = database.substring( Token1+1, Token2 );          // Price
      fields[3] = database.substring( Token2+1, Token3 );          // Product Name/Description
      fields[4] = database.substring( Token3+1, Token4 );          // Shipping Cost
      fields[5] = database.substring( Token4+1, Token5 ); 		 //Additional Information
      fields[6] = database.substring( Token5+1, Token6 ); 		 //Color
      //fields[7] = database.substring( Token6+1, database.length ); //Store Name
	  //Added by Achutha
	  fields[7] = database.substring( Token6+1, Token7 ); // Storename
	  fields[8] = database.substring( Token7+1, Token8 ); //firtlist
	  fields[9] = database.substring( Token8+1, Token9 ); //secondlist
	  fields[10] = database.substring( Token9+1, Token10 ); //thirdlist
	  fields[11] = database.substring( Token10+1, Token11 ); //fourthlist
	  fields[12] = database.substring( Token11+1, Token12 ); //fristquanty
	  fields[13] = database.substring( Token12+1, Token13 ); //firstquanty1
  	  fields[14] = database.substring( Token13+1, Token14 ); //secondquanty
  	  fields[15] = database.substring( Token14+1, Token15 ); //secondquanty1
  	  fields[16] = database.substring( Token15+1, Token16 ); //thirdquanty
  	  fields[17] = database.substring( Token16+1, Token17 ); //thirdquanty1
  	  fields[18] = database.substring( Token17+1, Token18 ); //fourquanty
	  fields[19] = database.substring( Token18+1, database.length ); //fourquanty
//END
//alert("ACHUTHA");
if (fields[19] != "" && fields[19] !=0 && fields[19] > 0)
{
centcount1 = Math.round((parseInt(fields[1]) * parseFloat(fields[19]))*100)/100;
}
else
{
centcount1=0;
}
if (parseInt(fields[12]) == "0" && parseInt(fields[13]) == "0" && parseInt(fields[14]) == "0" && parseInt(fields[15]) == "0" && parseInt(fields[16]) == "0" && parseInt(fields[17]) == "0" && parseInt(fields[18]) == "0")
{
//alert(fTotal);
      fTotal     += (parseInt(fields[1]) * parseFloat(fields[2]) + centcount1 );
	  fcheckp=1;
}
else
{
	if (parseInt(fields[1]) >= parseInt(fields[12]) && parseInt(fields[1]) <= parseInt(fields[13]) && parseInt(fields[13]) > 0 && parseInt(fields[1]) > 0 && parseInt(fields[12]) > 0 && parseFloat(fields[11]) >= 0)
	{
//		alert(fTotal);
	      fTotal     += (parseInt(fields[1]) * parseFloat(fields[8]) + centcount1);
		  		fcheckp=1;
	}else if (parseInt(fields[1]) >= parseInt(fields[14]) && parseInt(fields[1]) <= parseInt(fields[15]) && parseInt(fields[1]) > 0 && parseInt(fields[14]) >0 && parseInt(fields[15]) > 0 && parseFloat(fields[11]) >= 0)
	{
//		alert(fTotal);
		      fTotal     += (parseInt(fields[1]) * parseFloat(fields[9]) + centcount1);
			  		fcheckp=1;
	}else if (parseInt(fields[1]) >= parseInt(fields[16]) && parseInt(fields[1]) <= parseInt(fields[17]) && parseInt(fields[1]) >0 && parseInt(fields[16])> 0 && parseInt(fields[17]) > 0 && parseFloat(fields[11]) >= 0)
	{
//	alert(fTotal);
		      fTotal     += (parseInt(fields[1]) * parseFloat(fields[10]) + centcount1);
			  		fcheckp=1;
	}else if (parseInt(fields[1]) >= parseInt(fields[18]) && parseInt(fields[1]) >= 0 && parseInt(fields[18]) >= 0 && parseFloat(fields[11]) >= 0)
	{
		//alert(fTotal);
		      fTotal     += (parseInt(fields[1]) * parseFloat(fields[11]) + centcount1);
			  		fcheckp=1;
	}
}
      fShipping  += (parseInt(fields[1]) * parseFloat(fields[4]) );
      if ( !TaxByRegion ) fTax = (fTotal * TaxRate);
      strTotal    = moneyFormat(fTotal);
      if ( !TaxByRegion ) strTax = moneyFormat(fTax);
      strShipping = moneyFormat(fShipping);

      if ( bDisplay ) {
         strOutput += "<TR><TD CLASS=\"nopentry\">"  + fields[0] + "</TD>";

         //if ( fields[5] == "" )
		 if (centcount1 > 0)
		 {
            strOutput += "<TD CLASS=\"nopentry\">"  + fields[3] + "<br><b><font color=red>Personalized Amount: $" + centcount1 + "</font></b></TD>";
		 }
		 else
		  {
           strOutput += "<TD CLASS=\"nopentry\">"  + fields[3] + "</TD>";
		  }

         //else
           // strOutput += "<TD CLASS=\"nopentry\">"  + fields[3] + " - <I>"+ fields[5] + "</I></TD>";
         strOutput += "<TD CLASS=\"nopentry\">"  + fields[6] + "</TD>";
		 //strOutput += "<TD CLASS=\"nopentry\">"  + centcount1 + "</TD>";
         strOutput += "<TD CLASS=\"nopentry\">" + fields[1] + "</TD>";
		 if (parseInt(fields[12]) == "0" && parseInt(fields[13]) == "0" && parseInt(fields[14]) == "0" && parseInt(fields[15]) == "0" && parseInt(fields[16]) == "0" && parseInt(fields[17]) == "0" && parseInt(fields[18]) == "0")
		{
         strOutput += "<TD CLASS=\"nopentry\">"+ MonetarySymbol + moneyFormat(fields[2]) + centcount1 +"</TD>";
		}
		else
{
	if (parseInt(fields[1]) >= parseInt(fields[12]) && parseInt(fields[1]) <= parseInt(fields[13]) && parseFloat(fields[1]) > 0 && parseFloat(fields[13]) > 0 && parseFloat(fields[12]) > 0 && parseFloat(fields[11]) >= 0)
	{
	strOutput += "<TD CLASS=\"nopentry\">"+ MonetarySymbol + moneyFormat(fields[8]) + "</TD>";
	}else if (parseInt(fields[1]) >= parseInt(fields[14]) && parseInt(fields[1]) <= parseInt(fields[15]) && parseFloat(fields[1]) > 0 && parseFloat(fields[14]) > 0 && parseFloat(fields[15]) > 0 && parseFloat(fields[11]) >= 0)
	{
	strOutput += "<TD CLASS=\"nopentry\">"+ MonetarySymbol + moneyFormat(fields[9]) + "</TD>";
	}else if (parseInt(fields[1]) >= parseInt(fields[16]) && parseInt(fields[1]) <= parseInt(fields[17]) && parseInt(fields[1]) > 0 && parseInt(fields[16]) > 0 && parseInt(fields[17]) > 0 && parseInt(fields[11]) >= 0)
	{
	strOutput += "<TD CLASS=\"nopentry\">"+ MonetarySymbol + moneyFormat(fields[10]) + "</TD>";
	}else if (parseInt(fields[1]) >= parseInt(fields[18]) && parseFloat(fields[1]) > 0 && parseFloat(fields[18]) > 0 && parseFloat(fields[11]) >= 0)
	{
	strOutput += "<TD CLASS=\"nopentry\">"+ MonetarySymbol + moneyFormat(fields[11]) + "</TD>";
	}
}

if(fTotal == 0 | fTotal == "")
		  {
   strOutput += "<TD CLASS=\"nopentry\">"+ MonetarySymbol + moneyFormat(fields[2]) + "</TD>";
   //alert(centcount1);
	   fTotal     += (parseInt(fields[1]) * parseFloat(fields[2]) + centcount1);
	   strTotal    = moneyFormat(fTotal);
	  // 	alert("Achutha--8")
			fcheckp=1;
		  }
		  //fTotal=0;

	if (fcheckp == "0")
	{
    strOutput += "<TD CLASS=\"nopentry\">"+ MonetarySymbol + moneyFormat(fields[2]) + "</TD>";
	   fTotal     += (parseInt(fields[1]) * parseFloat(fields[2]) + centcount1 );
	   strTotal    = moneyFormat(fTotal);
	}
	fcheckp=0;
//	alert(fTotal);

         if ( DisplayShippingColumn ) {
            if ( parseFloat(fields[4]) > 0 )
               strOutput += "<TD CLASS=\"nopentry\">"+ MonetarySymbol + moneyFormat(fields[4]) + "</TD>";
            else
               strOutput += "<TD CLASS=\"nopentry\">N/A</TD>";
         }
         //strOutput += "<TD CLASS=\"nopentry\">"  +"<a href='http://www.weddingveil.com'>"+ fields[7] + "</a>"+"</TD>";
         strOutput += "</TR>";
      }

      if ( AppendItemNumToOutput ) {
         strFooter = i;
      } else {
         strFooter = "";
      }
      if ( PaymentProcessor != '' ) {
         //Process description field for payment processors instead of hidden values.
         //Format Description of product as:
         // ID, Name, Qty X
         strPP += fields[0] + ", " + fields[3];
         if ( fields[5] != "" )
            strPP += " - " + fields[5];
         strPP += ", Qty. " + fields[1] + "\n";
      } else {
         strOutput += "<input type=hidden name=\"" + OutputItemId        + strFooter + "\" value=\"" + fields[0] + "\">";
         strOutput += "<input type=hidden name=\"" + OutputItemQuantity  + strFooter + "\" value=\"" + fields[1] + "\">";
         strOutput += "<input type=hidden name=\"" + OutputItemPrice     + strFooter + "\" value=\"" + fields[2] + "\">";
         strOutput += "<input type=hidden name=\"" + OutputItemName      + strFooter + "\" value=\"" + fields[3] + "\">";
		 //2/15/05 - following 2 lines commented out so that Shipping and additional info for each
		 //product will not show up in the order email
         //strOutput += "<input type=hidden name=\"" + OutputItemShipping  + strFooter + "\" value=\"" + fields[4] + "\">";
         //strOutput += "<input type=hidden name=\"" + OutputItemAddtlInfo + strFooter + "\" value=\"" + fields[5] + "\">";
      } 

   }

   if ( bDisplay ) {
      strOutput += "<TR><TD CLASS=\"noptotal\" COLSPAN=4><B>"+strSUB+"</B></TD>";
      strOutput += "<TD CLASS=\"noptotal\" COLSPAN=2 ALIGN=RIGHT><B><span id=\"SUBTOTALCELL\" name=\"SUBTOTALCELL\">" + MonetarySymbol + strTotal + "</span></B></TD>";
      strOutput += "</TR>";

      if ( DisplayShippingRow ) {
         strOutput += "<TR><TD CLASS=\"noptotal\" COLSPAN=4><B>"+strSHIP+"</B></TD>";
         strOutput += "<TD CLASS=\"noptotal\" COLSPAN=2 ALIGN=RIGHT><B><span id=\"SHIPPINGCELL\" name=\"SHIPPINGCELL\">" + MonetarySymbol + strShipping + "</span></B></TD>";
         strOutput += "</TR>";
      }

      if ( DisplayTaxRow || TaxByRegion ) {
         strOutput += "<TR><TD CLASS=\"noptotal\" COLSPAN=4><B>"+strTAX+"</B></TD>";
         strOutput += "<TD CLASS=\"noptotal\" COLSPAN=2 ALIGN=RIGHT><B><span id=\"TAXCELL\" name=\"TAXCELL\">" + MonetarySymbol + strTax + "</span></B></TD>";
         strOutput += "</TR>";
      }

      strOutput += "<TR><TD CLASS=\"noptotal\" COLSPAN=4><B>"+strTOT+"</B></TD>";
      strOutput += "<TD CLASS=\"noptotal\" COLSPAN=2 ALIGN=RIGHT><B><span id=\"TOTALCELL\" name=\"TOTALCELL\">" + MonetarySymbol + moneyFormat((fTotal + fShipping + fTax)) + "</span></B></TD>";
      strOutput += "</TR>";

      strOutput += "</TABLE>";

      
      if ( PaymentProcessor == 'an') {
         //Process this for Authorize.net WebConnect
         strOutput += "<input type=hidden name=\"x_Version\" value=\"3.0\">";
         strOutput += "<input type=hidden name=\"x_Show_Form\" value=\"PAYMENT_FORM\">";
         strOutput += "<input type=hidden name=\"x_Description\" value=\""+ strPP + "\">";
         strOutput += "<input type=hidden name=\"x_Amount\" value=\""+ moneyFormat((fTotal + fShipping + fTax)) + "\">";
      } else if ( PaymentProcessor == 'wp') {
         //Process this for WorldPay
         strOutput += "<input type=hidden name=\"desc\" value=\""+ strPP + "\">";
         strOutput += "<input type=hidden name=\"amount\" value=\""+ moneyFormat((fTotal + fShipping + fTax)) + "\">";
      } else if ( PaymentProcessor == 'lp') {
         //Process this for LinkPoint         
         strOutput += "<input type=hidden name=\"mode\" value=\"fullpay\">";
         strOutput += "<input type=hidden name=\"chargetotal\" value=\""+ moneyFormat((fTotal + fShipping + fTax)) + "\">";
         strOutput += "<input type=hidden name=\"tax\" value=\""+ MonetarySymbol + strTax + "\">";
         strOutput += "<input type=hidden name=\"subtotal\" value=\""+ MonetarySymbol + strTotal + "\">";
         strOutput += "<input type=hidden name=\"shipping\" value=\""+ MonetarySymbol + strShipping + "\">";
         strOutput += "<input type=hidden name=\"desc\" value=\""+ strPP + "\">";
      } else {
         strOutput += "<input type=hidden name=\""+OutputOrderSubtotal+"\" id=\""+OutputOrderSubtotal+"\" value=\""+ MonetarySymbol + strTotal + "\">";
         strOutput += "<input type=hidden name=\""+OutputOrderShipping+"\" value=\""+ MonetarySymbol + strShipping + "\">";
         strOutput += "<input type=hidden name=\""+OutputOrderTax+"\"      value=\""+ MonetarySymbol + strTax + "\">";
         strOutput += "<input type=hidden name=\""+OutputOrderTotal+"\"    value=\""+ MonetarySymbol + moneyFormat((fTotal + fShipping + fTax)) + "\">";
      }
   }

   document.write(strOutput);
   document.close();
}

//---------------------------------------------------------------------||
// FUNCTION:    GetCookieTemp                                          ||
// PARAMETERS:  Name                                                   ||
// RETURNS:     Value in Cookie                                        ||
// PURPOSE:     Retrieves cookie from users browser                    ||
//---------------------------------------------------------------------||
function GetCookieTemp (tCookie, name) {
   var arg = name + "=";
   var alen = arg.length;
   var clen = tCookie.length;
   var i = 0;
   while ( i < clen ) {
      var j = i + alen;
      if ( tCookie.substring(i, j) == arg ) return(getCookieValTemp (tCookie, j));
      i = tCookie.indexOf(" ", i) + 1;
      if ( i == 0 ) break;
   }
   return(null);
}

//---------------------------------------------------------------------||
// FUNCTION:    getCookieValTemp                                       ||
// PARAMETERS:  offset                                                 ||
// RETURNS:     URL unescaped Cookie Value                             ||
// PURPOSE:     Get a specific value from a cookie                     ||
//---------------------------------------------------------------------||
function getCookieValTemp (tCookie, offset) {
   var endstr = tCookie.indexOf (";", offset);

   if ( endstr == -1 )
      endstr = tCookie.length;
   return(unescape(tCookie.substring(offset, endstr)));
}
//===========================Favors Script Ends========================||
//=====================================================================||



//=====================================================================||
//               END NOP Design SmartPost Shopping Cart                ||
//=====================================================================||

