diff options
Diffstat (limited to 'subsonic-main/src/main/webapp/script/tip_balloon.js')
-rw-r--r-- | subsonic-main/src/main/webapp/script/tip_balloon.js | 221 |
1 files changed, 221 insertions, 0 deletions
diff --git a/subsonic-main/src/main/webapp/script/tip_balloon.js b/subsonic-main/src/main/webapp/script/tip_balloon.js new file mode 100644 index 00000000..dc9d2e44 --- /dev/null +++ b/subsonic-main/src/main/webapp/script/tip_balloon.js @@ -0,0 +1,221 @@ +/* +tip_balloon.js v. 1.81 + +The latest version is available at +http://www.walterzorn.com +or http://www.devira.com +or http://www.walterzorn.de + +Initial author: Walter Zorn +Last modified: 2.2.2009 + +Extension for the tooltip library wz_tooltip.js. +Implements balloon tooltips. +*/ + +// Make sure that the core file wz_tooltip.js is included first +if(typeof config == "undefined") + alert("Error:\nThe core tooltip script file 'wz_tooltip.js' must be included first, before the plugin files!"); + +// Here we define new global configuration variable(s) (as members of the +// predefined "config." class). +// From each of these config variables, wz_tooltip.js will automatically derive +// a command which can be passed to Tip() or TagToTip() in order to customize +// tooltips individually. These command names are just the config variable +// name(s) translated to uppercase, +// e.g. from config. Balloon a command BALLOON will automatically be +// created. + +//=================== GLOBAL TOOLTIP CONFIGURATION =========================// +config. Balloon = false // true or false - set to true if you want this to be the default behaviour +config. BalloonImgPath = "script/tip_balloon/" // Path to images (border, corners, stem), in quotes. Path must be relative to your HTML file. +// Sizes of balloon images +config. BalloonEdgeSize = 6 // Integer - sidelength of quadratic corner images +config. BalloonStemWidth = 15 // Integer +config. BalloonStemHeight = 19 // Integer +config. BalloonStemOffset = -7 // Integer - horizontal offset of left stem edge from mouse (recommended: -stemwidth/2 to center the stem above the mouse) +config. BalloonImgExt = "gif";// File name extension of default balloon images, e.g. "gif" or "png" +//======= END OF TOOLTIP CONFIG, DO NOT CHANGE ANYTHING BELOW ==============// + + +// Create a new tt_Extension object (make sure that the name of that object, +// here balloon, is unique amongst the extensions available for wz_tooltips.js): +var balloon = new tt_Extension(); + +// Implement extension eventhandlers on which our extension should react + +balloon.OnLoadConfig = function() +{ + if(tt_aV[BALLOON]) + { + // Turn off native style properties which are not appropriate + balloon.padding = Math.max(tt_aV[PADDING] - tt_aV[BALLOONEDGESIZE], 0); + balloon.width = tt_aV[WIDTH]; + //if(tt_bBoxOld) + // balloon.width += (balloon.padding << 1); + tt_aV[BORDERWIDTH] = 0; + tt_aV[WIDTH] = 0; + tt_aV[PADDING] = 0; + tt_aV[BGCOLOR] = ""; + tt_aV[BGIMG] = ""; + tt_aV[SHADOW] = false; + // Append slash to img path if missing + if(tt_aV[BALLOONIMGPATH].charAt(tt_aV[BALLOONIMGPATH].length - 1) != '/') + tt_aV[BALLOONIMGPATH] += "/"; + return true; + } + return false; +}; +balloon.OnCreateContentString = function() +{ + if(!tt_aV[BALLOON]) + return false; + + var aImg, sImgZ, sCssCrn, sVaT, sVaB, sCss0; + + // Cache balloon images in advance: + // Either use the pre-cached default images... + if(tt_aV[BALLOONIMGPATH] == config.BalloonImgPath) + aImg = balloon.aDefImg; + // ...or load images from different directory + else + aImg = Balloon_CacheImgs(tt_aV[BALLOONIMGPATH], tt_aV[BALLOONIMGEXT]); + sCss0 = 'padding:0;margin:0;border:0;line-height:0;overflow:hidden;'; + sCssCrn = ' style="position:relative;width:' + tt_aV[BALLOONEDGESIZE] + 'px;' + sCss0 + 'overflow:hidden;'; + sVaT = 'vertical-align:top;" valign="top"'; + sVaB = 'vertical-align:bottom;" valign="bottom"'; + sImgZ = '" style="' + sCss0 + '" />'; + + tt_sContent = '<table border="0" cellpadding="0" cellspacing="0" style="width:auto;padding:0;margin:0;left:0;top:0;"><tr>' + // Left-top corner + + '<td' + sCssCrn + sVaB + '>' + + '<img src="' + aImg[1].src + '" width="' + tt_aV[BALLOONEDGESIZE] + '" height="' + tt_aV[BALLOONEDGESIZE] + sImgZ + + '</td>' + // Top border + + '<td valign="bottom" style="position:relative;' + sCss0 + '">' + + '<img id="bALlOOnT" style="position:relative;top:1px;z-index:1;display:none;' + sCss0 + '" src="' + aImg[9].src + '" width="' + tt_aV[BALLOONSTEMWIDTH] + '" height="' + tt_aV[BALLOONSTEMHEIGHT] + '" />' + + '<div style="position:relative;z-index:0;top:0;' + sCss0 + 'width:auto;height:' + tt_aV[BALLOONEDGESIZE] + 'px;background-image:url(' + aImg[2].src + ');">' + + '</div>' + + '</td>' + // Right-top corner + + '<td' + sCssCrn + sVaB + '>' + + '<img src="' + aImg[3].src + '" width="' + tt_aV[BALLOONEDGESIZE] + '" height="' + tt_aV[BALLOONEDGESIZE] + sImgZ + + '</td>' + + '</tr><tr>' + // Left border (background-repeat fix courtesy Dirk Schnitzler) + + '<td style="position:relative;background-repeat:repeat;' + sCss0 + 'width:' + tt_aV[BALLOONEDGESIZE] + 'px;background-image:url(' + aImg[8].src + ');">' + // Redundant image for bugous old Geckos which won't auto-expand TD height to 100% + + '<img width="' + tt_aV[BALLOONEDGESIZE] + '" height="100%" src="' + aImg[8].src + sImgZ + + '</td>' + // Content + + '<td id="bALlO0nBdY" style="position:relative;line-height:normal;background-repeat:repeat;' + + ';background-image:url(' + aImg[0].src + ')' + + ';color:' + tt_aV[FONTCOLOR] + + ';font-family:' + tt_aV[FONTFACE] + + ';font-size:' + tt_aV[FONTSIZE] + + ';font-weight:' + tt_aV[FONTWEIGHT] + + ';text-align:' + tt_aV[TEXTALIGN] + + ';padding:' + balloon.padding + 'px' + + ';width:' + ((balloon.width > 0) ? (balloon.width + 'px') : 'auto') + + ';">' + tt_sContent + '</td>' + // Right border + + '<td style="position:relative;background-repeat:repeat;' + sCss0 + 'width:' + tt_aV[BALLOONEDGESIZE] + 'px;background-image:url(' + aImg[4].src + ');">' + // Image redundancy for bugous old Geckos that won't auto-expand TD height to 100% + + '<img width="' + tt_aV[BALLOONEDGESIZE] + '" height="100%" src="' + aImg[4].src + sImgZ + + '</td>' + + '</tr><tr>' + // Left-bottom corner + + '<td' + sCssCrn + sVaT + '>' + + '<img src="' + aImg[7].src + '" width="' + tt_aV[BALLOONEDGESIZE] + '" height="' + tt_aV[BALLOONEDGESIZE] + sImgZ + + '</td>' + // Bottom border + + '<td valign="top" style="position:relative;' + sCss0 + '">' + + '<div style="position:relative;left:0;top:0;' + sCss0 + 'width:auto;height:' + tt_aV[BALLOONEDGESIZE] + 'px;background-image:url(' + aImg[6].src + ');"></div>' + + '<img id="bALlOOnB" style="position:relative;top:-1px;left:2px;z-index:1;display:none;' + sCss0 + '" src="' + aImg[10].src + '" width="' + tt_aV[BALLOONSTEMWIDTH] + '" height="' + tt_aV[BALLOONSTEMHEIGHT] + '" />' + + '</td>' + // Right-bottom corner + + '<td' + sCssCrn + sVaT + '>' + + '<img src="' + aImg[5].src + '" width="' + tt_aV[BALLOONEDGESIZE] + '" height="' + tt_aV[BALLOONEDGESIZE] + sImgZ + + '</td>' + + '</tr></table>';//alert(tt_sContent); + return true; +}; +balloon.OnSubDivsCreated = function() +{ + if(tt_aV[BALLOON]) + { + var bdy = tt_GetElt("bALlO0nBdY"); + + // Insert a TagToTip() HTML element into the central body TD + if (tt_t2t && !tt_aV[COPYCONTENT] && bdy) + tt_MovDomNode(tt_t2t, tt_GetDad(tt_t2t), bdy); + balloon.iStem = tt_aV[ABOVE] * 1; + balloon.aStem = [tt_GetElt("bALlOOnT"), tt_GetElt("bALlOOnB")]; + balloon.aStem[balloon.iStem].style.display = "inline"; + if (balloon.width < -1) + Balloon_MaxW(bdy); + return true; + } + return false; +}; +// Display the stem appropriately +balloon.OnMoveAfter = function() +{ + if(tt_aV[BALLOON]) + { + var iStem = (tt_aV[ABOVE] != tt_bJmpVert) * 1; + + // Tooltip position vertically flipped? + if(iStem != balloon.iStem) + { + // Display opposite stem + balloon.aStem[balloon.iStem].style.display = "none"; + balloon.aStem[iStem].style.display = "inline"; + balloon.iStem = iStem; + } + + balloon.aStem[iStem].style.left = Balloon_CalcStemX() + "px"; + return true; + } + return false; +}; +function Balloon_CalcStemX() +{ + var x = tt_musX - tt_x + tt_aV[BALLOONSTEMOFFSET] - tt_aV[BALLOONEDGESIZE]; + return Math.max(Math.min(x, tt_w - tt_aV[BALLOONSTEMWIDTH] - (tt_aV[BALLOONEDGESIZE] << 1) - 2), 2); +} +function Balloon_CacheImgs(sPath, sExt) +{ + var asImg = ["background", "lt", "t", "rt", "r", "rb", "b", "lb", "l", "stemt", "stemb"], + n = asImg.length, + aImg = new Array(n), + img; + + while(n) + {--n; + img = aImg[n] = new Image(); + img.src = sPath + asImg[n] + "." + sExt; + } + return aImg; +} +function Balloon_MaxW(bdy) +{ + if (bdy) + { + var iAdd = tt_bBoxOld ? (balloon.padding << 1) : 0, w = tt_GetDivW(bdy); + if (w > -balloon.width + iAdd) + bdy.style.width = (-balloon.width + iAdd) + "px"; + } +} +// This mechanism pre-caches the default images specified by +// congif.BalloonImgPath, so, whenever a balloon tip using these default images +// is created, no further server connection is necessary. +function Balloon_PreCacheDefImgs() +{ + // Append slash to img path if missing + if(config.BalloonImgPath.charAt(config.BalloonImgPath.length - 1) != '/') + config.BalloonImgPath += "/"; + // Preload default images into array + balloon.aDefImg = Balloon_CacheImgs(config.BalloonImgPath, config.BalloonImgExt); +} +Balloon_PreCacheDefImgs(); |