aboutsummaryrefslogtreecommitdiff
path: root/subsonic-main/src/main/webapp/script/tip_balloon.js
diff options
context:
space:
mode:
Diffstat (limited to 'subsonic-main/src/main/webapp/script/tip_balloon.js')
-rw-r--r--subsonic-main/src/main/webapp/script/tip_balloon.js221
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();