ObjectTools = new function(){	 
	this.classes = { 
		AlphaRollover : { 
			mixins: ["MouseEventElement", "OpacityElement"], 
			singleton: false, 
			domElement: true, 
			constructor: function(){ 
			 	 
				this.onmouseout = function(e){ 
				 
				 
				 
					try{ 
						if(this.checkMouseOut(e)){ 
						EaseManager.createEase({ 
							subject:this, 
							getter:"getOpacity", 
							setter:"setOpacity", 
							end: 1, 
							seconds: 0.5, 
							allowFractions: true 
						}); 
						} 
					}catch(e){ 
						this.handleError("onmouseout",e,arguments); 
					}; 
				};	 
				this.onmouseover = function(e){ 
				 
				 
				 
					try{ 
						if(this.checkMouseOver(e)){ 
						EaseManager.createEase({ 
							subject:this, 
							getter:"getOpacity", 
							setter:"setOpacity", 
							beginning: 0.6, 
							end:0.8, 
							seconds: 1, 
							allowFractions: true 
						}); 
						} 
					}catch(e){ 
						this.handleError("onmouseover",e,arguments); 
					}; 
				}; 
			} 
		},  
		AnimationBroadcaster : { 
			mixins: [], 
			singleton: true, 
			domElement: false, 
			constructor: function(){ 
				 
				this.animationInterval = false; 
					 
				this.FRAME_RATE = 20; 
					 
				this.listeners = []; 
				 	 
				this.activateBroadcaster = function(){ 
				 
				 
				 
					try{ 
						TimeoutManager.setTimeout(this,"broadcast",Math.floor(1000/this.FRAME_RATE),true); 
					}catch(e){ 
						this.handleError("activateBroadcaster",e,arguments); 
					}; 
				};	 
				this.addListener = function(obj, functionName){ 
				 
				 
				 
					try{ 
						this.removeListener(obj,functionName); 
						this.listeners.push({obj:obj,functionName:functionName}); 
						if(!this.animationInterval) this.activateBroadcaster(); 
					}catch(e){ 
						this.handleError("addListener",e,arguments); 
					}; 
				};	 
				this.broadcast = function(){ 
				 
				 
				 
					try{ 
						for(var i=0; i<this.listeners.length; i++){ 
							this.listeners[i].obj[this.listeners[i].functionName]();	 
						} 
						 
					}catch(e){ 
						this.handleError("broadcast",e,arguments); 
					}; 
				};	 
				this.deactivateBroadcaster = function(){ 
				 
				 
				 
					try{ 
						TimeoutManager.clearTimeout(this,"broadcast"); 
						 
					}catch(e){ 
						this.handleError("deactivateBroadcaster",e,arguments); 
					}; 
				};	 
				this.removeListener = function(obj, functionName){ 
				 
				 
				 
					try{ 
						for(var i=0; i<this.listeners.length; i++){ 
							if(this.listeners[i].obj == obj && this.listeners[i].functionName == functionName){ 
								this.listeners.splice(i,1); 
								i--; 
							} 
						} 
						if(this.listeners.length==0) this.deactivateBroadcaster(); 
					}catch(e){ 
						this.handleError("removeListener",e,arguments); 
					}; 
				}; 
			} 
		},  
		CalendarEventText : { 
			mixins: [], 
			singleton: false, 
			domElement: true, 
			constructor: function(){ 
			 	 
				this.onmouseout = function(){ 
				 
				 
				 
					this.style.backgroundColor = "#ffffff"; 
					this.style.cursor = "normal"; 
				};	 
				this.onmouseover = function(){ 
				 
				 
				 
					this.style.backgroundColor = "#e0e0e0"; 
					this.style.cursor = "pointer"; 
				}; 
			} 
		},  
		ContentBox : { 
			mixins: [], 
			singleton: false, 
			domElement: true, 
			constructor: function(){ 
			 	 
				this.init = function(){ 
				 
				 
				 
					if(!this.getAttribute('nopadding')){ 
					//fake padding 
					var pad = this.appendChild(document.createElement("div")); 
					pad.style.marginLeft = "8px"; 
					pad.style.marginRight = "8px"; 
					pad.style.marginTop = "4px"; 
					pad.style.marginBottom = "4px"; 
					while(this.childNodes.length>1){ 
						pad.appendChild(this.childNodes[0]); 
					} 
					} 
					 
					//top left corner 
					var e = this.insertBefore(document.createElement('img'),this.firstChild); 
					e.style.display = "block"; 
					e.src = "resources/images/corner_top_left.gif"; 
					 
					//top right is handled in CSS 
					 
					//bottom right corner 
					var e = this.appendChild(document.createElement("div")); 
					e.style.backgroundImage = "url(resources/images/corner_bottom_right.gif)"; 
					e.style.backgroundPosition = "bottom right"; 
					e.style.backgroundRepeat = "no-repeat"; 
					 
					//bottom left corner 
					e = e.appendChild(document.createElement("img")); 
					e.src = "resources/images/corner_bottom_left.gif"; 
					e.style.display = "block"; 
					 
					 
					 
				}; 
			} 
		},  
		ContentBoxFlatTop : { 
			mixins: [], 
			singleton: false, 
			domElement: true, 
			constructor: function(){ 
			 	 
				this.init = function(){ 
				 
				 
				 
					if(!this.getAttribute('nopadding')){ 
					//add border 
					this.style.borderTop = "1px solid #a0a0a0"; 
					 
					//fake padding 
					var pad = this.appendChild(document.createElement("div")); 
					pad.style.marginLeft = "18px"; 
					pad.style.marginRight = "18px"; 
					pad.style.marginTop = "16px"; 
					pad.style.marginBottom = "48px"; 
					while(this.childNodes.length>1){ 
						pad.appendChild(this.childNodes[0]); 
					} 
					} 
					 
					//top left corner 
					//var e = this.insertBefore(document.createElement('img'),this.firstChild); 
					//e.style.display = "block"; 
					//e.src = "resources/images/corner_top_left.gif"; 
					 
					//top right is handled in CSS 
					 
					//bottom right corner 
					var e = this.appendChild(document.createElement("div")); 
					e.style.backgroundImage = "url(resources/images/corner_bottom_right.gif)"; 
					e.style.backgroundPosition = "bottom right"; 
					e.style.backgroundRepeat = "no-repeat"; 
					 
					//bottom left corner 
					e = e.appendChild(document.createElement("img")); 
					e.src = "resources/images/corner_bottom_left.gif"; 
					e.style.display = "block"; 
				}; 
			} 
		},  
		Ease : { 
			mixins: [], 
			singleton: false, 
			domElement: false, 
			constructor: function(){ 
				 
				this.easeParams = null; 
					 
				this.frameCounter = null; 
				 	 
				this.enterFrame = function(){ 
				 
				 
				 
					try{ 
						var easeParams = this.easeParams; 
						 
						//Figure out the end value (this may change from frame to frame). 
						var endValue; 
						if(easeParams.endObjectGetter){ 
							endValue = easeParams.endObject[easeParams.endObjectGetter](); 
						}else{ 
							endValue = easeParams.endObject[easeParams.endProperty]; 
						} 
						 
						endValue = parseFloat(endValue); 
						 
						//Figure out the current value. 
						var currentValue = easeParams.easeFunction( 
						this.frameCounter, 
						easeParams.beginning, 
						endValue-easeParams.beginning, 
						easeParams.frames 
						); 
						if(!easeParams.allowFractions) currentValue = Math.floor(currentValue); 
						if(easeParams.unit) currentValue += easeParams.unit; 
						 
						//Set the current value. 
						if(easeParams.setter){ 
						easeParams.subject[easeParams.setter](currentValue); 
						}else{ 
						easeParams.subject[easeParams.property] = currentValue; 
						} 
						 
						//Stop the ease if it >is that time. 
						if (this.frameCounter == easeParams.frames) { 
						EaseManager.removeEase(easeParams); 
						if (easeParams.callback) easeParams.callbackObject[easeParams.callback](); 
						} 
						 
						this.frameCounter++; 
						 
					}catch(e){ 
						this.handleError("enterFrame",e,arguments); 
					}; 
				};	 
				this.setParameters = function(easeParams){ 
				 
				 
				 
					try{ 
						this.easeParams = easeParams; 
						 
						//Set up the beginning value. 
						if(easeParams.beginning==undefined){ 
							if(easeParams.getter){ 
								easeParams.beginning = parseFloat(easeParams.subject[easeParams.getter]()); 
							}else{ 
								easeParams.beginning = parseFloat(easeParams.subject[easeParams.property]);	 
							} 
							if(!easeParams.beginning) easeParams.beginning = 0; 
						} 
						 
						//Set up the end object. 
						if(!easeParams.endObject){ 
							if(easeParams.endProperty){ 
								easeParams.endObject = easeParams.subject; 
							}else{ 
								easeParams.endObject = {endProperty:easeParams.end}; 
								easeParams.endProperty = "endProperty"; 
							} 
						} 
						 
						//Default callback object is the subject. 
						if(!easeParams.callbackObject) easeParams.callbackObject = easeParams.subject; 
						 
						//Default ease function is easeOutSine. 
						if(!easeParams.easeFunction) easeParams.easeFunction = EaseFunctions.easeOutSine; 
						 
						//Figure frames from seconds or set to default value. 
						if(!easeParams.frames){ 
							if(easeParams.seconds) easeParams.frames = Math.floor(easeParams.seconds*AnimationBroadcaster.FRAME_RATE); 
							else easeParams.frames = 16; 
						} 
						 
						//Set the subject to the beginning, in case it is not already there. 
						this.enterFrame(); 
					}catch(e){ 
						this.handleError("setParameters",e,arguments); 
					}; 
				}; 
			} 
		},  
		EaseFunctions : { 
			mixins: [], 
			singleton: true, 
			domElement: false, 
			constructor: function(){ 
			 	 
				this.easeInLinear = function(t, b, c, d){ 
				 
				 
				 
					try{ 
						if(t==d) return b+c; 
						return c*t/d+b; 
					}catch(e){ 
						this.handleError("easeInLinear",e,arguments); 
					}; 
				};	 
				this.easeInSine = function(t, b, c, d){ 
				 
				 
				 
					try{ 
						if(t==d) return b+c; 
						return -c*Math.cos(t/d*(Math.PI/2))+c+b; 
					}catch(e){ 
						this.handleError("easeInSine",e,arguments); 
					}; 
				};	 
				this.easeOutLinear = function(t, b, c, d){ 
				 
				 
				 
					try{ 
						if(t==d) return b+c; 
						return c*t/d+b; 
					}catch(e){ 
						this.handleError("easeOutLinear",e,arguments); 
					}; 
				};	 
				this.easeOutSine = function(t, b, c, d){ 
				 
				 
				 
					try{ 
						if(t==d) return b+c; 
						return c*Math.sin(t/d*(Math.PI/2))+b; 
					}catch(e){ 
						this.handleError("easeOutSine",e,arguments); 
					}; 
				}; 
			} 
		},  
		EaseManager : { 
			mixins: [], 
			singleton: true, 
			domElement: false, 
			constructor: function(){ 
				 
				this.eases = []; 
				 	 
				this.createEase = function(easeParams){ 
				 
				 
				 
					try{ 
						this.removeEase(easeParams); 
						var ease = ObjectTools.createFromClass("Ease"); 
						ease.setParameters(easeParams); 
						this.eases.push(ease); 
						AnimationBroadcaster.addListener(ease,'enterFrame'); 
						return ease; 
					}catch(e){ 
						this.handleError("createEase",e,arguments); 
					}; 
				};	 
				this.removeEase = function(easeParams){ 
				 
				 
				 
					try{ 
						for(var i=0; i<this.eases.length;i++){ 
							var ease = this.eases[i]; 
							//If the subject matches and either the property or setter matches, 
							//then remove the ease. 
							if(ease.easeParams.subject==easeParams.subject 
							   && ( 
							   easeParams.property && easeParams.property==ease.easeParams.property || 
							   easeParams.setter && easeParams.setter==ease.easeParams.setter 
							   ) 
							){ 
								AnimationBroadcaster.removeListener(ease,'enterFrame'); 
								this.eases.splice(i,1); 
								 
								//there should only ever be one ease to remove 
								break; 
							} 
						} 
					}catch(e){ 
						this.handleError("removeEase",e,arguments); 
					}; 
				}; 
			} 
		},  
		EventBroadcaster : { 
			mixins: [], 
			singleton: false, 
			domElement: true, 
			constructor: function(){ 
				 
				this.eventRegistry = {}; 
				 	 
				this.addListener = function(listenerObject, eventType){ 
				 
				 
				 
					try{ 
						if(!this.eventRegistry[eventType]) this.eventRegistry[eventType] = []; 
						this.eventRegistry[eventType].push(listenerObject); 
					}catch(e){ 
						this.handleError("addListener",e,arguments); 
					}; 
				};	 
				this.broadcast = function(eventType, eventObject){ 
				 
				 
				 
					try{ 
						if(this.eventRegistry[eventType]){ 
							for(var i=0;i<this.eventRegistry[eventType].length;i++){ 
								this.eventRegistry[eventType][i][eventType](eventObject); 
							} 
						} 
					}catch(e){ 
						this.handleError("broadcast",e,arguments); 
					}; 
				};	 
				this.removeListener = function(listenerObject, eventType){ 
				 
				 
				 
					try{ 
						if(this.eventRegistry[eventType]){ 
							for(var i=0; i<this.eventRegistry[eventType].length; i++) { 
								if(this.eventRegistry[eventType][i]==listenerObject) { 
								this.eventRegistry[eventType].splice(i,1); 
								} 
							} 
						} 
					}catch(e){ 
						this.handleError("removeListener",e,arguments); 
					}; 
				}; 
			} 
		},  
		EventSidebarEventText : { 
			mixins: [], 
			singleton: false, 
			domElement: true, 
			constructor: function(){ 
			 	 
				this.onmouseout = function(){ 
				 
				 
				 
					this.style.backgroundColor = "#ffffff"; 
					this.style.cursor = "default"; 
					 
				};	 
				this.onmouseover = function(){ 
				 
				 
				 
					this.style.backgroundColor = "#e0e0e0"; 
					this.style.cursor = "pointer"; 
					 
				}; 
			} 
		},  
		ImageLoader : { 
			mixins: [], 
			singleton: true, 
			domElement: false, 
			constructor: function(){ 
				 
				this.isActive = false; 
					 
				this.parallel = 4; 
					 
				this.queue = []; 
					 
				this.timeout = 4000; 
				 	 
				this.activate = function(){ 
				 
				 
				 
					try{ 
						this.isActive = true; 
						this.update(); 
						 
						//its safe to do this even if there is a timeout set already 
						//timeoutmanager limits to one timeout per object per function 
						//TimeoutManager.setTimeout(this,'update',1000); 
						 
						 
					}catch(e){ 
						this.handleError("activate",e,arguments); 
					}; 
				};	 
				this.load = function(element, filename){ 
				 
				 
				 
					try{ 
						//add to queue 
						this.queue.push({ 
						element: element, 
						filename: filename, 
						added: new Date() 
						}); 
						 
						//activate loader 
						this.activate(); 
						 
					}catch(e){ 
						this.handleError("load",e,arguments); 
					}; 
				};	 
				this.reportComplete = function(item){ 
				 
				 
				 
					try{ 
						//remove the item from the queue 
						for(var i=this.queue.length-1; i>=0; i--){ 
							if(this.queue[i]==item){ 
								this.queue.splice(i,1); 
							} 
						} 
						 
						//update the queue if the loader is active 
						if(this.isActive) this.update(); 
						 
					}catch(e){ 
						this.handleError("reportComplete",e,arguments); 
					}; 
				};	 
				this.update = function(){ 
				 
				 
				 
					try{ 
						for(var i=0; i<this.parallel; i++){ 
							var item = this.queue[i]; 
							var el = item.element; 
							var filename = item.filename; 
							if(el.src!=filename){ 
								el.loaderQueueItem = item; 
								el.onload = function(){ 
									ImageLoader.reportComplete(this.loaderQueueItem); 
								}; 
								el.src = filename; 
							} 
						} 
						 
						 
					}catch(e){ 
						this.handleError("update",e,arguments); 
					}; 
				}; 
			} 
		},  
		Layout : { 
			mixins: ["EventBroadcaster"], 
			singleton: true, 
			domElement: false, 
			constructor: function(){ 
				 
				this.allowErrors = true; 
				 	 
				this.getSize = function(){ 
				 
				 
				 
					try{ 
						var s = {}; 
						 
						//viewport size 
						if (window.innerHeight) // all except Explorer 
						{ 
						    s.vw = window.innerWidth-18; 
						    s.vh = window.innerHeight; 
						} 
						else if (document.documentElement && document.documentElement.clientHeight) 
						// Explorer 6 Strict Mode 
						{ 
						    s.vw = document.documentElement.clientWidth; 
						    s.vh = document.documentElement.clientHeight; 
						} 
						else if (document.body) // other Explorers 
						{ 
						    s.vw = document.body.clientWidth; 
						    s.vh = document.body.clientHeight; 
						} 
						 
						//page size  
						s.pw = Math.max(s.vw,document.body.scrollWidth); 
						s.ph = Math.max(s.vh,document.body.scrollHeight); 
						 
						//scroll position 
						if (self.pageYOffset) // all except Explorer 
						{ 
							s.sx = self.pageXOffset; 
							s.sy = self.pageYOffset; 
						} 
						else if (document.documentElement && document.documentElement.scrollTop) 
							// Explorer 6 Strict 
						{ 
							s.sx = document.documentElement.scrollLeft; 
							s.sy = document.documentElement.scrollTop; 
						} 
						else if (document.body) // all other Explorers 
						{ 
							s.sx = document.body.scrollLeft; 
							s.sy = document.body.scrollTop; 
						} 
						 
						return s; 
						 
					}catch(e){ 
						this.handleError("getSize",e,arguments); 
					}; 
				};	 
				this.init = function(){ 
				 
				 
				 
					try{ 
						window.onresize = function(){ 
							Layout.onResize(); 
						}; 
						window.onscroll = function(){ 
							Layout.onScroll(); 
						}; 
						window.onunload = function(){ 
							Layout.onUnload(); 
						};  
						 
					}catch(e){ 
						this.handleError("init",e,arguments); 
					}; 
				};	 
				this.onResize = function(s){ 
				 
				 
				 
					try{ 
						var s = this.getSize(); 
						this.broadcast("onResize",s); 
						 
					}catch(e){ 
						this.handleError("onResize",e,arguments); 
					}; 
				};	 
				this.onScroll = function(){ 
				 
				 
				 
					try{ 
						var s = this.getSize(); 
						this.broadcast("onScroll",s); 
					}catch(e){ 
						this.handleError("onScroll",e,arguments); 
					}; 
				};	 
				this.onUnload = function(){ 
				 
				 
				 
					try{ 
						TimeoutManager.clearAllTimeouts(); 
						 
					}catch(e){ 
						this.handleError("onUnload",e,arguments); 
					}; 
				}; 
			} 
		},  
		Logger : { 
			mixins: [], 
			singleton: false, 
			domElement: true, 
			constructor: function(){ 
			 	 
				this.handleError = function(functionName, e, args){ 
				 
				 
				 
					if(false){ 
						 
					//The arguments object does not have a join method, even though it acts like an array.  It needs one. 
					args.join = [].join; 
					 
					var message = this.clazz+"."+functionName+"("+args.join(", ")+"): "+e.message+". "; //+line; 
					try{  
						console.log(message); 
					}catch(e){ 
						alert(message); 
					} 
					 
					} 
				};	 
				this.log = function(message){ 
				 
				 
				 
					try{ 
						message = this.clazz+": "+message; 
						try{  
							console.log(message); 
						}catch(e){ 
							var body = document.getElementsByTagName('body')[0]; 
							body.appendChild(document.createTextNode(message)); 
							body.appendChild(document.createElement('br')); 
						} 
						 
					}catch(e){ 
						this.handleError("log",e,arguments); 
					}; 
				};	 
				this.logFunctionCall = function(functionName, args){ 
				 
				 
				 
					//The arguments object does not have a join method, even though it acts like an array.  It needs one. 
					args.join = [].join; 
					 
					this.log(functionName+"("+args.join(", ")+")"); 
					 
				}; 
			} 
		},  
		Menubar : { 
			mixins: [], 
			singleton: true, 
			domElement: true, 
			constructor: function(){ 
				 
				this.activatedButton = null; 
					 
				this.buttonPendingActivation = null; 
					 
				this.buttons = []; 
					 
				this.isActivated = false; 
					 
				this.menus = []; 
				 	 
				this.activateMenubar = function(button){ 
				 
				 
				 
					try{ 
						if(!this.isActivated){ 
							this.isActivated = true; 
							this.activatedButton = null; 
							if(button) this.setActivatedButton(button); 
							else this.setActivatedButton(this.buttonPendingActivation); 
						} 
						 
					}catch(e){ 
						this.handleError("activateMenubar",e,arguments); 
					}; 
				};	 
				this.deactivateMenubar = function(){ 
				 
				 
				 
					try{ 
						this.isActivated = false; 
						this.setActivatedButton(null); 
					}catch(e){ 
						this.handleError("deactivateMenubar",e,arguments); 
					}; 
				};	 
				this.onmouseout = function(){ 
				 
				 
				 
					try{ 
						TimeoutManager.setTimeout(this,"deactivateMenubar",1200); 
					}catch(e){ 
						this.handleError("onmouseout",e,arguments); 
					}; 
				};	 
				this.onmouseover = function(){ 
				 
				 
				 
					try{ 
						TimeoutManager.clearTimeout(this,"deactivateMenubar"); 
					}catch(e){ 
						this.handleError("onmouseover",e,arguments); 
					}; 
				};	 
				this.setActivatedButton = function(button){ 
				 
				 
				 
					try{ 
						if(!this.isActivated && button){ 
							//In this case, the menu is not activated, but a button is selected 
							//so the menu is pending activation 
							this.buttonPendingActivation = button; 
							TimeoutManager.setTimeout(this,"activateMenubar",1200); 
						}else{ 
							//Otherwise, the menu is active, or it has just been deactivated 
							if(this.activatedButton != button){ 
								this.activatedButton = button;	 
								 
								//So we know out which menus to keep. 
								var keepers = []; 
								if(button){ 
						 
									TimeoutManager.clearTimeout(button.parentMenu,"hide"); 
						 
									//If the button has a submenu, show the menu, 
									//and mark the menu as a keeper. 
									if(button.submenu && this.isActivated){ 
										button.submenu.show(); 
										keepers.push(button.submenu); 
									} 
						 
									//If the button has a parent menu, mark the menu, 
									//and it's ancestors, as keepers. 
									var menu = button.parentMenu; 
									if(menu) do{ 
										keepers.push(menu); 
									}while(menu = menu.parentMenu); 
								} 
								//Hide the other menus. 
								for(var i=0; i<this.menus.length; i++){ 
									if(!ObjectTools.contains(this.menus[i],keepers)){ 
										//Do we need to get out of the way of another menu? 
										if(!button || button.submenu){ 
											//Hide the menu NOW. 
											this.menus[i].hide(); 
										}else{ 
											//Hide the menu in a little bit. 
											this.menus[i].hideLater(); 
										} 
									} 
								} 
							} 
						} 
						 
						//Set button rollovers. 
						if(button) button.doRollover(); 
						 
						for(var i=0; i<this.buttons.length; i++){ 
							if(this.buttons[i]!=button){ 
								if(!ObjectTools.contains(this.buttons[i].submenu,keepers)){ 
									this.buttons[i].resetRollover(); 
								} 
							} 
						} 
					}catch(e){ 
						this.handleError("setActivatedButton",e,arguments); 
					}; 
				}; 
			} 
		},  
		MenubarButton : { 
			mixins: ["MouseEventElement", "OpacityElement"], 
			singleton: false, 
			domElement: true, 
			constructor: function(){ 
				 
				this.backgroundColor = "transparent"; 
					 
				this.backgroundRolloverColor = "transparent"; 
					 
				this.textColor = "#ffffff"; 
					 
				this.textRolloverColor = "#ffffa0"; 
				 	 
				this.doRollover = function(){ 
				 
				 
				 
					try{ 
						this.firstChild.style.backgroundColor = this.backgroundRolloverColor; 
						this.lastChild.style.color = this.textRolloverColor; 
					}catch(e){ 
						this.handleError("doRollover",e,arguments); 
					}; 
				};	 
				this.init = function(){ 
				 
				 
				 
					try{ 
						//Add to the buttons array. 
						Menubar.buttons.push(this); 
						//Assign the parentMenu property. 
						if(this.parentNode.className.indexOf('MenubarCascadingMenu')!=-1){ 
						   this.parentMenu = this.parentNode; 
						} 
						//Register this button with the parent menu. 
						if(!this.parentNode.buttons) this.parentNode.buttons = []; 
						this.parentNode.buttons.push(this);	 
						 
						 
					}catch(e){ 
						this.handleError("init",e,arguments); 
					}; 
				};	 
				this.onmouseover = function(e){ 
				 
				 
				 
					try{ 
						Menubar.setActivatedButton(this); 
						 
					}catch(e){ 
						this.handleError("onmouseover",e,arguments); 
					}; 
				};	 
				this.resetRollover = function(){ 
				 
				 
				 
					try{ 
						this.firstChild.style.backgroundColor = this.backgroundColor; 
						this.lastChild.style.color = this.textColor; 
						 
					}catch(e){ 
						this.handleError("resetRollover",e,arguments); 
					}; 
				}; 
			} 
		},  
		MenubarCascadingButton : { 
			mixins: ["MenubarButton"], 
			singleton: false, 
			domElement: true, 
			constructor: function(){ 
				 
				this.backgroundColor = "#A5A595"; 
					 
				this.backgroundRolloverColor = "#B6B6A9"; 
					 
				this.textColor = "#ffffff"; 
					 
				this.textRolloverColor = "#ffffa0"; 
				 	 
				this.init = function(){ 
				 
				 
				 
					//Add to the buttons array. 
					Menubar.buttons.push(this); 
					//Assign the parentMenu property. 
					if(this.parentNode.className.indexOf('MenubarCascadingMenu')!=-1){ 
					   this.parentMenu = this.parentNode; 
					} 
					//Register this button with the parent menu. 
					if(!this.parentNode.buttons) this.parentNode.buttons = []; 
					this.parentNode.buttons.push(this); 
					 
					this.setOpacity(0); 
					 
				}; 
			} 
		},  
		MenubarCascadingMenu : { 
			mixins: [], 
			singleton: false, 
			domElement: true, 
			constructor: function(){ 
			 	 
				this.finishedHiding = function(){ 
				 
				 
				 
					try{ 
						this.style.display = 'none'; 
					}catch(e){ 
						this.handleError("finishedHiding",e,arguments); 
					}; 
				};	 
				this.getOpacity = function(){ 
				 
				 
				 
					try{ 
						return this.buttons[0].getOpacity(); 
					}catch(e){ 
						this.handleError("getOpacity",e,arguments); 
					}; 
				};	 
				this.hide = function(){ 
				 
				 
				 
					try{ 
						//is it already hidden? 
						if(this.style.display == 'none') return; 
						TimeoutManager.clearTimeout(this,"hide"); 
						this.style.zIndex = 0; 
						EaseManager.createEase({ 
							subject:this, 
							setter:'setOpacity', 
							getter:'getOpacity', 
							end:0, 
							allowFractions:true, 
							callbackObject:this, 
							callback:'finishedHiding' 
						}); 
						 
						 
					}catch(e){ 
						this.handleError("hide",e,arguments); 
					}; 
				};	 
				this.hideLater = function(){ 
				 
				 
				 
					try{ 
						//is it already hidden or hiding? 
						if(this.style.display == 'none' || TimeoutManager.getTimeout(this,"hide")) return; 
						TimeoutManager.setTimeout(this,"hide",1000); 
						 
						 
					}catch(e){ 
						this.handleError("hideLater",e,arguments); 
					}; 
				};	 
				this.init = function(){ 
				 
				 
				 
					try{ 
						//Assign this to a button as it's submenu. 
						this.previousSibling.submenu = this; 
						 
						//Add to the menus array. 
						Menubar.menus.push(this); 
						 
						//Assign the parentMenu property. 
						if(this.parentNode.className.indexOf('MenubarCascadingMenu')!=-1){ 
						   this.parentMenu = this.parentNode; 
						} 
						 
						 
					}catch(e){ 
						this.handleError("init",e,arguments); 
					}; 
				};	 
				this.setOpacity = function(opacity){ 
				 
				 
				 
					try{ 
						for(var i=0; i<this.buttons.length; i++){ 
							this.buttons[i].setOpacity(opacity); 
						} 
						 
						 
					}catch(e){ 
						this.handleError("setOpacity",e,arguments); 
					}; 
				};	 
				this.show = function(){ 
				 
				 
				 
					try{ 
						TimeoutManager.clearTimeout(this,"hide"); 
						this.style.zIndex = 1; 
						EaseManager.createEase({ 
							subject:this, 
							setter:'setOpacity', 
							getter:'getOpacity', 
							end:1, 
							allowFractions:true 
						}); 
						this.style.display = 'block'; 
						 
						 
					}catch(e){ 
						this.handleError("show",e,arguments); 
					}; 
				}; 
			} 
		},  
		MouseEventElement : { 
			mixins: [], 
			singleton: false, 
			domElement: true, 
			constructor: function(){ 
			 	 
				this.checkMouseOut = function(event){ 
				 
				 
				 
					try{ 
						if (!event) var event = window.event; 
						if (!event){ 
							this.log("No event object available"); 
							return true; 
						} 
						var target = window.event ? event.srcElement : event.target; 
						 
						var relatedTarget = event.relatedTarget ? event.relatedTarget : event.toElement; 
						 
						while (relatedTarget && relatedTarget.nodeName != 'BODY'){ 
							if(relatedTarget==this) return false; 
							relatedTarget = relatedTarget.parentNode; 
						} 
						return true; 
						 
						 
					}catch(e){ 
						this.handleError("checkMouseOut",e,arguments); 
					}; 
				};	 
				this.checkMouseOver = function(event){ 
				 
				 
				 
					try{ 
						if (!event) var event = window.event; 
						var target = (window.event) ? event.srcElement : event.target; 
						var relatedTarget = (event.relatedTarget) ? event.relatedTarget : event.fromElement; 
						 
						while (relatedTarget && relatedTarget.nodeName != 'BODY'){ 
							if(relatedTarget==this) return false; 
							relatedTarget = relatedTarget.parentNode; 
						} 
						return true; 
						 
						 
					}catch(e){ 
						this.handleError("checkMouseOver",e,arguments); 
					}; 
				};	 
				this.getEventTarget = function(e){ 
				 
				 
				 
					try{ 
						//Credit Peter-Paul Koch 
						//quirksmode.org 
						var target; 
						if (!e) var e = window.event; 
						if (e.target) target = e.target; 
						else if (e.srcElement) target = e.srcElement; 
						if (target.nodeType == 3) // defeat Safari bug 
							target = target.parentNode; 
						return target; 
					}catch(e){ 
						this.handleError("getEventTarget",e,arguments); 
					}; 
				}; 
			} 
		},  
		ObjectTools : { 
			mixins: [], 
			singleton: true, 
			domElement: false, 
			constructor: function(){ 
			 	 
				this.contains = function(needle, haystack){ 
				 
				 
				 
					try{ 
						for(var i=0; i<haystack.length; i++){ 
							if(needle==haystack[i]) return true; 
						} 
						return false; 
						 
						 
					}catch(e){ 
						this.handleError("contains",e,arguments); 
					}; 
				};	 
				this.createDomElementFromClass = function(nodeName, className){ 
				 
				 
				 
					try{ 
						var e = document.createElement(nodeName); 
							e.className = className; 
							ObjectTools.mixIn(e,className); 
							if(e.init) e.init(); 
						return e; 
						 
					}catch(e){ 
						this.handleError("createDomElementFromClass",e,arguments); 
					}; 
				};	 
				this.createFromClass = function(name){ 
				 
				 
				 
					try{ 
						var c = this.classes[name]; 
						var o = new c.constructor(); 
						o.clazz = name; 
						for(var i=0; i<c.mixins.length; i++){ 
							this.mixIn(o,c.mixins[i]); 
						} 
						if(!o.log) this.mixIn(o,"Logger"); 
						return o; 
						 
					}catch(e){ 
						this.handleError("createFromClass",e,arguments); 
					}; 
				};	 
				this.getKeys = function(obj){ 
				 
				 
				 
					try{ 
						var keys = []; 
						for(key in obj){ 
							keys.push(key); 
						} 
						return keys; 
					}catch(e){ 
						this.handleError("getKeys",e,arguments); 
					}; 
				};	 
				this.hasKey = function(obj, key){ 
				 
				 
				 
					try{ 
						for(aKey in obj){ 
							if(aKey == key) return true; 
						} 
						return false; 
					}catch(e){ 
						this.handleError("hasKey",e,arguments); 
					}; 
				};	 
				this.init = function(){ 
				 
				 
				 
					var domMixins = []; 
					 
					var inits = []; 
					 
					for(var name in this.classes){ 
						var c = this.classes[name]; 
						//Find the singletons, instantiate or mix in to dom elements as appropriate. 
						if(c.singleton){ 
							if(c.domElement){ 
								var e = document.getElementById(name); 
								if(e){ 
									ObjectTools.mixIn(e,name); 
									window[name] = e; 
								} 
							}else{ 
								if(name!=this.clazz){ 
									window[name] = this.createFromClass(name); 
								} 
								 
							} 
							if(window[name] && window[name].init && name!=this.clazz) inits.push(window[name]); 
						}else{ 
							if(c.domElement){ 
								domMixins.push({ 
									name: name, 
									regex: new RegExp("^(.*? )?"+name+"( .*?)?$") 
								}); 
							}else{ 
								//Do nothing. 
							} 
						} 
					} 
					 
					//Scan the document and mix in classes based on class names. 
					var elements = document.getElementsByTagName("*"); 
					for(var i=0; i<elements.length; i++){ 
						var e = elements[i]; 
						if(e.className){ 
							for(var j=0; j<domMixins.length; j++){ 
								var mixin = domMixins[j]; 
								if(e.className.match(mixin.regex)){ 
									ObjectTools.mixIn(e,mixin.name); 
									if(e.init) inits.push(e); 
								} 
							} 
						} 
					} 
					 
					//Execute the inits 
					for(var i=0; i<inits.length; i++){ 
						inits[i].init(); 
					} 
					 
					 
					//Layout the display 
					Layout.onResize(); 
					 
				};	 
				this.mixIn = function(iceCream, cherries){ 
				 
				 
				 
					try{ 
						//Instantiate an object of the class if a class name is specified. 
						if(typeof cherries == "string") cherries = this.createFromClass(cherries); 
						 
						//Copy the properties from cherries to object. 
						for(name in cherries){ 
							if(iceCream[name]==undefined) iceCream[name] = cherries[name];	 
						} 
						return iceCream; 
					}catch(e){ 
						this.handleError("mixIn",e,arguments); 
					}; 
				}; 
			} 
		},  
		OpacityElement : { 
			mixins: [], 
			singleton: false, 
			domElement: true, 
			constructor: function(){ 
			 	 
				this.getOpacity = function(){ 
				 
				 
				 
					try{ 
						var opacity; 
						if(this.filters){ 
							opacity = this.filters.item(0).opacity/100; 
						}else{ 
							opacity = parseFloat(this.style.opacity); 
						} 
						 
						//if opacity is not explicitly set, then we assume  
						//there is full opacity as the browser would render it 
						if(typeof opacity != "number" || isNaN(opacity)) opacity=1; 
						 
						return opacity; 
					}catch(e){ 
						this.handleError("getOpacity",e,arguments); 
					}; 
				};	 
				this.setOpacity = function(opacity){ 
				 
				 
				 
					try{ 
						if(this.filters){ 
							this.filters.item(0).opacity = Math.floor(opacity*100);	 
						}else{ 
							this.style.opacity = opacity; 
						} 
						 
					}catch(e){ 
						this.handleError("setOpacity",e,arguments); 
					}; 
				}; 
			} 
		},  
		PhotoLarge : { 
			mixins: [], 
			singleton: true, 
			domElement: true, 
			constructor: function(){ 
				 
				this.aspect = null; 
				 	 
				this.hide = function(){ 
				 
				 
				 
					try{ 
						Screen.hide(); 
						this.style.display='none'; 
						 
						 
					}catch(e){ 
						this.handleError("hide",e,arguments); 
					}; 
				};	 
				this.init = function(){ 
				 
				 
				 
					try{ 
						Layout.addListener(this,'onResize'); 
						Layout.addListener(this,'onScroll'); 
						 
					}catch(e){ 
						this.handleError("init",e,arguments); 
					}; 
				};	 
				this.onclick = function(){ 
				 
				 
				 
					try{ 
						this.hide(); 
					}catch(e){ 
						this.handleError("onclick",e,arguments); 
					}; 
				};	 
				this.onload = function(){ 
				 
				 
				 
					try{ 
						this.style.display='block'; 
					}catch(e){ 
						this.handleError("onload",e,arguments); 
					}; 
				};	 
				this.onResize = function(s){ 
				 
				 
				 
					try{ 
						var max = 1024; 
						var viewportAspect = s.vw/s.vh; 
						var maxWidth, maxHeight, finalWidth, finalHeight; 
						 
						if(this.aspect>1){ 
							maxWidth = max; 
							maxHeight = Math.floor(max/this.aspect); 
						}else{ 
							maxHeight = max; 
							maxWidth = Math.floor(max/this.aspect); 
						} 
						 
						if(maxWidth>s.vw || maxHeight>s.vh){ 
							//scale the image down to fit the viewport 
							if(this.aspect>viewportAspect){ 
								finalWidth = s.vw-32; 
								finalHeight = Math.floor(s.vw/this.aspect); 
							}else{ 
								finalHeight = s.vh-32; 
								finalWidth = Math.floor(s.vh*this.aspect); 
							} 
						}else{ 
							finalHeight = maxHeight; 
							finalWidth = maxWidth; 
						} 
						 
						this.style.width = finalWidth+"px"; 
						this.style.height = finalHeight+"px"; 
						 
						this.style.left = Math.floor((s.vw-finalWidth)/2)+"px"; 
						this.style.top = (Math.floor((s.vh-finalHeight)/2)+s.sy)+"px"; 
						 
					}catch(e){ 
						this.handleError("onResize",e,arguments); 
					}; 
				};	 
				this.onScroll = function(s){ 
				 
				 
				 
					try{ 
						var height = parseInt(this.style.height); 
						this.style.top = (Math.floor((s.vh-height)/2)+s.sy)+"px"; 
					}catch(e){ 
						this.handleError("onScroll",e,arguments); 
					}; 
				};	 
				this.show = function(filename, aspect){ 
				 
				 
				 
					try{ 
						this.aspect = aspect; 
						 
						//setup width and height 
						var s = Layout.getSize(); 
						this.onResize(s); 
						 
						//set the src for the image 
						this.src = "l_"+filename; 
						 
						//show the screen 
						Screen.show(); 
						 
					}catch(e){ 
						this.handleError("show",e,arguments); 
					}; 
				}; 
			} 
		},  
		RemoteBoat : { 
			mixins: [], 
			singleton: false, 
			domElement: false, 
			constructor: function(){ 
			 	 
				this.getXMLHTTPRequest = function(){ 
				 
				 
				 
					try{ 
						var req = false; 
						// branch for native XMLHttpRequest object 
						if(window.XMLHttpRequest) { 
							try { 
								req = new XMLHttpRequest(); 
						    } catch(e) { 
								req = false; 
						    } 
						// branch for IE/Windows ActiveX version 
						} else if(window.ActiveXObject) { 
						   	try { 
						    	req = new ActiveXObject("Msxml2.XMLHTTP"); 
						  	} catch(e) { 
						    	try { 
						      		req = new ActiveXObject("Microsoft.XMLHTTP"); 
						    	} catch(e) { 
						      		req = false; 
						    	} 
							} 
						} 
						return req; 
					}catch(e){ 
						this.handleError("getXMLHTTPRequest",e,arguments); 
					}; 
				};	 
				this.sendRequest = function(params){ 
				 
				 
				 
					try{ 
						var request = this.getXMLHTTPRequest(); 
						 
						//The default callback object is this. 
						if(params.callbackObject==undefined) params.callbackObject = this; 
						 
						//If an XML doc has been provided, serialize it. 
						if(typeof params.query == "object"){ 
							//For Gecko browsers. 
							if(params.query.xml) params.query = params.query.xml; 
							//For IE 
							else params.query = (new XMLSerializer()).serializeToString(params.query); 
						} 
						 
						//Prepare to handle the completed request. 
						request.onreadystatechange = function(){ 
						 
							// only if request shows "loaded" 
							if (request.readyState == 4) { 
								// only if "OK" 
								if (request.status == 200) { 
									 
									//in IE6 you can't mixin to the request object 
						 
									var result = {responseText: request.responseText, responseXML: request.responseXML}; 
									 
									if(params.mixin){ 
										ObjectTools.mixIn(result,params.mixin); 
									} 
						 
									if(params.callback) params.callbackObject[params.callback](result); 
								} else { 
									alert("There was a problem executing the query: " + request.statusText); 
								} 
							} 
						} 
						//Send the request. 
						request.open('POST',params.url,true); 
						 
						if(params.query) request.send(params.query);	 
						else request.send(""); 
						 
					}catch(e){ 
						this.handleError("sendRequest",e,arguments); 
					}; 
				}; 
			} 
		},  
		Screen : { 
			mixins: ["OpacityElement"], 
			singleton: true, 
			domElement: true, 
			constructor: function(){ 
			 	 
				this.finishedHiding = function(){ 
				 
				 
				 
					try{ 
						this.style.display = "none"; 
					}catch(e){ 
						this.handleError("finishedHiding",e,arguments); 
					}; 
				};	 
				this.hide = function(){ 
				 
				 
				 
					try{ 
						TimeoutManager.clearTimeout(this,"show"); 
						this.setOpacity(0); 
						this.finishedHiding(); 
						 
						/* 
						EaseManager.createEase({ 
							subject:this, 
							setter:'setOpacity', 
							getter:'getOpacity', 
							end:0, 
							allowFractions:true, 
							callbackObject:this, 
							callback:'finishedHiding' 
						}); 
						*/ 
						 
					}catch(e){ 
						this.handleError("hide",e,arguments); 
					}; 
				};	 
				this.init = function(){ 
				 
				 
				 
					try{ 
						Layout.addListener(this,'onResize'); 
						Layout.addListener(this,'onScroll'); 
						 
					}catch(e){ 
						this.handleError("init",e,arguments); 
					}; 
				};	 
				this.onclick = function(){ 
				 
				 
				 
					try{ 
						PhotoLarge.hide(); 
					}catch(e){ 
						this.handleError("onclick",e,arguments); 
					}; 
				};	 
				this.onResize = function(s){ 
				 
				 
				 
					try{ 
						this.style.top = (s.sy-128)+"px"; 
						this.style.width = s.vw+"px"; 
						this.style.height = (s.vh+256)+"px"; 
					}catch(e){ 
						this.handleError("onResize",e,arguments); 
					}; 
				};	 
				this.onScroll = function(s){ 
				 
				 
				 
					try{ 
						this.style.top = (s.sy-128)+"px"; 
					}catch(e){ 
						this.handleError("onScroll",e,arguments); 
					}; 
				};	 
				this.show = function(){ 
				 
				 
				 
					try{ 
						this.onResize(Layout.getSize()); 
						 
						TimeoutManager.clearTimeout(this,"hide"); 
						EaseManager.createEase({ 
							subject:this, 
							setter:'setOpacity', 
							getter:'getOpacity', 
							beginning: 0, 
							end:0.9, 
							allowFractions:true 
						}); 
						 
						this.style.display = "block"; 
						 
					}catch(e){ 
						this.handleError("show",e,arguments); 
					}; 
				}; 
			} 
		},  
		Thumbnail : { 
			mixins: [], 
			singleton: false, 
			domElement: true, 
			constructor: function(){ 
			 	 
				this.init = function(){ 
				 
				 
				 
					try{ 
						var f = this.getAttribute('f'); 
						ImageLoader.load(this,f); 
					}catch(e){ 
						this.handleError("init",e,arguments); 
					}; 
				}; 
			} 
		},  
		TimeoutManager : { 
			mixins: [], 
			singleton: true, 
			domElement: false, 
			constructor: function(){ 
				 
				this.timeouts = []; 
				 	 
				this.clearAllTimeouts = function(){ 
				 
				 
				 
					try{ 
						while(this.timeouts.length){ 
							clearInterval(this.timeouts[0].id); 
							this.timeouts.splice(0,1); 
						} 
					}catch(e){ 
						this.handleError("clearAllTimeouts",e,arguments); 
					}; 
				};	 
				this.clearTimeout = function(obj, functionName){ 
				 
				 
				 
					try{ 
						for(var i=0; i<this.timeouts.length; i++){ 
							if(this.timeouts[i].obj==obj && this.timeouts[i].functionName==functionName){ 
								clearInterval(this.timeouts[i].id); 
								this.timeouts.splice(i,1); 
								i--; 
							} 
						} 
					}catch(e){ 
						this.handleError("clearTimeout",e,arguments); 
					}; 
				};	 
				this.getTimeout = function(obj, functionName){ 
				 
				 
				 
					try{ 
						var timeout = false; 
						for(var i=0; i<this.timeouts.length; i++){ 
							if(this.timeouts[i].obj==obj && this.timeouts[i].functionName==functionName){ 
								timeout = this.timeouts[i]; 
							} 
						} 
						return timeout; 
					}catch(e){ 
						this.handleError("getTimeout",e,arguments); 
					}; 
				};	 
				this.setTimeout = function(obj, functionName, time){ 
				 
				 
				 
					try{ 
						var repeat = arguments[3]; 
						var exists = false; 
						for(var i=0; i<this.timeouts.length; i++){ 
							if(this.timeouts[i].obj==obj && this.timeouts[i].functionName==functionName){ 
								exists = true; 
							} 
						} 
						if(!exists){ 
							var doFunction = function(){ 
								if(!repeat) TimeoutManager.clearTimeout(obj,functionName); 
								obj[functionName](); 
							} 
							this.timeouts.push({ 
								obj:obj, 
								functionName:functionName, 
								id: setInterval(doFunction,time) 
							}); 
						} 
					}catch(e){ 
						this.handleError("setTimeout",e,arguments); 
					}; 
				}; 
			} 
		},  
		BookingsApp : { 
			mixins: [], 
			singleton: true, 
			domElement: true, 
			constructor: function(){ 
				 
				this.divers = []; 
				  
			} 
		},  
		MenubarButtonBackground : { 
			mixins: ["OpacityElement"], 
			singleton: false, 
			domElement: true, 
			constructor: function(){ 
			  
			} 
		} 
	};	 
}; 
 
function initJavascript(){ 
 
	//Set up the ObjectTools properly, and initialize. 
 
	var o = new ObjectTools.classes.ObjectTools.constructor(); 
 
	o.clazz = "ObjectTools"; 
 
	for(name in o){ 
		if(ObjectTools[name]==undefined) ObjectTools[name] = o[name]; 
	} 
 
	var o = new ObjectTools.classes.Logger.constructor(); 
 
	for(name in o){ 
		if(ObjectTools[name]==undefined) ObjectTools[name] = o[name]; 
	} 
 
	ObjectTools.init(); 
} 
