Since we're already using jquery-ui for other stuff, it makes sense to use it for tooltips too, instead of using an old-school-written-in-2009 1300 lines steaming pile of javascript named wz_tooltip.jsmaster
parent
6b3a7a9261
commit
195a0879c3
@ -1,221 +0,0 @@ |
|||||||
/* |
|
||||||
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(); |
|
File diff suppressed because it is too large
Load Diff
Loading…
Reference in new issue