// 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('') 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 += ""; // +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(''); write('') 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('
 
     
') } }