function $g(elem)
{
	return document.getElementById(elem);
}
var Utility  = function () {
    /// <summary>
    /// A collection of helper functions.
    /// </summary>
    this.getOpenerElem = function(Jb)
    {
        /// <summary>
        /// Gets a DOM object from the parent or opening document
        /// </summary>
        /// <param name="elem">The ID of the element you want to get
        /// a DOM object for</param>
        /// <returns>A DOM object if a match was found for the specified id.</returns>
	    return window.opener.document.getElementById(Jb);
    }
    this.ToggleDisplay = function (elemId) {
        /// <summary>
        /// Toggles the display of the of the specified DOM object.
        /// </summary>
        /// <param name="elemId">The ID of the DOM object to toggle.</param>
        var elem = $g(elemId);
 	    elem.style.display = (elem.style.display != 'none') ? 'none' : '';
 	}
 	
 	this.SetDivVisiblility = function (elemId, visibility)
 	{
 	    if (elemId == null) return;
 	    if (visibility == null) visibility = false;
 	    var elem;
	    if (typeof(elemId) =='string')
		    elem = $g(elemId);
	    else
		    elem = elemId;
		
		if (visibility)
		    elem.style.visibility = 'visible';
		else    
		    elem.style.visibility = 'collapse';
 	}
 	this.DisplayDiv = function (elemId, v) {
 	    /// <summary>
        /// Sets the diplay style of the specified DOM element
        /// </summary>
        /// <param name="elemId">The ID of the DOM object or a DOM object.</param>
        /// <param name="v">A valid CSS display style, like 'block', 'inline' or 'none'.</param>
 	    if (elemId == null) return;
 	    var elem;
	    if (typeof(elemId) =='string')
		    elem = $g(elemId);
	    else
		    elem = elemId;
	    elem.style.display=v;
	}
 	this.HideDiv = function (elemId) {
        /// <summary>
        /// Hides the specified div.
        /// </summary>
        /// <param name="elemId">The ID of the DOM object or a DOM object.</param>
 	    this.DisplayDiv(elemId, 'none');
 	}
 	this.ShowDiv = function (elemId) {
 	 	/// <summary>
        /// Shows the specified div.
        /// </summary>
        /// <param name="elemId">The ID of the DOM object or a DOM object.</param>
 	    this.DisplayDiv(elemId, 'inline');
 	}
    this.MyAttachEvent = function (obj,evt,fnc){
        /// <summary>
        /// The following are for browsers like NS4 or IE5Mac which don't support either
        /// attachEvent or addEventListener
        /// </summary>
	    if (!obj.myEvents) obj.myEvents={};
	    if (!obj.myEvents[evt]) obj.myEvents[evt]=[];
	    var evts = obj.myEvents[evt];
	    evts[evts.length]=fnc;
    }
    this.MyFireEvent = function (obj,evt){
        /// <summary>
        /// Triggers an event.
        /// </summary>
	    if (!obj || !obj.myEvents || !obj.myEvents[evt]) return;
	    var evts = obj.myEvents[evt];
	    for (var i=0,len=evts.length;i<len;i++) evts[i]();
    }
    this.AttachEvent = function (obj,evt,fnc,useCapture){
        /// <summary>
        /// Attaches the event based on the browser.
        /// </summary>
	    if (!useCapture) useCapture=false;
	    if (obj.addEventListener){
		    obj.addEventListener(evt,fnc,useCapture);
		    return true;
	    } 
	    else if (obj.attachEvent) 
	        return obj.attachEvent("on"+evt,fnc);
	    else{
		    MyAttachEvent(obj,evt,fnc);
		    obj['on'+evt]=function(){ MyFireEvent(obj,evt) };
		}
	}
}

// Instantiate the Utility class
var Util = new Utility();