#!/usr/bin/perl

MAIN:
{

	$server = $ENV{'SERVER_NAME'};
	$query  = $ENV{'QUERY_STRING'};
	$query0 = $query;
	$query0 =~ s/\&price\_range\=.*//g;

	$domain = $server;
	if   ( $domain =~ m/sex\-superstore/i ) { $domain = '.sex-superstore.com' }
	else                                    { $domain = '' }

	print &PrintHeader;

	#affiliate flag
	if (    !( $server =~ m/pexxx/i )
		and !( $server =~ m/privateentertainment/i )
		and !( $server =~ m/myadultwarehouse/i ) )
	{
		$aff_flag = 1;
	}
	if (   $server =~ /shop\.sex\-superstore\.com/i
		or $server =~ /store\.sex\-superstore\.com/i
		or $server =~ /store\.dev\.sex\-superstore\.com/i
		or $server =~ /shop\.dev\.sex\-superstore\.com/i )
	{
		$aff_super = 1;
	}

	$status = 'date';

	#initial categories
	@asso00 = (
		'hotdeal',  'anal',    'gaggift',  'battery',
		'bondage',  'book',    'cockring', 'condom',
		'dildo',    'egg',     'enhancer', 'extension',
		'couples',  'games',   'grooming', 'headcleaner',
		'herbals',  'jewelry', 'lingerie', 'doll',
		'lube',     'massage', 'vagina',   'pump',
		'strap-on', 'vibrator'
	);

	#init-name  association
	@asso0 = (
		'all',         'New Releases', 'hotdeal',  'Hot Deals!',
		'anal',        'Anal Toys',    'gaggift',  'Bachelorette',
		'battery',     'Batteries',    'bondage',  'Bondage',
		'book',        'Books',        'cockring', 'Cockrings',
		'condom',      'Condoms',      'dildo',    'Dildos/Dongs',
		'egg',         'Eggs/Bullets', 'enhancer', 'Enhancers',
		'extension',   'Extensions',   'couples',  'For Couples',
		'games',       'Games',        'grooming', 'Grooming',
		'headcleaner', 'Head Cleaner', 'herbals',  'Herbals',
		'jewelry',     'Jewelry',      'lingerie', 'Lingerie',
		'doll',        'Love Dolls',   'lube',     'Lubricants',
		'massage',     'Massage',      'vagina',   'Masturbators',
		'pump',        'Penis Pumps',  'strap-on', 'Strap-Ons',
		'vibrator',    'Vibrators'
	);
	%asso0 = @asso0;

	use CGI;
	$foo = new CGI;

	#DATE
	local ( $sec, $min, $hour, $mday, $mon, $year, $wday, $yday, $isdst ) =
	  localtime(time);
	$year = 1900 + $year;
	local (@month) = (
		'January',   'February', 'March',    'April',
		'May',       'June',     'July',     'August',
		'September', 'October',  'November', 'December'
	);
	local ($mo) = $month[$mon];

	&ReadParse;
	(
		$ecode,      $text,       $type,    $criteria, $last_list,
		$first_list, $fam,        $hotdeal, $discount, $bestseller,
		$init,       $dozen_list, $letter,  $search,   $init1,
		$affiliate,  $battery,    $price_range
	  )
	  = (
		$in{'ecode'},      $in{'text'},      $in{'type'},
		$in{'criteria'},   $in{'last_list'}, $in{'first_list'},
		$in{'fam'},        $in{'hotdeal'},   $in{'discount'},
		$in{'bestseller'}, $in{'init'},      $in{'dozen_list'},
		$in{'letter'},     $in{'search'},    $in{'init1'},
		$in{'af'},         $in{'battery'},   $in{'price_range'}
	  );
	  
	if (length($ecode) > 10) {
		die('Invalid Parameter');
	}
		  
	if ( $text eq 'hotdeal' or $init eq 'hotdeal' ) { $hotdeal = 'Yes' }

	if ( $criteria eq 'voldiscount' or $init eq 'voldiscount' ) {
		$discount = 'Yes';
		$init     = 'voldiscount';
	}
	if ( $criteria eq 'init' ) { $init = $text }
	if ( !$init and !$criteria ) { $init = 'all' }

	&get_cookie;
	$stock = $cookie{'stock'};
	$stock = substr( $stock, 0, 1 );
	if (
		!$stock
		or (    $stock ne 'N'
			and $stock ne 'T'
			and $stock ne 'A'
			and $stock ne 'P'
			and $stock ne 'O'
			and $stock ne 'F'
			and $stock ne 'D' )
	  )
	{
		$stock = 'N';
	}
	if ( $stock ne 'N' ) { $inv_mod = " and inventory.available='$stock'"; }
	else {
		$inv_mod = " and (inventory.available='T' or inventory.available='P')";
	}
	$res_field = 'results';
	if ( $stock eq 'T' ) { $sel_T = 'selected'; $res_field = 'res_T' }
	if ( $stock eq 'A' ) {
		$sel_A     = 'selected';
		$inv_mod   = '';
		$res_field = 'res_A';
	}
	if ( $stock eq 'P' ) { $sel_P = 'selected'; $res_field = 'res_P' }
	if ( $stock eq 'O' ) { $sel_O = 'selected'; $res_field = 'res_O' }
	if ( $stock eq 'F' ) { $sel_F = 'selected'; $res_field = 'res_F'; }
	if ( $stock eq 'D' ) { $sel_D = 'selected'; $res_field = 'res_D'; }

	if ( !( $affiliate =~ /^\d/ ) ) {
		$affiliate = $cookie{'affiliate'};
	}
	$affiliate =~ s/\D.*//s;
	if ( !( $affiliate =~ /^\d/ ) ) { $affiliate = 0 }

	if ( !$dozen )      { $dozen      = 1 }
	if ( !$dozen_list ) { $dozen_list = 1 }
	$dozen0      = $dozen - 1;
	$dozen1      = $dozen + 1;
	$dozen_list0 = $dozen_list - 1;
	$dozen_list1 = $dozen_list + 1;
	$first_list0 = $first_list;
	$last_list0  = $last_list;

	if ( !$init1 and ( $discount eq 'Yes' ) ) { $init1 = 'all' }

	$type  = 'toys';
	$type3 = $type;

	$back = $type . 'back';

	$text3 = $foo->escape($text);

	if ($price_range) { $price_app = "&price_range=$price_range" }

	require("../inc/dbc.dat");

	#product DB retrieve
	$table  = 'date_' . $type;
	$table1 = 'aph_' . $type;

	if ($battery) {
		( $bt_qty, $battery ) = split / /, $battery;
		$ecode = &getBatt($battery);
	}

	$sql1 = $dbh->prepare(
	" SELECT REPLACE(product_name,CHAR(34),'"') as product_name,saleprice,price,manufacturer,pimage,voldiscount,synopsis,available,bigkey,initial,family1,family2,batt,options,options_set,item_set,inventory.opt_set,sku
     FROM $table,inventory
     WHERE $table.item='$ecode' and inventory.item='$ecode'
     "
	);
	$sql1->execute;
	(
		$name,      $saleprice, $price,     $manufacturer, $image,
		$onsale,    $synopsis,  $available, $key,          $init0,
		$family1,   $family2,   $batter,    $option,       $opt_set,
		$ecode_set, $opt_set1,  $sku
	) = $sql1->fetchrow_array;
	$sql1->finish;

	#get rating
	$sqlR = $dbh->prepare(
		" SELECT reviews,rating_ave
     FROM rating
     WHERE item='$ecode'
     LIMIT 1
     "
	);

	$sqlR->execute;
	( $reviews, $rating_ave ) = $sqlR->fetchrow_array;
	$sqlR->finish;

	$init = $init0;
	$rating1 = sprintf "%.0f", $rating_ave;
	$ecode_set =~ s/ //;

###CATEGORY & family SELECT

	if ( $criteria eq 'init' ) { $init = $text }
	$text_type = $type;

	open( FILEHANDLE, "< store.txt" ) or print 'Cannot open file';
	while (<FILEHANDLE>) { chop $_; $code .= $_ }
	close(FILEHANDLE);
	eval($code);
	%assa3 = @asso3;
	%assa1 = @asso1;
	%assa0 = @asso0;

	$fam_number = ( $#asso1 + 1 ) / 2;

	$initial = $assa0{$init};
	if ( !$text ) { $text = $initial }

	$family = $assa1{$fam};

	if ( $criteria eq 'init' ) {
		$text1 =
" &GT; <a href='/cgi-bin/toys.cgi?af=$affiliate&type=$type&text=$text3&criteria=init' class='text1large'>$assa3{$text}</a>";
	}
	if ($fam) {
		$fam1 =
" &GT; <a href='/cgi-bin/toys.cgi?af=$affiliate&init=$init&fam=$fam' class='text1large'>$family</a>";
	}
	if ($init1) {
		$fam1 =
" &GT; <a href='/cgi-bin/toys.cgi?af=$affiliate&init1=$init1&criteria=$criteria&text=$text3' class='text1large'>$asso0{$init1}</a>";
	}
	if ($init1) {
		$fam1 =
" &GT; <a href='/cgi-bin/toys.cgi?af=$affiliate&init1=$init1&criteria=$criteria&text=$text3' class='text1large'>$asso0{$init1}</a>";
	}

	#show stream
	$text1 =
" &GT; <a href='/cgi-bin/toys.cgi?af=$affiliate&init=$init&text=$text3&criteria=$criteria' class='text1large'>$text</a>";
	if ( $hotdeal eq 'Yes' ) {
		$text1 =
" &GT; <a href='/cgi-bin/toys.cgi?af=$affiliate&hotdeal=Yes' class='text1large'>Hot Deals!</a>";
		$addition = '&hotdeal=Yes';
	}
	if ( $discount eq 'Yes' ) {
		$text1 =
" &GT; <a href='/cgi-bin/toys.cgi?af=$affiliate&discount=Yes' class='text1large'>Volume Discounts</a>";
		$addition = '&discount=Yes';
	}
	if ( $bestseller eq 'Yes' ) {
		$text1 =
" &GT; <a href='/cgi-bin/toys.cgi?af=$affiliate&bestseller=Yes' class='text1large'>Bestsellers</a>";
		$addition = '&bestseller=Yes';
		$pth      = 'pimage';
	}
	$type1 =
"<a href='/cgi-bin/toys.cgi?af=$affiliate' class='text1large'>Sex Toys</a>";

	if ( $available eq 'T' ) {
		$available1 = '1 to 2 business days';
		$available2 = 'IN STOCK';
	}
	if ( $available eq 'F' ) {
		$available1 = '10 to 15 business days';
		$available2 = 'SPECIAL ORDER';
	}
	if ( $available eq 'P' ) {
		$available1 = 'upon release';
		$available2 = 'PRE-ORDER';
	}
	if ( $available eq 'O' ) {
		$available1 = '10 to 15 business days';
		$available2 = 'ON ORDER';
	}
	if ( $available eq 'D' ) {
		$available1 = 'not available';
		$available2 = 'NOT AVAILABLE';
	}

	$onsale1 = $onsale;
	$sale    = '';
	if ( $onsale eq 'T' ) {
		$onsale1 = 1;
		$sale =
'<img src="/assets/images/sale.gif" align=absmiddle width=35 height=16 border=0 alt="Volume Discounts" >';
	}
	if ( $onsale eq 'C' ) {
		$sale =
'<img src="/assets/images/salec.gif" align=absmiddle width=35 height=16 border=0 alt="Volume Discounts" >';
	}
	if ( $onsale eq 'F' ) { $onsale1 = 0; }

	#alphabetic list

	if ( $init ne 'all' ) {
		$where_list = "WHERE initial='$init'";
	}
	else {
		$where_list = "WHERE (bigkey>=0)";
	}

	if ( $criteria eq 'title' )        { $crt = 'product_name' }
	if ( $criteria eq 'manufacturer' ) { $crt = 'manufacturer' }
	if ( $criteria eq 'star' )         { $crt = 'stars' }
	if ( $criteria eq 'ecode' )        { $crt = 'inventory.item' }
	if ( $criteria eq 'init' )         { $crt = 'initial' }
	if ( $criteria eq 'sku' )          { $crt = 'sku' }
	if   ( $text ne 'all' ) { $textE = "%" . $text . "%"; }
	else                    { $textE = "%" . "%"; }
	$textE = $dbh->quote($textE);

	if ( $criteria or $init1 ) {
		$where_list = "WHERE $crt LIKE $textE";
		if ($init1) { $where_list = $where_list . " and initial='$init1'"; }
	}

	if ($fam) {
		$where_list = $where_list . " and (family1='$fam' or family2='$fam')";
	}

	if ( $hotdeal eq 'Yes' ) {
		$where      = "WHERE hotdeals='T'";
		$where_list = "WHERE hotdeals='T'";
		if ($fam) {
			$where_list = $where_list
			  . " and (initial='$fam' or family1='$fam' or family2='$fam')";
		}
	}

	$where_list0 = $where_list;
	if ($last_list) { $where_list = $where_list . " and bigkey>'$last_list'" }
	if ($first_list) {
		$where_list = $where_list . " and bigkey<'$first_list'";
		$order_list = 'DESC';
	}
	if ($letter) {
		$where_list  = $where_list . " and product_name LIKE '$letter%'";
		$where_list0 = $where_list0 . " and product_name LIKE '$letter%'";
	}

	#price range/match
	if ($price_range) {

		#field for price
		if (   ( $aff_flag and !( $server =~ m/shop/ ) )
			or ( $server =~ m/myadultwarehouse/ ) )
		{
			$price_field = 'price';
		}
		else { $price_field = 'saleprice' }

		if ( $price_range !~ /\-/ ) {    #exact match
			$price_match = $price_range;
			if ( $price_match =~ /^\d+$/ or $price_match =~ /^\d+\.\d+$/ ) {
				$price_mod = "$price_field=$price_match";
				$price2    = "\$$price_match";
			}
		}
		else {                           #range
			( $price_min, $price_max ) = split /-/, $price_range;
			if ( $price_min =~ /^\d+$/ or $price_min =~ /^\d+\.\d+$/ ) {
				$price_mod_min = "$price_field>$price_min";
			}
			if ( $price_max =~ /^\d+$/ or $price_max =~ /^\d+\.\d+$/ ) {
				$price_mod_max = "$price_field<$price_max";
			}
			if ( $price_mod_min and $price_mod_max ) {
				$price_mod = "$price_mod_min and $price_mod_max";
				$price2    = "\$$price_min - \$$price_max";
			}
			elsif ($price_mod_min) {
				$price_mod = $price_mod_min;
				$price2    = "more than \$$price_min";
			}
			elsif ($price_mod_max) {
				$price_mod = $price_mod_max;
				$price2    = "less than \$$price_max";
			}
		}

	}

	if ($price_mod) {
		if   ($where_list) { $where_list = "$where_list and $price_mod"; }
		else               { $where_list = "WHERE $price_mod"; }
	}

	$sql2 = $dbh->prepare(
		" SELECT $table1.item,$table1.product_name,$table1.bigkey
     FROM $table1,inventory
     $where_list and $table1.item=inventory.item $inv_mod
     ORDER by bigkey $order_list 
     LIMIT 50
     "
	);

	$sql2->execute;
	$j = 0;
	while ( @record1 = $sql2->fetchrow_array ) {
		( $list_ecode[$j], $list[$j], $bigkey_list[$j] ) = @record1;
		$j++;
	}
	$sql2->finish;

	#number of search results
	if ( $letter or ( $criteria and ( $criteria ne 'init' ) ) ) {
		$phrase = $dbh->quote($text);
		$sql0   = $dbh->prepare(
			" SELECT $res_field,inits
     FROM search
     WHERE phrase=$phrase and type='$type' and criteria='$criteria' and site='SuperStore'
     LIMIT 1
     "
		);

		$sql0->execute;
		( $jj, $inits ) = $sql0->fetchrow_array;
		$sql0->finish;

		@inits = split /,/, $inits;
		foreach $init_dd (@inits) { $init_present{$init_dd} = 'Yes' }

	}

	if ($first_list) {
		@list_ecode  = reverse @list_ecode;
		@list        = reverse @list;
		@bigkey_list = reverse @bigkey_list;
	}

	$first_list = $bigkey_list[0];
	$last_list  = $bigkey_list[ $j - 1 ];
	$l0         = $#list;

	#FILTER FOR NAMES IN LIST
	$l = $#list + 1;
	local ($lil) = 0;
	local ($il)  = 0;
	while ( $lil + $il <= 100 && $il <= $l - 1 ) {
		local ($lilo) = 0;
		local ($prev) = 0;
		for ( $i = 0 ; $i <= ( length( $list[$il] ) - 1 ) ; $i++ ) {
			if (   ( substr( $list[$il], $i, 1 ) eq ' ' )
				&& ( ( $i - $prev ) > 25 )
				&& substr( $list[$il], $i + 1, 1 ) )
			{
				$prev = $i + $prev;
				$lilo++;
				substr( $list[$il], $i, 1 ) = '*';
			}
		}
		$lil = $lil + $lilo;
		while ( $list[$il] =~ m/\*/ ) {
			$list[$il] =~
s/\*/<\/a><br>&nbsp;&nbsp;&nbsp;<a href='\/cgi-bin\/toys2.cgi?af=$affiliate&ecode=$list_ecode[$il]&fam=$fam&init=$init&letter=$letter&last_list=$last_list0&first_list=$first_list0&dozen_list=$dozen_list&text=$text3&criteria=$criteria&init1=$init1$price_app' class='text1'>/;
		}
		$il++;
	}
	for ( $i = $0 ; $i < $il ; $i++ ) { $list[ $i + $il ] = $list[ $i + $l ] }
	$lold     = $l;
	$l        = $il;
	$list_key = $list[ 2 * $l - 1 ];

	$escape_batter = $foo->escape($batter);

	$new_option = ucfirst $option;

	$item_batt = $ecode;
	if ( $batter eq 'Included' ) { $battery = qq(Included); }
	if ( $batter eq 'None' )     { $battery = qq(none); }
	if ( $batter ne 'None' and $batter ne 'Included' ) {
		( $bt_qty1, $battery1 ) = split / /, $batter;
		if ( &getBatt($battery1) ) {
			$battery =
qq(<a href="/cgi-bin/toys2.cgi?battery=$escape_batter&init=battery">$batter</a>&nbsp;&nbsp;
                  <a href="/cgi-bin/toys2.cgi?battery=$escape_batter&init=battery"><img src="/ahtml/images/batticon.jpg" align=absmiddle width=32 height=12 border=0 alt="Batteries"></a>);
		}
		else {
			$battery =
qq($batter&nbsp;&nbsp;<img src="/ahtml/images/batticon.jpg" align=absmiddle width=32 height=12 border=0 alt="Batteries">);
		}
	}

	$stk3[0] = $available;
	$sorry = "Sorry, this product is NOT AVAILABLE. Please try other products.";

	if ( $option ne 'none' ) {
		$sorry =
		  "Sorry, this option is NOT AVAILABLE. Please try other options.";
		$opt_set =~ tr/\'/\`/;

		@stk3     = split /,/, $opt_set1;
		@opt_set0 = split /,/, $opt_set;
		@ecode_set0 = split( /,/, $ecode_set );

		if ( $stk3[0] ne 'T' ) {
			$stk3_0       = $stk3[0];
			$opt_set0_0   = $opt_set0[0];
			$ecode_set0_0 = $ecode_set0[0];
		  COMMENTS: for ( $opt_i = 1 ; $opt_i <= $#stk3 ; $opt_i++ ) {
				if ( $stk3[$opt_i] eq 'T' ) {
					$stk3[0]            = $stk3[$opt_i];
					$stk3[$opt_i]       = $stk3_0;
					$opt_set0[0]        = $opt_set0[$opt_i];
					$opt_set0[$opt_i]   = $opt_set0_0;
					$ecode_set0[0]      = $ecode_set0[$opt_i];
					$ecode_set0[$opt_i] = $ecode_set0_0;
					last COMMENTS;
				}
			}

		}

		$available2 =
"<img name=stock_image src=/ahtml/images/$stk3[0].gif width=90 height=8 border=0>";
		$available1 =
"<img name=ship_image src=/ahtml/images/$stk3[0]_ship.gif width=114 height=12 border=0 align=absmiddle>";
		$ecode_set0[0] =~ s/ //g;
	}

	if ( $option eq 'color' ) {
		$imgg = $ecode_set0[0] . '.gif';
		$gamma_array =
qq(<a href="javascript:setColor('$ecode_set0[0]','$opt_set0[0]','$stk3[0]')"><img src="/images/pcolors/$imgg" width=18 height=18 border=1 alt='$opt_set0[0]'></a> );
		for ( $i = 1 ; $i <= $#ecode_set0 ; $i++ ) {
			while ( $ecode_set0[$i] =~ / / ) { $ecode_set0[$i] =~ s/ //; }
			$imgg        = $ecode_set0[$i] . '.gif';
			$gamma_array = $gamma_array
			  . qq(<a href="javascript:setColor('$ecode_set0[$i]','$opt_set0[$i]','$stk3[$i]')"><img src="/images/pcolors/$imgg" width=18 height=18 border=1 alt='$opt_set0[$i]'></a> );
		}
	}

	if (   $option eq 'flavor'
		or $option eq 'fragrance'
		or $option eq 'style'
		or $option eq 'size'
		or $option eq 'aroma' )
	{
		$fragrance_array =
		  qq(<option value='$ecode_set0[0],$stk3[0]' selected>$opt_set0[0]);
		for ( $i = 1 ; $i <= $#ecode_set0 ; $i++ ) {
			$ecode_set0[$i] =~ s/^ //;
			$opt_set0[$i]   =~ s/^ //;
			$fragrance_array = $fragrance_array
			  . qq(<option value='$ecode_set0[$i],$stk3[$i]'>$opt_set0[$i]);
		}
	}

	$split_manuf = $foo->escape($manufacturer);

	@split_star = split( /,/, $star );

	require("/export/home0/vhost218/cgi-serverwide/colors.pl");

	#page layout

	print <<EOT;
<html>
<head>
<title>Sex Toys: $name</title>
<META HTTP-EQUIV="Expires" CONTENT="0">

<script language="JavaScript">
<!--
self.status='';

function repl(value){
var url='/cgi-bin/toys.cgi?af=$affiliate&fam='+value+'&init=$init'
window.location = url;
}

function replC(value){
var url='/cgi-bin/toys.cgi?af=$affiliate&init1='+value+'&criteria=$criteria&text=$text3'
window.location = url;
}

function replP(value){
  if(value){window.location='http://$ENV{"HTTP_HOST"}/cgi-bin/$type.cgi?$query0&price_range='+value;}
  else{window.location='http://$ENV{"HTTP_HOST"}/cgi-bin/$type.cgi?$query0';}
}

var caution = false
today=new Date();
quarterlater=new Date();
quarterlater.setTime(today.getTime()+7776000000);
yearslater=new Date();
yearslater.setTime(today.getTime()+315360000000);

function setCookie(name, value, expires, path, domain, secure) {
	var curCookie = name + "=" + escape(value) +
		((expires) ? "; expires=" + expires.toGMTString() : "") +
		 "; path=/" +
		((domain) ? "; domain=" + domain : "") +
		((secure) ? "; secure" : "")
	if (!caution || (name + "=" + escape(value)).length <= 4000)
		document.cookie = curCookie
	else
		if (confirm("Cookie exceeds 4KB and will be cut!"))
			document.cookie = curCookie
}

function getCookie(name) {
	var prefix = name + "="
	var cookieStartIndex = document.cookie.indexOf(prefix)
	if (cookieStartIndex == -1)
		return null
	var cookieEndIndex = document.cookie.indexOf(";", cookieStartIndex + prefix.length)
	if (cookieEndIndex == -1)
		cookieEndIndex = document.cookie.length
	return unescape(document.cookie.substring(cookieStartIndex + prefix.length, cookieEndIndex))
}

function deleteCookie(name, path, domain) {
	if (getCookie(name)) {
		document.cookie = name + "=" + 
		"; path=/" +
		((domain) ? "; domain=" + domain : "") +
		"; expires=Thu, 01-Jan-70 00:00:01 GMT"
	}
}

function fixDate(date) {
	var base = new Date(0)
	var skew = base.getTime()
	if (skew > 0)
		date.setTime(date.getTime() - skew)
}


function Start(page) {
OpenWin1 = this.open(page,"Sale","toolbar=no,menubar=no,location=no,scrollbars=yes,resizable=yes,width=320,height=335");
}

function send_link() {
this.open('/cgi-share/send_link.cgi?af=$affiliate&ecode=$ecode&type=$type',"SendLink","toolbar=no,menubar=no,location=no,scrollbars=no,resizable=no,width=340,height=258");
}

function bookmark()
{
bookmarkurl="http://$server/cgi-bin/product.cgi?af=$affiliate&criteria=ecode&text=$ecode&type=$type"
bookmarktitle= new String("$name");
bookmarktitle = bookmarktitle.replace('&#174;', '(r)');
bookmarktitle = bookmarktitle.replace('&#8482;', '(tm)');
if (document.all)
window.external.AddFavorite(bookmarkurl,bookmarktitle)
}

browserName = navigator.appName;
browserVer = parseInt(navigator.appVersion);
if (browserVer >= 3) version = "n3";
else if (browserName == "Netscape" && browserVer <= 2) version = "n2";
else version = "ie"
function MakeHelpLogin(url) {
	if (version == "ie" || version == "n2") { alert('Netscape 3.0 and above or Internet Explorer 4.0 and above are required to use the Help Windows.'); }
	if (version == "n3") {
		HelpWindow=window.open(url,"HelpWindow","toolbar=no,width=300,height=400,scrollbars=auto,directories=no,status=no,menubar=no");
		HelpWindow.focus();
	}
}

ecode='$ecode';
coll='$opt_set0[0]';
stkk='$stk3[0]'
function setColor(ecd,col,stk){
ecode=ecd;
coll=col;
stkk=stk;
document.color.src="/images/pcolors/"+ecd+".gif";
document.stock_image.src='/ahtml/images/'+stk+'.gif';
document.ship_image.src='/ahtml/images/'+stk+'_ship.gif';
}

function setWishlist(){
if(stkk == 'D'){alert('$sorry');return;}
window.location = '/cgi-share/1wishlist.cgi?af=$affiliate&add='+ecode;
}

function setGiftReg(){
if(stkk == 'D'){alert('$sorry');return;}
window.location = '/cgi-share/1giftreg.cgi?af=$affiliate&add=Yes&ecode='+ecode;
}

function setCart(last_price){
if(stkk == 'D'){alert('$sorry');return;}
var key='$ecode'+'alpha'+ecode
var keyss = getCookie("keysCookie")		
var onsales = getCookie("onsalesCookie")

if ( keyss ) {keyss = keyss+key+'\$' }
else {keyss = key+'\$' }
if ( onsales ) {onsales = onsales+0+'\$' }
else {onsales =0+'\$' }

var total = getCookie("total");
var tot_qty = getCookie("tot_qty");
if(eval(total)>0){total = eval(total)+eval(last_price);} else{total = eval(last_price)}
if(eval(tot_qty)){tot_qty = eval(tot_qty)+1} else{tot_qty = 1}


setCookie ("keysCookie",keyss,quarterlater)
setCookie ("onsalesCookie",onsales,quarterlater)
setCookie ("total",total,quarterlater);
setCookie ("tot_qty",tot_qty,quarterlater);
document.location.reload();
}

function MM_reloadPage(init) {  //reloads the window if Nav4 resized
  if (init==true) with (navigator) {if ((appName=="Netscape")&&(parseInt(appVersion)==4)) {
    document.MM_pgW=innerWidth; document.MM_pgH=innerHeight; onresize=MM_reloadPage; }}
  else if (innerWidth!=document.MM_pgW || innerHeight!=document.MM_pgH) location.reload();
}
MM_reloadPage(true);
// -->
</script>
$style_sheet
</head>
<body bgcolor="$bgcolor" text="#000000" link="#0000FF" vlink="#0000FF" alink="$hover" topmargin=0 leftmargin=0 marginwidth=0 marginheight=0>
EOT

	require("/export/home0/vhost218/cgi-serverwide/header.pl");

	print <<EOT;
<table border="0" cellspacing="0" cellpadding="0" width=100%>
 <tr>
  <td width="5%" bgcolor="$bgcolor2" valign="top">
EOT

	require("/export/home0/vhost218/cgi-serverwide/menu_new.pl");

	print <<EOT;
  </td>
  <td valign=top>
   <table bgcolor="$bgcolor" border=0 cellspacing=0 cellpadding=0 width="100%" valign=top align=center>
    <tr>
     <td width="75%" valign=top>
      <table border=0 cellspacing=6 cellpadding=0 width="100%" valign=top align=center>
       <tr>
        <td width="100%" align=center valign=top>
         <table bgcolor="$bgcolor" cellspacing=0 cellpadding=0 border=0 width="100%" valign=top align=center>
          <tr>
           <td valign=middle width=75% class="text1large">&nbsp;&nbsp;$type1$text1$fam1</td>
           <td valign=middle align=right width=25%><a href="javascript:bookmark();" class="text1">Bookmark this item</a></td>
          </tr>
         </table>
        </td>
       </tr>
       <tr>
        <td bgcolor="$bgcolor3" width="100%" align=center valign=top>
         <table width=100% cellspacing=0 cellpadding=0 valign=top border=0 bgcolor="$bgcolor3">
          <tr>
           <td valign=top height=19 width=3%><img src="/assets/images/spacer.gif" height=19 width=35 vspace=0 hspace=0></td>
           <td align=center height=19><span class="text3large">&nbsp;$name</span></td>
           <td align=right valign=top height=19 width=3%><img src="/ahtml/images/toy.gif" height=19 width=35 vspace=0 hspace=0></td>
          </tr>
         </table>
        </td>
       </tr>  
       <tr>
        <td bgcolor="#FFFFFF" width="100%" align=center valign=top>
         <table width=100% cellspacing=2 cellpadding=2 valign=top border=0>
          <tr>
           <td width=225 valign=top align=center><img src="/images/pimage/toys/$image" vspace=0 hspace=0 align="TOP" border=0 width=225 height=300></td>
           <td valign=top>
           <form name="RatingForm" METHOD=get action=/cgi-share/1review.cgi>
           <input type=hidden name=mode value=submit>
           <input type=hidden name=ecode value='$ecode'>
           <input type=hidden name=type value='$type'> 
           <input type=hidden name=af value='$affiliate'>                      
            <table width=100% cellspacing=0 cellpadding=2 border=0>
             <tr>
              <td valign=top class="black"><span class="blackbold">Description:</span>&nbsp;$synopsis</td>
             </tr>
             <tr>
              <td height=22 class="black"><span class="blackbold">Manufacturer:</span>&nbsp;<a href='/cgi-bin/toys.cgi?af=$affiliate&text=$split_manuf&criteria=manufacturer'>$manufacturer</a></td>
             </tr>


EOT

	if ( $option eq 'color' ) {
		print <<E_O_T;
             <tr>    
              <td height=22>
               <table valign=top border=0 cellspacing=0 cellpadding=0>
                <tr>
                 <td nowrap class="blackbold">Select a Color:&nbsp;</td>
                 <td class="black">$gamma_array</td>
                </tr>
               </table>
              </td>
             </tr>
             <tr>    
              <td height=22>
               <table valign=top border=0 cellspacing=0 cellpadding=0>
                <tr>
                 <td nowrap class="blackbold">Your Color:&nbsp;</td>
                 <td><img name=color src="/images/pcolors/$ecode_set0[0].gif" width=18 height=18 border=1 alt="Selected Color"></td>
                </tr>
               </table>
              </td>
             </tr>
E_O_T
		1;
	}
	if (   $option eq 'flavor'
		|| $option eq 'fragrance'
		|| $option eq 'style'
		|| $option eq 'size'
		|| $option eq 'aroma' )
	{
		print <<E_O_T;
             <tr>    
              <td height=22>
               <table valign=top border=0 cellspacing=0 cellpadding=0>
                <tr>
                 <td nowrap class="blackbold">Select a $new_option:&nbsp;</td>
                 <td><select name=flavor onChange="sel()">$fragrance_array</select></td>
                </tr>
               </table>    
              </td>
             </tr>

E_O_T
		1;
	}

	print <<E_O_T;
             <tr>    
              <td height=22 class="black"><span class="blackbold">Status:</span>&nbsp;<a href="javascript:MakeHelpLogin('/ahtml/help/menu_status.html')" onMouseover="self.status='Open A Help Window'; return true;" onMouseout="self.status=''; return true;" class="redbold">$available2</a></td>
             </tr>                  
               
E_O_T

	#change plan A->B
	if (   ( $aff_flag and !( $server =~ m/shop/ ) )
		or ( $server =~ m/myadultwarehouse/ ) )
	{
		$saleprice = $price;
	}
	else {
		$you_save = sprintf "%.2f", ( $price - $saleprice );
		$reg_line =
qq(Regular Price:&nbsp;<span class="blackbold"><s>\$$price</s></span>&nbsp;&nbsp;&nbsp;<span class="blackbold">You Save:&nbsp;\$$you_save</span>);
	}

	#-change-

	$saleprice = sprintf "%.2f", $saleprice;
	$name =~ s/\'/\`/g;
	$name =~ s/\"/ inches/g;
	$name =~ s/&#8482;/\(TM\)/ig;
	$name =~ s/&#188;/ 1\/4/ig;
	$name =~ s/&#189;/ 1\/2/ig;
	$name =~ s/&#190;/ 3\/4/ig;
	$keystatus = $key . $status . $ecode;

	print <<E_O_T;
             <tr>
              <td height=22 nowrap class="black"><span class="blackbold">Our Price:</span>&nbsp;<span class="redlarge">\$$saleprice</span>&nbsp;&nbsp;<a href="javascript:Start('/ahtml/discounts.html')">$sale</a><br>
               $reg_line</td>
             </tr>

E_O_T

	if ( $stk3[0] ) { $available = $stk3[0]; }
	print <<EOT;
             <tr>
              <td height=30 valign=middle><a href="javascript:setCart($saleprice)"><img src="/ahtml/images/add_cart.gif" align=absmiddle width=173 height=22 border=0 alt="Add to Cart"></a></td>
             </tr>
             <tr>
              <td height=30 valign=middle><a href="javascript:setWishlist()"><img src="/ahtml/images/add_wishlist.gif" width=173 height=22 border=0 alt="Add to Wish List"></a></td>
             </tr>
             <tr>
              <td height=30 valign=middle><a href="javascript:setGiftReg()"><img src="/ahtml/images/add_giftreg.gif" width=173 height=22 border=0 alt="Add to Gift Registry"></a></td>
             </tr>
EOT

	print <<EOT;
             <tr>
              <td height=30 valign=middle><a href=/cgi-share/1order.cgi?af=$affiliate><img src="/ahtml/images/checkout.gif" width=173 height=22 border=0 alt="Checkout"></a></td>
             </tr>
             <tr> 
              <td height=22 class="black"><span class="blackbold">Batteries Required:</span>&nbsp;$battery</td>
             </tr>
             <tr>
              <td height=22 class="black"><span class="blackbold">Manufacturer SKU:</span>&nbsp;$sku</td>
             </tr>
             <tr>
              <td height=22 class="black"><span class="blackbold">e-Code:</span>&nbsp;$ecode</td>
             </tr>
             <tr>    
              <td height=22 class="black"><span class="blackbold">Ships:</span>&nbsp;$available1</td>
             </tr>
             <tr> 
              <td height=22 class="black"><span class="blackbold">Initial Genre:</span>&nbsp;<a href='/cgi-bin/toys.cgi?af=$affiliate&init=$init'>$initial</a></td>
             </tr>
             <tr> 
              <td height=22 class="black"><span class="blackbold">Category 1:</span>&nbsp;<a href='/cgi-bin/toys.cgi?af=$affiliate&init=$init&fam=$family1'>$assa1{$family1}</a></td>
             </tr>
             <tr> 
              <td height=22 class="black"><span class="blackbold">Category 2:</span>&nbsp;<a href='/cgi-bin/toys.cgi?af=$affiliate&init=$init&fam=$family2'>$assa1{$family2}</a></td>
             </tr>
EOT

	if ( $reviews > 0 ) {
		print <<E_O_T;
             <tr> 
              <td height=22 class="black"><span class="blackbold">Customer Rating:</span>&nbsp;<img src="/ahtml/images/stars-$rating1-0.gif" width="100" height="18" align="absmiddle"><br><img src="/ahtml/images/spacer.gif" height="6" width="100">based on $reviews ratings or <a href="#rating">reviews</a></td>
             </tr>
E_O_T
	}

	print <<EOT;
             <tr> 
              <td>
               <table width="240" border="0" cellspacing="0" cellpadding="2">
                <tr> 
                 <td width="95" class="blackbold">Rate this Toy:</td>
                 <td class="blackbold" width="75" valign="middle"> 
                  <select name="rating">
                   <option value="5" selected>5 Stars</option>
                   <option value="4">4 Stars</option>
                   <option value="3">3 Stars</option>
                   <option value="2">2 Stars</option>
                   <option value="1">1 Star</option>
                  </select>&nbsp;
                 </td>
                 <td class="blackbold" width="70" valign="middle">
                  <input type="submit" value="Submit">
                 </td>
                </tr>
               </table>
              </td>
             </tr>
             <tr> 
              <td height=22 class="black"><a href="/cgi-share/1review.cgi?af=$affiliate&type=$type&ecode=$ecode">Write 
               an online review</a></td>
             </tr>
             <tr> 
              <td height=22 class="black"><a href="/cgi-share/1review.cgi?af=$affiliate&mode=edit&type=$type&ecode=$ecode">Edit your review</a></td>
             </tr>
             <tr>    
              <td height=22 class="black"><a href="javascript:send_link();">Email a friend about this item</a>&nbsp;<img src="/ahtml/images/envelope.gif" width=39 height=15 align=absmiddle border=0></td>
             </tr>
            </table>
           </form>
           </td>	
          </tr>
         </table>
        </td>
       </tr>
       <tr>
        <td align=center bgcolor="$bgcolor3" class="text3large">We also recommend these similar Sex Toys:</td>
       </tr>
       <tr> 
        <td bgcolor="#FFFFFF"> 
         <table width=100% border="0" cellspacing="0" cellpadding="2">
          <tr valign=top align=center> 

EOT

	#thumbs to other products

	foreach $fm ( ( $family1, $family2 ) ) {

		if ( $fm eq $family2 ) {
			$and_filter =
			  "and (date_toys.item != '$item1' and date_toys.item != '$item2')";
		}

		$sql3 = $dbh->prepare(
			" SELECT date_toys.item,date_toys.product_name,date_toys.pthumbs
          FROM date_toys,inventory
          WHERE (family1='$fm' or family2='$fm') AND initial='$init' AND date_toys.item !='$ecode' $and_filter and date_toys.item=inventory.item and inventory.available='T'
          ORDER by RAND()
          LIMIT 2
          "
		);

		$sql3->execute;

		$it_cnt = 0;
		while ( @record = $sql3->fetchrow_array ) {
			( $item_th, $name_th, $thumb_th ) = @record;
			$it_cnt++;
			if ( $fm eq $family1 ) {
				if ( $it_cnt eq 1 ) { $item1 = $item_th }
				if ( $it_cnt eq 2 ) { $item2 = $item_th }
			}
			print
qq(<td width=25% class="blue">CATEGORY:<br><a href='/cgi-bin/toys.cgi?af=$affiliate&init=$init&fam=$fm' class="redbold">$assa1{$fm}</a><br><a href="/cgi-bin/toys2.cgi?af=$affiliate&ecode=$item_th&init=$init&fam=$fm"><img src="/images/pthumbs/toys/$thumb_th" width="105" height="140" border="1"><br>$name_th</a></td>);
		}
		$sql3->finish;
	}

	print <<E_O_T;
		                        
         </tr>
         </table>
        </td>
       </tr>
       <tr> 
        <td align=center bgcolor="$bgcolor3" class="text3large"><a name="rating">Customer Ratings and Reviews:</a></td>
       </tr>
       <tr> 
        <td bgcolor="#FFFFFF">
         <table width="100%" border="0" cellspacing="2" cellpadding="2">
          <tr> 
           <td class="blacklarge">Toy: $name</td>
          </tr>
E_O_T

	if ( $reviews > 0 ) {
		print <<E_O_T;
          <tr> 
           <td height=22 class="black"><span class="blackbold">Customer Rating:</span>&nbsp;<img src="/ahtml/images/stars-$rating1-0.gif" width="100" height="18" align="absmiddle">&nbsp;based on $reviews ratings or reviews</td>
          </tr>
E_O_T

		#get reviews
		$sqlRR = $dbh->prepare(
" SELECT title,review,rating,reviewer_nickname,reviewer_location,DATE_FORMAT(date, '%M %e, %Y')
     FROM reviews
     WHERE item='$ecode' AND title IS NOT NULL
     ORDER by date DESC
     LIMIT 10
     "
		);

		$aa = $sqlRR->execute;

		#show reviews
		if ( $aa > 0 ) {
			print <<E_O_T;
          <tr> 
           <td> 
            <hr noshade color="$bgcolor3">
           </td>
          </tr>
          <tr> 
           <td class="blackbold">Customer Ratings and Reviews:</td>
          </tr>
E_O_T

			while (
				(
					$review_title,      $review,
					$review_rating,     $reviewer_nickname,
					$reviewer_location, $review_date
				)
				= $sqlRR->fetchrow_array
			  )
			{
				if ($reviewer_location) {
					$from_rev = "from $reviewer_location";
				}
				print <<EOT;
          <tr> 
           <td> 
            <table width="100%" border="0" cellspacing="2" cellpadding="0">
             <tr> 
              <td class="black"><img src="/ahtml/images/stars-$review_rating-0.gif" width="100" height="18" align="absmiddle">&nbsp;<span class="blackbold">$review_title</span>, $review_date </td>
             </tr>
             <tr> 
              <td class="black">Reviewer:&nbsp;$reviewer_nickname $from_rev</td>
             </tr>
             <tr> 
              <td class="black">
              $review
              </td>
             </tr>
             <tr> 
              <td> 
               <hr noshade color="$bgcolor3">
              </td>
             </tr>
            </table>
           </td>
          </tr>

EOT
			}    #end of reviews loop
		}    #end of show reviews

		$sqlRR->finish;
	}    ###reviews exist
	else {
		print <<E_O_T;
          <tr> 
           <td class="black">There are no reviews for this SexToy.<br>
            <a href="/cgi-share/1review.cgi?af=$affiliate&type=$type&ecode=$ecode">Click Here</a> to be the first to review this SexToy.</td>
          </tr>
          <tr> 
           <td>
            <form name="RatingForm2" METHOD=post action=/cgi-share/1review.cgi>
            <input type=hidden name=mode value=submit>
            <input type=hidden name=ecode value='$ecode'>
            <input type=hidden name=type value='$type'>
            <input type=hidden name=af value='$affiliate'>                                 
            <table width="240" border="0" cellspacing="0" cellpadding="2">
             <tr> 
              <td width="95" class="blackbold">Rate this Toy:</td>
              <td class="blackbold" width="75" valign="middle"> 
               <select name="rating">
                <option value="5" selected>5 Stars</option>
                <option value="4">4 Stars</option>
                <option value="3">3 Stars</option>
                <option value="2">2 Stars</option>
                <option value="1">1 Star</option>
               </select>&nbsp;
              </td>
              <td class="blackbold" width="70" valign="middle">
               <input type="submit" value="Submit">
              </td>
             </tr>
            </table>
            </form>
           </td>
          </tr>
E_O_T
	}

	print <<E_O_T;
          <tr> 
           <td height=22 class="blackbold"><a href="/cgi-share/1review.cgi?af=$affiliate&type=$type&ecode=$ecode">Write 
            your own online review</a> of $name</td>
          </tr>
         </table>
        </td>
       </tr>
      </table>
     </td>
     <td align="CENTER" valign="top" width="25%">
     <form name="InventoryForm2" METHOD=get>
      <table valign="top" border=0>
E_O_T

	require("/export/home0/vhost218/cgi-serverwide/cart.pl");
	require("/export/home0/vhost218/cgi-serverwide/promo_inc.pl");

	$initial1 = $initial;
	if ( $criteria and ( $criteria ne 'init' ) ) {
		$criteria1 = ucfirst $criteria;

		#  if($criteria1 eq 'Manufacturer'){$criteria1 = 'Studio'}
		$initial1 = "$criteria1 : $text";
	}

	print <<E_O_T;
		<tr>
			<td class="text1large" height="20">&nbsp;&nbsp;&nbsp;Alphabetically Sorted List</td>
		</tr>
		<tr>
			<td class="text1large">&nbsp;&nbsp;&nbsp;$initial1</td>
		</tr>
E_O_T

	if ( !( $criteria and ( $criteria ne 'init' ) ) and ( $discount ne 'Yes' ) )
	{
		print <<E_O_T;
       <tr>
        <td valign="top">
         <select id="InventoryComboBox" name="fam" onChange="repl(this.options[this.selectedIndex].value)"><option value="category" SELECTED>-- Select a Category --</option>
E_O_T
		for ( $ji = 0 ; $ji <= $fam_number - 1 ; $ji++ ) {
			$fam_this = $asso1[ 2 * $ji ];
			local ($show) = $assa1{$fam_this};
			$show =~ s/&#8482;/(TM)/;
			print '<option value="', $fam_this, '">', $show, '</option>';
		}
		print "</select>";
	}

	if ( ( $criteria and ( $criteria ne 'init' ) ) or $discount eq 'Yes' ) {
		print <<E_O_T;
       <tr>
        <td valign="top">
         <select id="InventoryComboBox" name="fam" onChange="replC(this.options[this.selectedIndex].value)"><option value="category" SELECTED>-- Select a Category --</option>
E_O_T
		for ( $ji = 0 ; $ji <= $#asso00 ; $ji++ ) {
			$ini = $asso00[$ji];
			if ( $ini eq 'hotdeal' or $ini eq 'voldiscount' ) { next }
			if ( $init_present{$ini} eq 'Yes' or $criteria eq 'voldiscount' ) {
				print '<option value="', $ini, '">', $asso0{$ini}, '</option>';
			}
		}
		print <<E_O_T;
         </select>
        </td>
       </tr>
E_O_T
	}

	&RightDefault;
	print <<E_O_T;
        </td>
       </tr>
       <tr>
        <td align="center" valign="middle">
E_O_T

	# DOZENS CONTROL for list (NEXT -- PREVIOUS)
	if ( $dozen_list > 1 ) {
		print
"<a href='/cgi-bin/toys.cgi?af=$affiliate&first_list=$first_list&init=$init&fam=$fam&dozen_list=$dozen_list0&letter=$letter&criteria=$criteria&text=$text3&init1=$init1$price_app' class=\"text1bold\"><img src=\"/assets/images/arrowback.gif\" HEIGHT=10 WIDTH=30 align=absmiddle border=0>BACK&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;</a>";
	}
	if ( $l0 eq 49 ) {
		print
"<a href='/cgi-bin/toys.cgi?af=$affiliate&last_list=$last_list&init=$init&fam=$fam&dozen_list=$dozen_list1&letter=$letter&criteria=$criteria&text=$text3&init1=$init1$price_app' class=\"text1bold\">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;NEXT<img src=\"/assets/images/arrownext.gif\" HEIGHT=10 WIDTH=30 align=absmiddle border=0></a>";
	}

	if ( $server =~ /^store/i or $server =~ /myadultwarehouse/i ) {

		#options for higher price
		$price_range_options = qq(
      <option value="">All Prices</option>
      <option value="-15">less than \$15</option>
      <option value="15-20">\$15-\$20</option>
      <option value="20-25">\$20-\$25</option>
      <option value="25-30">\$25-\$30</option>
      <option value="30-35">\$30-\$35</option>      
      <option value="35-">more than \$35</option>);
	}
	else {    #options for lower price
		$price_range_options = qq(
      <option value="">All Prices</option>
      <option value="-10">less than \$10</option>
      <option value="10-15">\$10-\$15</option>
      <option value="15-20">\$15-\$20</option>
      <option value="20-25">\$20-\$25</option>
      <option value="25-30">\$25-\$30</option>
      <option value="30-35">\$30-\$35</option>      
      <option value="35-">more than \$35</option>);
	}

	print <<E_O_T;
        </td>
       </tr>   
       <tr>
        <td align=center>
         <br>
         <select name="price_rng" onChange="replP(this.options[this.selectedIndex].value)">
          <option value="" SELECTED>-- Price Range --</option>                        
          $price_range_options      
         </select>
        </td>
       </tr>                              
       <tr>
        <td align=center> 
         <br>                
E_O_T
	$br         = '';
	$alph_count = 1;
	@alphabet   = (
		'A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'I', 'J', 'K', 'L', 'M', 'N',
		'O', 'P', 'Q', 'R', 'S', 'T', 'U', 'V', 'W', 'X', 'Y', 'Z'
	);

	print <<E_O_T;
         <table cellspacing=0 cellpadding=2 border=1 bgcolor='$bgcolor3' bordercolor='$bgcolor3'>
          <tr>
           <td align=center class="text3large">Alphabetical
E_O_T
	$initial_category = $foo->escape($initial_category);
	print <<E_O_T;
           </td>
          </tr>
          <tr>
           <td align=center bgcolor="#FFFFFF" class="black">
E_O_T
	foreach $alphabet (@alphabet) {
		if   ( $init ne 'top20' ) { $init2 = $init; $fam2 = $fam }
		else                      { $init2 = '';    $fam2 = '' }
		print <<E_O_T;
            <a href=/cgi-bin/toys.cgi?af=$affiliate&init=$init2&fam=$fam2&letter=$alphabet$price_app>$alphabet</a>
$br
E_O_T
		$br = '';
		$alph_count++;
		if ( $alph_count == 13 or $alph_count == 26 ) { $br = '<br>'; }
	}
	print <<E_O_T;
           </td>
	      </tr>
         </table>
        </td>
	   </tr>
      </table>
     </form>
     </td>
    </tr>
   </table>
  </td>
 </tr>
</table>

E_O_T

	#FOOTER

	require("/export/home0/vhost218/cgi-serverwide/footer.pl");

	print <<E_O_T;

<script>
<!--
function sel(){
var strng=document.RatingForm.flavor.options[document.RatingForm.flavor.selectedIndex].value;
ecode=strng.substr(0,8);
stkk=strng.substr(9,1);
document.stock_image.src='/ahtml/images/'+stkk+'.gif';
document.ship_image.src='/ahtml/images/'+stkk+'_ship.gif';
coll=document.RatingForm.flavor.options[document.RatingForm.flavor.selectedIndex].text;} 

// --> 
</script>
</body>
</html> 
E_O_T

	$sql1->finish();
	$dbh->disconnect;
	exit;
}

############################################################################################################################################

#RIGHTDEFAULT
sub RightDefault {

	if ( $criteria and ( $criteria ne 'init' ) ) { $initial = $text; }
	if ( !$family ) {
		$family = 'All Categories';
		if ($price_range) { $family = $price2 }
	}
	if ($letter) { $letter1 = "<br>&nbsp;&nbsp;&nbsp;$letter" }
	if ( $letter or ( $criteria and ( $criteria ne 'init' ) ) ) {
		$family = "$jj products found$letter1";
	}
	if ($init1) { $family = $asso0{$init1} }
	print <<E_O_T;

        <tr>
         <td valign=top nowrap class="text1large">&nbsp;&nbsp;&nbsp;$family<br></td>
        </tr>
        <tr valign=top>
         <td valign=top nowrap class="text1">

E_O_T
	for ( $j = 0 ; $j <= ( $il - 1 ) ; $j++ ) {
		print
"&#8226;&nbsp;<a href='/cgi-bin/toys2.cgi?af=$affiliate&ecode=$list_ecode[$j]&letter=$letter&fam=$fam&init=$init&last_list=$last_list0&first_list=$first_list0&dozen_list=$dozen_list&text=$text3&criteria=$criteria&init1=$init1$price_app' class='text1'>$list[$j]</a><br>
";
	}
	print "<br>";
	1;
}

#############################################################################################################################################

sub PrintHeader {
	return "Content-type: text/html\n\n";
}

sub Flag {
	local ($input) = @_;
	local ($flag)  = 1;
	$flag = 0
	  if ( $input / 2 eq int( $input / 2 ) );  # $flag=0 if even, and =1 if odd;
	return $flag;
}

sub get_cookie {
	local ( $chip, $val );
	foreach ( split( /; /, $ENV{'HTTP_COOKIE'} ) ) {

   # split cookie at each ; (cookie format is name=value; name=value; etc...)
   # Convert plus to space (in case of encoding (not necessary, but recommended)
		s/\+/ /g;                              # Split into key and value.
		( $chip, $val ) = split( /=/, $_, 2 ); # splits on the first =.
		        # Convert %XX from hex numbers to alphanumeric
		$chip =~ s/%([A-Fa-f0-9]{2})/pack("c",hex($1))/ge;
		$val  =~ s/%([A-Fa-f0-9]{2})/pack("c",hex($1))/ge;

		# Associate key and value
		next if ( defined( $cookie{$chip} ) );
		$cookie{$chip} .= $val;
	}
}

sub getBatt {
	local ($battery) = @_;

	local ($sql1) = $dbh->prepare(
		" SELECT $table.item
     FROM $table,inventory
     WHERE $table.family1='$battery' and $table.initial='battery' and inventory.item=$table.item and inventory.available='T'
     "
	);

	$sql1->execute;

	local ($ecb) = $sql1->fetchrow_array;

	$sql1->finish;
	return $ecb;

}

sub ReadParse {
	local (*in) = @_ if @_;
	local ( $i, $key, $val );

	# Read in text
	if (&MethGet) {
		$in = $ENV{'QUERY_STRING'};
	}
	elsif (&MethPost) {
		read( STDIN, $in, $ENV{'CONTENT_LENGTH'} );
	}

	@in = split( /[&;]/, $in );

	foreach $i ( 0 .. $#in ) {

		# Convert plus's to spaces
		$in[$i] =~ s/\+/ /g;

		# Split into key and value.
		( $key, $val ) = split( /=/, $in[$i], 2 );    # splits on the first =.

		# Convert %XX from hex numbers to alphanumeric
		$key =~ s/%(..)/pack("c",hex($1))/ge;
		$val =~ s/%(..)/pack("c",hex($1))/ge;

		# Associate key and value
		$in{$key} .= "\0"
		  if ( defined( $in{$key} ) );    # \0 is the multiple separator
		$in{$key} .= $val;

	}

	return scalar(@in);
}

sub MethGet {
	return ( $ENV{'REQUEST_METHOD'} eq "GET" );
}

# MethPost
# Return true if this cgi call was using the POST request, false otherwise

sub MethPost {
	return ( $ENV{'REQUEST_METHOD'} eq "POST" );
}