includes/clientside/static/fadefilter.js
author Dan Fuhry <dan@enanocms.org>
Thu, 28 Oct 2010 03:05:31 -0400
changeset 1308 f9bee9b125ee
parent 1227 bdac73ed481e
permissions -rw-r--r--
Parser updates. Added the "styled" keyword to wikitables to allow them to be styled using the current theme's standard table skinning, and changes to how the image tag parser decides how to display an image (framed, inline or raw).

/**
 * Darkens the browser screen. This will make the entire page un-clickable except for any floating divs created after this is called. Restore with enlighten().
 * @param bool Controls whether the fade should be disabled or not. aclDisableTransitionFX will override this if set to true, and fades are never fired on IE.
 * @param int When specified, represents the numeric opacity value to set the fade layer to. 1-100.
 */

var darkener_index = [];
var FADE_TIME = 500; // in ms

function darken(nofade, opacVal, layerid)
{
	layerid = ( layerid ) ? layerid : 'specialLayer_darkener';
	if(IE)
		nofade = true;
	if ( !opacVal )
		opacVal = 70;
	darkener_index[layerid] = ( typeof(darkener_index[layerid]) == 'number' ) ? darkener_index[layerid] + 1 : 1;
	if(document.getElementById(layerid) && !document.getElementById(layerid).destroying)
	{
		document.getElementById(layerid).style.zIndex = getHighestZ() + 1;
		if(nofade)
		{
			changeOpac(opacVal, layerid);
			document.getElementById(layerid).style.display = 'block';
			document.getElementById(layerid).myOpacVal = opacVal;
		}
		else
		{
			if ( document.getElementById(layerid).style.display != 'none' )
			{
				var currentOpac = document.getElementById(layerid).myOpacVal;
				opacity(layerid, currentOpac, opacVal, FADE_TIME);
				document.getElementById(layerid).myOpacVal = opacVal;
			}
			else
			{
				document.getElementById(layerid).style.display = 'block';
				document.getElementById(layerid).myOpacVal = opacVal;
				opacity(layerid, 0, opacVal, FADE_TIME);
			}
		}
	}
	else if(document.getElementById(layerid) && document.getElementById(layerid).destroying)
	{
		// fade in progress - abort
		console.warn('Aborting fade');
		abortFades();
		changeOpac(opacVal, layerid);
		document.getElementById(layerid).destroying = false;
		return document.getElementById(layerid);
	}
	else
	{
		w = getWidth();
		h = getHeight();
		var thediv = document.createElement('div');
		if(IE)
			thediv.style.position = 'absolute';
		else
			thediv.style.position = 'fixed';
		if ( IE )
		{
			var top = getScrollOffset();
			thediv.style.top = String(top) + 'px';
		}
		else
		{
			thediv.style.top = '0px';
		}
		thediv.style.left = '0px';
		thediv.style.opacity = '0';
		thediv.style.filter = 'alpha(opacity=0)';
		thediv.style.backgroundColor = '#000000';
		thediv.style.width =  '100%';
		thediv.style.height = IE ? h + 'px' : '100%';
		thediv.style.zIndex = getHighestZ() + 1;
		thediv.id = layerid;
		thediv.myOpacVal = opacVal;
		if(nofade)
		{
			thediv.style.opacity = ( parseFloat(opacVal) / 100 );
			thediv.style.filter = 'alpha(opacity=' + opacVal + ')';
			body = document.getElementsByTagName('body');
			body = body[0];
			body.appendChild(thediv);
		} else {
			body = document.getElementsByTagName('body');
			body = body[0];
			body.appendChild(thediv);
			opacity(layerid, 0, opacVal, FADE_TIME);
		}
	}
	return document.getElementById(layerid);
}

/**
 * Un-darkens the screen and re-enables clicking of on-screen controls.
 * @param bool If true, disables the fade effect. Fades are always disabled if aclDisableTransitionFX is true and on IE.
 */

function enlighten(nofade, layerid)
{
	layerid = ( layerid ) ? layerid : 'specialLayer_darkener';
	
	if(IE)
		nofade = true;
	darkener_index[layerid] -= 1;
	if ( darkener_index[layerid] > 0 )
		return false;
	if(document.getElementById(layerid))
	{
		if(nofade)
		{
			document.getElementById(layerid).style.display = 'none';
		}
		else
		{
			document.getElementById(layerid).destroying = true;
			var from = document.getElementById(layerid).myOpacVal;
			opacity(layerid, from, 0, FADE_TIME);
			setTimeout("var l = document.getElementById('" + layerid + "'); var b = document.getElementsByTagName('body')[0]; b.removeChild(l);", 1000);
		}
	}
	return document.getElementById(layerid);
}