// the image path to use, with an {ITEMID} placeholder embedded in it
var WOWstrCoverPath = "http://www.syndetics.com/hw7.pl?isbn={ITEMID}/mc.gif&client=BEL&type=hw7";
// the widget's width (in pixels)
var WOWiWidgetWidth=500;
// the widget's height
var WOWiWidgetHeight=100;
// the slide speed (larger is faster 1-10)
var WOWslidespeed=2;
// cycles to pause per title
var WOWiPause=100;
// max width of visible titles in characters - however, a more precise method is used to ensure title fits onscreen
var WOWiTitleMaxShowingLength = 70;
// configure S curve - this is really percentages
var WOWarraySpeedRamp = new Array(-0.50,-0.37,-0.26,-0.17,-0.10,-0.05,-0.02,-0.01,0,0.01,0.02,0.05,0.10,0.17,0.26,0.37);
// bar-separated list of ASIN-or-ISBN/WowbraryURL/Title (no final bar)
var WOWstrRawData = "9781439128299|http://www.wowbrary.org/l.aspx?l=3077&c=ocn464593331&i=9781439128299&t=The+Glass+Rainbow&widget|The Glass Rainbow|9780345515483|http://www.wowbrary.org/l.aspx?l=3077&c=ocn466340039&i=9780345515483&t=Ice+Cold%3a+A+Rizzoli+%26amp%3b+Isles+Novel&widget|Ice Cold: A Rizzoli & Isles Novel|9780061966200|http://www.wowbrary.org/l.aspx?l=3077&c=ocn593543405&i=9780061966200&t=Game+Change%3a+Obama+and+the+Clintons%2c+McCain+and+Palin%2c+and+the+Race+of+a+Lifetime+(Electronic+Format)&widget|Game Change: Obama and the Clintons, McCain and Palin, and the Race of a Lifetime (Electronic Format)|9781415751954|http://www.wowbrary.org/l.aspx?l=3077&c=ocn639350098&i=9781415751954&t=The+Backyardigans%3a+Operation+Elephant+Drop&widget|The Backyardigans: Operation Elephant Drop|9780545060493|http://www.wowbrary.org/l.aspx?l=3077&c=ocn614443575&i=9780545060493&t=The+39+Clues%2c+Book+9%3a+Storm+Warning&widget|The 39 Clues, Book 9: Storm Warning|9786313614806|http://www.wowbrary.org/l.aspx?l=3077&c=ocn611275536&i=9786313614806&t=SpongeBob+SquarePants%3a+Triton%27s+Revenge&widget|SpongeBob SquarePants: Triton\'s Revenge|9781935251736|http://www.wowbrary.org/l.aspx?l=3077&c=ocn435419271&i=9781935251736&t=The+Zen+of+Social+Media+Marketing%3a+An+Easier+Way+to+Build+Credibility%2c+Generate+Buzz%2c+and+Increase+Revenue&widget|The Zen of Social Media Marketing: An Easier Way to Build Credibility, Generate Buzz, and Increase Revenue|9780061735066|http://www.wowbrary.org/l.aspx?l=3077&c=ocn456181125&i=9780061735066&t=Insatiable&widget|Insatiable|9780765320162|http://www.wowbrary.org/l.aspx?l=3077&c=ocn468981806&i=9780765320162&t=People+of+the+Longhouse+(North+America%27s+Forgotten+Past)&widget|People of the Longhouse (North America\'s Forgotten Past)|9781600852619|http://www.wowbrary.org/l.aspx?l=3077&c=ocn313078448&i=9781600852619&t=Wiring+a+House+4th+Edition%3a+Completely+Revised+and+Updated+(For+Pros+By+Pros)&widget|Wiring a House 4th Edition: Completely Revised and Updated (For Pros By Pros)|9780061780271|http://www.wowbrary.org/l.aspx?l=3077&c=ocn419851017&i=9780061780271&t=The+10+Things+You+Need+to+Eat%3a+And+More+Than+100+Easy+and+Delicious+Ways+to+Prepare+Them&widget|The 10 Things You Need to Eat: And More Than 100 Easy and Delicious Ways to Prepare Them|9780765322968|http://www.wowbrary.org/l.aspx?l=3077&c=ocn471819983&i=9780765322968&t=The+Bird+of+the+River&widget|The Bird of the River|9780312612375|http://www.wowbrary.org/l.aspx?l=3077&c=ocn471817772&i=9780312612375&t=Delhi%3a+Adventures+in+a+Megacity&widget|Delhi: Adventures in a Megacity|9781604690002|http://www.wowbrary.org/l.aspx?l=3077&c=ocn436623440&i=9781604690002&t=How+to+Grow+a+School+Garden%3a+A+Complete+Guide+for+Parents+and+Teachers&widget|How to Grow a School Garden: A Complete Guide for Parents and Teachers|9781593786441|http://www.wowbrary.org/l.aspx?l=3077&c=ocn428823314&i=9781593786441&t=Citizen+Canine&widget|Citizen Canine|9780307473851|http://www.wowbrary.org/l.aspx?l=3077&c=ocn290464690&i=9780307473851&t=The+Maeve+Binchy+Writers%27+Club&widget|The Maeve Binchy Writers\' Club|9781603560054|http://www.wowbrary.org/l.aspx?l=3077&c=ocn457161076&i=9781603560054&t=IBD+Self-Management%3a+The+AGA+Guide+to+Crohn%27s+Disease+and+Ulcerative+Colitis&widget|IBD Self-Management: The AGA Guide to Crohn\'s Disease and Ulcerative Colitis|9781594732812|http://www.wowbrary.org/l.aspx?l=3077&c=ocn457160285&i=9781594732812&t=Creative+Aging%3a+Rethinking+Retirement+and+Non-Retirement+in+a+Changing+World&widget|Creative Aging: Rethinking Retirement and Non-Retirement in a Changing World|9781413311884|http://www.wowbrary.org/l.aspx?l=3077&c=ocn457010512&i=9781413311884&t=The+Women%27s+Small+Business+Start-Up+Kit%3a+A+Step-by-Step+Legal+Guide&widget|The Women\'s Small Business Start-Up Kit: A Step-by-Step Legal Guide|9780061735813|http://www.wowbrary.org/l.aspx?l=3077&c=ocn464240845&i=9780061735813&t=Good+Omens+CD&widget|Good Omens CD";
// gap between each image (use HTML):
var WOWimagegap=" "
var WOWslidebgcolor="white";
var WOWiMoveDirection = 1; // -1, 0, 1
var WOWarraySlideWidths = new Array();
var WOWstrSlideContents = "";
var WOWarrayRawData = WOWstrRawData.split("|");
for (WOWi = 0; WOWi < WOWarrayRawData.length; WOWi += 3)
WOWstrSlideContents += "
";
WOWstrSlideContents += '';
var WOWiedom=document.all||document.getElementById;
if (WOWiedom) document.write(''+WOWstrSlideContents+'')
var WOWiSlides = 0;
var WOWarraySlideCenters = new Array();
var WOWarraySlideTitles = new Array();
var WOWactualwidth;
var WOWcross_slide, WOWcross_slide2, WOWns_slide, WOWns_slide2;
// this isn't called until all images have loaded
function WOWfillup(){
// figure out which images loaded and use just those to create the title array, eliminate gaps in the width array,
// recreate WOWstrSlideContents for display, sum the image widths, and count valid slides
var iTotalWidths = 0;
WOWstrSlideContents = "";
WOWiSlides = 0;
var i;
for (i = 0; i < WOWarrayRawData.length; i += 3)
if (document.getElementById("WOWimage" + i).width > 1) {
WOWarraySlideTitles[WOWiSlides] = WOWarrayRawData[i+2],
WOWarraySlideWidths[WOWiSlides] = document.getElementById("WOWimage" + i).width;
iTotalWidths += WOWarraySlideWidths[WOWiSlides];
WOWstrSlideContents += "![Click to see more about " + WOWarrayRawData[i+2] + "](" +
WOWstrCoverPath.replace("{ITEMID}", WOWarrayRawData[i]) +
")
"; // +WOWimagegap;
WOWiSlides++;
}
WOWstrSlideContents += '';
// for unclear reasons, sometimes the slides haven't really loaded in yet, so if none have arrived, exit and try again later
if (WOWiSlides == 0) {
setTimeout("WOWfillup()",100);
return;
}
if (WOWiedom){
WOWcross_slide = document.getElementById? document.getElementById("WOWtest2") : document.all.WOWtest2;
WOWcross_slide2 = document.getElementById? document.getElementById("WOWtest3") : document.all.WOWtest3;
WOWcross_slide.innerHTML = WOWcross_slide2.innerHTML = WOWstrSlideContents;
// bug: Firefox reports wrong .offsetWidth initially (it takes it a bit to calculate it) - so we use a different method
// WOWactualwidth = document.all ? WOWcross_slide.offsetWidth : document.getElementById("WOWtest2").offsetWidth;
WOWactualwidth = iTotalWidths + 10*WOWiSlides;
WOWcross_slide2.style.left = WOWactualwidth + "px";
}
else if (document.layers){
WOWns_slide=document.ns_slidemenu.document.ns_slidemenu2;
WOWns_slide2=document.ns_slidemenu.document.ns_slidemenu3;
WOWns_slide.document.write(WOWstrSlideContents);
WOWns_slide.document.close();
WOWactualwidth=WOWns_slide.document.width;
WOWns_slide2.left=WOWactualwidth;
WOWns_slide2.document.write(WOWstrSlideContents);
WOWns_slide2.document.close();
}
// alert("WOWactualwidth: " + WOWactualwidth + "; slides: " + WOWiSlides + "; sum of widths: " + iTotalWidths + "; widths: " + strWidths);
// alert("try2: WOWactualwidth: " + WOWcross_slide.offsetWidth);
// compute the distance between each image (this is slightly off)
// var fDistanceBetweenImages = (WOWactualwidth - iTotalWidths)/WOWiSlides;
// compute the mid position of each slide
var fSpot = 0;
var strWidths = "";
var i;
for (i = 0; i < WOWiSlides; i++) {
WOWarraySlideCenters[i] = Math.round(fSpot + WOWarraySlideWidths[i]/2);
fSpot += WOWarraySlideWidths[i] + 10;
strWidths += WOWarraySlideWidths[i] + ":" + WOWarraySlideCenters[i] + " ";
}
// alert(strWidths + ' | ' + WOWiSlides + ' ' + iTotalWidths + ' | ' + WOWarrayRawData.length + ' ' + WOWstrSlideContents);
// use timer to start slides moving
lefttime=setInterval("WOWmoveSlides()",30);
}
function WOWAddOnload()
{
if(window.addEventListener) window.addEventListener('load', WOWfillup, false);
else if(window.attachEvent) window.attachEvent('onload', WOWfillup);
else window.onload = WOWfillup;
}
// put self into calling chain
WOWAddOnload()
// converts a number up to 255 to a two-digit hex representation
function WOWtoHex(iValue) {
var strHex = "0123456789ABCDEF";
return String(strHex.charAt(Math.floor(iValue / 16))) + String(strHex.charAt(iValue % 16));
}
// low level: simply sets slide 1 or 2 so that its iPosition'th part is at the left of the slider area
function WOWsetSlide(iSlide, iPosition) {
// determine the slide
var slide = WOWiedom ? (iSlide == 1 ? WOWcross_slide : WOWcross_slide2) : (iSlide == 1 ? WOWns_slide : WOWns_slide2);
// put the new position in
if (WOWiedom) slide.style.left = -iPosition + "px"; else slide.left = -iPosition;
}
// sets the two slides to the indicated position
function WOWsetPosition(iPosition) {
// the first slide goes at the position
WOWsetSlide(1, iPosition);
// the second slide goes after it if necessary, or else before
WOWsetSlide(2, iPosition + (WOWactualwidth - iPosition >= WOWiWidgetWidth ? WOWactualwidth : -WOWactualwidth));
}
// returns the x position associated with the given step, using ramping
function WOWStepToX(WOWiStep)
{
// determine which slides we are between
var bBeforeSlide = (WOWiStep % WOWarraySpeedRamp.length) < (WOWarraySpeedRamp.length / 2);
var iSlide1 = Math.floor(WOWiStep / WOWarraySpeedRamp.length);
var iSlide2 = (bBeforeSlide ? iSlide1 - 1 + WOWiSlides : iSlide1 + 1) % WOWiSlides;
// compute the distance between the slides, taking into account that iSlide1 may be before or after iSlide2 AND they may be on opposing ends of the slider
var iDistance = Math.min(Math.abs(WOWarraySlideCenters[iSlide1] - WOWarraySlideCenters[iSlide2]),
Math.min((WOWarraySlideCenters[iSlide1] - WOWarraySlideCenters[iSlide2] + WOWactualwidth) % WOWactualwidth,
(WOWarraySlideCenters[iSlide2] - WOWarraySlideCenters[iSlide1] + WOWactualwidth) % WOWactualwidth));
// return the x position
return Math.round(WOWarraySlideCenters[iSlide1] + iDistance*WOWarraySpeedRamp[WOWiStep % WOWarraySpeedRamp.length]);
}
// returns the slide nearest to the given step - this can be off if a wide slide is near a thin one
function WOWStepToSlide(WOWiStep)
{
// step 0 .. WOWarraySpeedRamp.length - 1 is slide 0, etc.
return Math.floor(WOWiStep / WOWarraySpeedRamp.length);
}
// returns the distance as a percentage to the nearest slide (0 means on top of it and 1 means between slides) - this can be off if a wide slide is near a thin one
function WOWDistanceToSlide(WOWiStep)
{
return Math.abs(WOWarraySpeedRamp[WOWiStep % WOWarraySpeedRamp.length]*2.0);
}
var WOWiSlideShowing = -1; // this causes the first slide to roll in immediately
var WOWbSuspended = false;
var WOWiPausing = 0;
var WOWiPauseSuppression = 0; // number of next steps to not pause during
var WOWiStep = 0;
function WOWmoveSlides() {
// do nothing if suspended
if (WOWbSuspended) return;
// reduce pause suppression if it's on
if (WOWiPauseSuppression > 0) WOWiPauseSuppression--;
// countdown timer for when paused on an image
if (WOWiPausing > 0) {
WOWiPausing--;
return;
}
// do nothing if not supposed to move
if (!WOWiMoveDirection) return;
// advance the step
var iTotalSteps = WOWiSlides*WOWarraySpeedRamp.length;
WOWiStep = (WOWiStep + WOWiMoveDirection + iTotalSteps) % iTotalSteps;
// if this puts us at a slide, pause unless pause suppression is in place
if (WOWDistanceToSlide(WOWiStep) == 0 && WOWiPauseSuppression == 0) WOWiPausing = WOWiPause;
// set the new position
WOWsetPosition((WOWStepToX(WOWiStep) - WOWiWidgetWidth/2) % WOWactualwidth);
// see if the slide has changed
if (WOWStepToSlide(WOWiStep) != WOWiSlideShowing) {
// set the new slide
WOWiSlideShowing = WOWStepToSlide(WOWiStep);
// shorten titles initially
var strTitle = WOWarraySlideTitles[WOWiSlideShowing];
while (strTitle.length > WOWiTitleMaxShowingLength) strTitle = strTitle.replace(/ [^ ]*( ...)?$/," ...");
// put the possibly shortened title in place
document.getElementById("WOWTitle").innerHTML = strTitle;
// if the title is too long, truncate it (20 is used for the height because the type is set at 16 pt below
while (document.getElementById("WOWTitle").offsetWidth > WOWiWidgetWidth || document.getElementById("WOWTitle").offsetHeight > 20)
document.getElementById("WOWTitle").innerHTML = document.getElementById("WOWTitle").innerHTML.replace(/ [^ ]*( ...)?$/," ...");
}
// adjust the title color
var iIntensity = Math.round(WOWDistanceToSlide(WOWiStep)*255);
document.getElementById("WOWTitle").style.color = "#" + WOWtoHex(iIntensity) + WOWtoHex(iIntensity)+ WOWtoHex(iIntensity);
}
function WOWsetSpeed(iSpeedNew)
{
WOWiMoveDirection = iSpeedNew;
WOWiPausing = 0;
if (iSpeedNew) WOWiPauseSuppression = Math.round(WOWarraySpeedRamp.length/3);
}
// write out material for the area
if (WOWiedom||document.layers){
with (document){
write('
| Newest Arrivals |
| |
')
if (WOWiedom){
write('')
write(' '); //
write(' ')
write(' ')
write(' ')
}
else if (document.layers){
write('')
write(''); // onMouseover="copyspeed=0" onMouseout="copyspeed=WOWslidespeed"
write(''); // onMouseover="copyspeed=0" onMouseout="copyspeed=WOWslidespeed"
write('')
}
write(' |
| ');
write('    |
')
write('
')
}
}