/*

tip_balloon.js  v. 1.7



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: 8.10.2008



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		= "/js/wz_tooltip/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)

//=======  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, sCssImg, sCssStem;



	// 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]);

	sCssCrn = ' style="position:relative;width:' + tt_aV[BALLOONEDGESIZE] + 'px;padding:0px;margin:0px;overflow:hidden;line-height:0px;';

	sVaT = 'vertical-align:top;" valign="top"';

	sVaB = 'vertical-align:bottom;" valign="bottom"';

	sCssImg = 'padding:0px;margin:0px;border:0px;';

	sImgZ = '" style="' + sCssImg + '" />';

	sCssStem = 'vertical-align:bottom;'; // Remove space below stem images under XHTML strict

	

	tt_sContent = '<table border="0" cellpadding="0" cellspacing="0" style="width:auto;padding:0px;margin:0px;left:0px;top:0px;"><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;padding:0px;margin:0px;overflow:hidden;">'

				+ '<img id="bALlOOnT" style="position:relative;top:1px;z-index:1;display:none;' + sCssImg + sCssStem + '" src="' + aImg[9].src + '" width="' + tt_aV[BALLOONSTEMWIDTH] + '" height="' + tt_aV[BALLOONSTEMHEIGHT] + '" />'

				+ '<div style="position:relative;z-index:0;padding:0px;margin:0px;overflow:hidden;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

				+ '<td style="position:relative;padding:0px;margin:0px;width:' + tt_aV[BALLOONEDGESIZE] + 'px;overflow:hidden;background-image:url(' + aImg[8].src + ');">'

				// Redundant image for bugous old Geckos that 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-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;padding:0px;margin:0px;width:' + tt_aV[BALLOONEDGESIZE] + 'px;overflow:hidden;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;padding:0px;margin:0px;overflow:hidden;">'

				+ '<div style="position:relative;left:0px;top:0px;padding:0px;margin:0px;overflow:hidden;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;' + sCssImg + sCssStem + '" 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>';

	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)

{

	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] + ".gif";  //  Change to ".png" if you want to use PNG images

	}

	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);

}

Balloon_PreCacheDefImgs();

