var cH=800;var cW=1200;var CtryCD='USA';var StCD='NJ';var SAID=0;var TbPos=10702;
var Prototype = { Version: '1.6.0.2', Browser: { IE: !!(window.attachEvent && !window.opera), Opera: !!window.opera, WebKit: navigator.userAgent.indexOf('AppleWebKit/') > -1, Gecko: navigator.userAgent.indexOf('Gecko') > -1 && navigator.userAgent.indexOf('KHTML') == -1, MobileSafari: !!navigator.userAgent.match(/Apple.*Mobile.*Safari/) }, BrowserFeatures: { XPath: !!document.evaluate, ElementExtensions: !!window.HTMLElement, SpecificElementExtensions:
 document.createElement('div').__proto__ &&
 document.createElement('div').__proto__ !==
 document.createElement('form').__proto__
 }, ScriptFragment: '<script[^>]*>([\\S\\s]*?)<\/script>', JSONFilter: /^\/\*-secure-([\s\S]*)\*\/\s*$/, emptyFunction: function() { }, K: function(x) { return x }};if (Prototype.Browser.MobileSafari) Prototype.BrowserFeatures.SpecificElementExtensions = false;var Class = { create: function() { var parent = null, properties = $A(arguments); if (Object.isFunction(properties[0])) parent = properties.shift(); function klass() { this.initialize.apply(this, arguments); } Object.extend(klass, Class.Methods); klass.superclass = parent; klass.subclasses = []; if (parent) { var subclass = function() { }; subclass.prototype = parent.prototype; klass.prototype = new subclass; parent.subclasses.push(klass); } for (var i = 0; i < properties.length; i++) klass.addMethods(properties[i]); if (!klass.prototype.initialize) klass.prototype.initialize = Prototype.emptyFunction; klass.prototype.constructor = klass; return klass; }};Class.Methods = { addMethods: function(source) { var ancestor = this.superclass && this.superclass.prototype; var properties = Object.keys(source); if (!Object.keys({ toString: true }).length) properties.push("toString", "valueOf"); for (var i = 0, length = properties.length; i < length; i++) { var property = properties[i], value = source[property]; if (ancestor && Object.isFunction(value) &&
 value.argumentNames().first() == "$super") { var method = value, value = Object.extend((function(m) { return function() { return ancestor[m].apply(this, arguments) }; })(property).wrap(method), { valueOf: function() { return method }, toString: function() { return method.toString() } }); } this.prototype[property] = value; } return this; }};var Abstract = { };Object.extend = function(destination, source) { for (var property in source) destination[property] = source[property]; return destination;};Object.extend(Object, { inspect: function(object) { try { if (Object.isUndefined(object)) return 'undefined'; if (object === null) return 'null'; return object.inspect ? object.inspect() : String(object); } catch (e) { if (e instanceof RangeError) return '...'; throw e; } }, toJSON: function(object) { var type = typeof object; switch (type) { case 'undefined':
 case 'function':
 case 'unknown': return; case 'boolean': return object.toString(); } if (object === null) return 'null'; if (object.toJSON) return object.toJSON(); if (Object.isElement(object)) return; var results = []; for (var property in object) { var value = Object.toJSON(object[property]); if (!Object.isUndefined(value)) results.push(property.toJSON() + ': ' + value); } return '{' + results.join(', ') + '}'; }, toQueryString: function(object) { return $H(object).toQueryString(); }, toHTML: function(object) { return object && object.toHTML ? object.toHTML() : String.interpret(object); }, keys: function(object) { var keys = []; for (var property in object) keys.push(property); return keys; }, values: function(object) { var values = []; for (var property in object) values.push(object[property]); return values; }, clone: function(object) { return Object.extend({ }, object); }, isElement: function(object) { return object && object.nodeType == 1; }, isArray: function(object) { return object != null && typeof object == "object" &&
 'splice' in object && 'join' in object; }, isHash: function(object) { return object instanceof Hash; }, isFunction: function(object) { return typeof object == "function"; }, isString: function(object) { return typeof object == "string"; }, isNumber: function(object) { return typeof object == "number"; }, isUndefined: function(object) { return typeof object == "undefined"; }});Object.extend(Function.prototype, { argumentNames: function() { var names = this.toString().match(/^[\s\(]*function[^(]*\((.*?)\)/)[1].split(",").invoke("strip"); return names.length == 1 && !names[0] ? [] : names; }, bind: function() { if (arguments.length < 2 && Object.isUndefined(arguments[0])) return this; var __method = this, args = $A(arguments), object = args.shift(); return function() { return __method.apply(object, args.concat($A(arguments))); } }, bindAsEventListener: function() { var __method = this, args = $A(arguments), object = args.shift(); return function(event) { return __method.apply(object, [event || window.event].concat(args)); } }, curry: function() { if (!arguments.length) return this; var __method = this, args = $A(arguments); return function() { return __method.apply(this, args.concat($A(arguments))); } }, delay: function() { var __method = this, args = $A(arguments), timeout = args.shift() * 1000; return window.setTimeout(function() { return __method.apply(__method, args); }, timeout); }, wrap: function(wrapper) { var __method = this; return function() { return wrapper.apply(this, [__method.bind(this)].concat($A(arguments))); } }, methodize: function() { if (this._methodized) return this._methodized; var __method = this; return this._methodized = function() { return __method.apply(null, [this].concat($A(arguments))); }; }});Function.prototype.defer = Function.prototype.delay.curry(0.01);Date.prototype.toJSON = function() { return '"' + this.getUTCFullYear() + '-' +
 (this.getUTCMonth() + 1).toPaddedString(2) + '-' +
 this.getUTCDate().toPaddedString(2) + 'T' +
 this.getUTCHours().toPaddedString(2) + ':' +
 this.getUTCMinutes().toPaddedString(2) + ':' +
 this.getUTCSeconds().toPaddedString(2) + 'Z"';};var Try = { these: function() { var returnValue; for (var i = 0, length = arguments.length; i < length; i++) { var lambda = arguments[i]; try { returnValue = lambda(); break; } catch (e) { } } return returnValue; }};RegExp.prototype.match = RegExp.prototype.test;RegExp.escape = function(str) { return String(str).replace(/([.*+?^=!:${}()|[\]\/\\])/g, '\\$1');};var PeriodicalExecuter = Class.create({ initialize: function(callback, frequency) { this.callback = callback; this.frequency = frequency; this.currentlyExecuting = false; this.registerCallback(); }, registerCallback: function() { this.timer = setInterval(this.onTimerEvent.bind(this), this.frequency * 1000); }, execute: function() { this.callback(this); }, stop: function() { if (!this.timer) return; clearInterval(this.timer); this.timer = null; }, onTimerEvent: function() { if (!this.currentlyExecuting) { try { this.currentlyExecuting = true; this.execute(); } finally { this.currentlyExecuting = false; } } }});Object.extend(String, { interpret: function(value) { return value == null ? '' : String(value); }, specialChar: { '\b': '\\b', '\t': '\\t', '\n': '\\n', '\f': '\\f', '\r': '\\r', '\\': '\\\\'
 }});Object.extend(String.prototype, { gsub: function(pattern, replacement) { var result = '', source = this, match; replacement = arguments.callee.prepareReplacement(replacement); while (source.length > 0) { if (match = source.match(pattern)) { result += source.slice(0, match.index); result += String.interpret(replacement(match)); source = source.slice(match.index + match[0].length); } else { result += source, source = ''; } } return result; }, sub: function(pattern, replacement, count) { replacement = this.gsub.prepareReplacement(replacement); count = Object.isUndefined(count) ? 1 : count; return this.gsub(pattern, function(match) { if (--count < 0) return match[0]; return replacement(match); }); }, scan: function(pattern, iterator) { this.gsub(pattern, iterator); return String(this); }, truncate: function(length, truncation) { length = length || 30; truncation = Object.isUndefined(truncation) ? '...' : truncation; return this.length > length ?
 this.slice(0, length - truncation.length) + truncation : String(this); }, strip: function() { return this.replace(/^\s+/, '').replace(/\s+$/, ''); }, stripTags: function() { return this.replace(/<\/?[^>]+>/gi, ''); }, stripScripts: function() { var str = this.replace(new RegExp(Prototype.ScriptFragment, 'img'), ''); while (str.indexOf('&amp;')>=0) 
 str = str.replace('&amp;','&'); return str; }, extractScripts: function() { var matchAll = new RegExp(Prototype.ScriptFragment, 'img'); var matchOne = new RegExp(Prototype.ScriptFragment, 'im'); return (this.match(matchAll) || []).map(function(scriptTag) { return (scriptTag.match(matchOne) || ['', ''])[1]; }); }, evalScripts: function() { return this.extractScripts().map(function(script) { return eval(script) }); }, escapeHTML: function() { var self = arguments.callee; self.text.data = this; return self.div.innerHTML; }, unescapeHTML: function() { var div = new Element('div'); div.innerHTML = this.stripTags(); return div.childNodes[0] ? (div.childNodes.length > 1 ?
 $A(div.childNodes).inject('', function(memo, node) { return memo+node.nodeValue }) :
 div.childNodes[0].nodeValue) : ''; }, toQueryParams: function(separator) { var match = this.strip().match(/([^?#]*)(#.*)?$/); if (!match) return { }; return match[1].split(separator || '&').inject({ }, function(hash, pair) { if ((pair = pair.split('='))[0]) { var key = decodeURIComponent(pair.shift()); var value = pair.length > 1 ? pair.join('=') : pair[0]; if (value != undefined) value = decodeURIComponent(value); if (key in hash) { if (!Object.isArray(hash[key])) hash[key] = [hash[key]]; hash[key].push(value); } else hash[key] = value; } return hash; }); }, toArray: function() { return this.split(''); }, succ: function() { return this.slice(0, this.length - 1) +
 String.fromCharCode(this.charCodeAt(this.length - 1) + 1); }, times: function(count) { return count < 1 ? '' : new Array(count + 1).join(this); }, camelize: function() { var parts = this.split('-'), len = parts.length; if (len == 1) return parts[0]; var camelized = this.charAt(0) == '-'
 ? parts[0].charAt(0).toUpperCase() + parts[0].substring(1) : parts[0]; for (var i = 1; i < len; i++) camelized += parts[i].charAt(0).toUpperCase() + parts[i].substring(1); return camelized; }, capitalize: function() { return this.charAt(0).toUpperCase() + this.substring(1).toLowerCase(); }, underscore: function() { return this.gsub(/::/, '/').gsub(/([A-Z]+)([A-Z][a-z])/,'#{1}_#{2}').gsub(/([a-z\d])([A-Z])/,'#{1}_#{2}').gsub(/-/,'_').toLowerCase(); }, dasherize: function() { return this.gsub(/_/,'-'); }, inspect: function(useDoubleQuotes) { var escapedString = this.gsub(/[\x00-\x1f\\]/, function(match) { var character = String.specialChar[match[0]]; return character ? character : '\\u00' + match[0].charCodeAt().toPaddedString(2, 16); }); if (useDoubleQuotes) return '"' + escapedString.replace(/"/g, '\\"') + '"'; return "'" + escapedString.replace(/'/g, '\\\'') + "'"; }, toJSON: function() { return this.inspect(true); }, unfilterJSON: function(filter) { return this.sub(filter || Prototype.JSONFilter, '#{1}'); }, isJSON: function() { var str = this; if (str.blank()) return false; str = this.replace(/\\./g, '@').replace(/"[^"\\\n\r]*"/g, ''); return (/^[,:{}\[\]0-9.\-+Eaeflnr-u \n\r\t]*$/).test(str); }, evalJSON: function(sanitize) { var json = this.unfilterJSON(); try { if (!sanitize || json.isJSON()) return eval('(' + json + ')'); } catch (e) { } throw new SyntaxError('Badly formed JSON string: ' + this.inspect()); }, include: function(pattern) { return this.indexOf(pattern) > -1; }, startsWith: function(pattern) { return this.indexOf(pattern) === 0; }, endsWith: function(pattern) { var d = this.length - pattern.length; return d >= 0 && this.lastIndexOf(pattern) === d; }, empty: function() { return this == ''; }, blank: function() { return /^\s*$/.test(this); }, interpolate: function(object, pattern) { return new Template(this, pattern).evaluate(object); }});if (Prototype.Browser.WebKit || Prototype.Browser.IE) Object.extend(String.prototype, { escapeHTML: function() { return this.replace(/&/g,'&amp;').replace(/</g,'&lt;').replace(/>/g,'&gt;'); }, unescapeHTML: function() { return this.replace(/&amp;/g,'&').replace(/&lt;/g,'<').replace(/&gt;/g,'>'); }});String.prototype.gsub.prepareReplacement = function(replacement) { if (Object.isFunction(replacement)) return replacement; var template = new Template(replacement); return function(match) { return template.evaluate(match) };};String.prototype.parseQuery = String.prototype.toQueryParams;Object.extend(String.prototype.escapeHTML, { div: document.createElement('div'), text: document.createTextNode('')});with (String.prototype.escapeHTML) div.appendChild(text);var Template = Class.create({ initialize: function(template, pattern) { this.template = template.toString(); this.pattern = pattern || Template.Pattern; }, evaluate: function(object) { if (Object.isFunction(object.toTemplateReplacements)) object = object.toTemplateReplacements(); return this.template.gsub(this.pattern, function(match) { if (object == null) return ''; var before = match[1] || ''; if (before == '\\') return match[2]; var ctx = object, expr = match[3]; var pattern = /^([^.[]+|\[((?:.*?[^\\])?)\])(\.|\[|$)/; match = pattern.exec(expr); if (match == null) return before; while (match != null) { var comp = match[1].startsWith('[') ? match[2].gsub('\\\\]', ']') : match[1]; ctx = ctx[comp]; if (null == ctx || '' == match[3]) break; expr = expr.substring('[' == match[3] ? match[1].length : match[0].length); match = pattern.exec(expr); } return before + String.interpret(ctx); }); }});Template.Pattern = /(^|.|\r|\n)(#\{(.*?)\})/;var $break = { };var Enumerable = { each: function(iterator, context) { var index = 0; iterator = iterator.bind(context); try { this._each(function(value) { iterator(value, index++); }); } catch (e) { } return this; }, eachSlice: function(number, iterator, context) { iterator = iterator ? iterator.bind(context) : Prototype.K; var index = -number, slices = [], array = this.toArray(); while ((index += number) < array.length) slices.push(array.slice(index, index+number)); return slices.collect(iterator, context); }, all: function(iterator, context) { iterator = iterator ? iterator.bind(context) : Prototype.K; var result = true; this.each(function(value, index) { result = result && !!iterator(value, index); if (!result) throw $break; }); return result; }, any: function(iterator, context) { iterator = iterator ? iterator.bind(context) : Prototype.K; var result = false; this.each(function(value, index) { if (result = !!iterator(value, index)) throw $break; }); return result; }, collect: function(iterator, context) { iterator = iterator ? iterator.bind(context) : Prototype.K; var results = []; this.each(function(value, index) { results.push(iterator(value, index)); }); return results; }, detect: function(iterator, context) { iterator = iterator.bind(context); var result; this.each(function(value, index) { if (iterator(value, index)) { result = value; throw $break; } }); return result; }, findAll: function(iterator, context) { iterator = iterator.bind(context); var results = []; this.each(function(value, index) { if (iterator(value, index)) results.push(value); }); return results; }, grep: function(filter, iterator, context) { iterator = iterator ? iterator.bind(context) : Prototype.K; var results = []; if (Object.isString(filter)) filter = new RegExp(filter); this.each(function(value, index) { if (filter.match(value)) results.push(iterator(value, index)); }); return results; }, include: function(object) { if (Object.isFunction(this.indexOf)) if (this.indexOf(object) != -1) return true; var found = false; this.each(function(value) { if (value == object) { found = true; throw $break; } }); return found; }, inGroupsOf: function(number, fillWith) { fillWith = Object.isUndefined(fillWith) ? null : fillWith; return this.eachSlice(number, function(slice) { while(slice.length < number) slice.push(fillWith); return slice; }); }, inject: function(memo, iterator, context) { iterator = iterator.bind(context); this.each(function(value, index) { memo = iterator(memo, value, index); }); return memo; }, invoke: function(method) { var args = $A(arguments).slice(1); return this.map(function(value) { return value[method].apply(value, args); }); }, max: function(iterator, context) { iterator = iterator ? iterator.bind(context) : Prototype.K; var result; this.each(function(value, index) { value = iterator(value, index); if (result == null || value >= result) result = value; }); return result; }, min: function(iterator, context) { iterator = iterator ? iterator.bind(context) : Prototype.K; var result; this.each(function(value, index) { value = iterator(value, index); if (result == null || value < result) result = value; }); return result; }, partition: function(iterator, context) { iterator = iterator ? iterator.bind(context) : Prototype.K; var trues = [], falses = []; this.each(function(value, index) { (iterator(value, index) ?
 trues : falses).push(value); }); return [trues, falses]; }, pluck: function(property) { var results = []; this.each(function(value) { results.push(value[property]); }); return results; }, reject: function(iterator, context) { iterator = iterator.bind(context); var results = []; this.each(function(value, index) { if (!iterator(value, index)) results.push(value); }); return results; }, sortBy: function(iterator, context) { iterator = iterator.bind(context); return this.map(function(value, index) { return {value: value, criteria: iterator(value, index)}; }).sort(function(left, right) { var a = left.criteria, b = right.criteria; return a < b ? -1 : a > b ? 1 : 0; }).pluck('value'); }, toArray: function() { return this.map(); }, zip: function() { var iterator = Prototype.K, args = $A(arguments); if (Object.isFunction(args.last())) iterator = args.pop(); var collections = [this].concat(args).map($A); return this.map(function(value, index) { return iterator(collections.pluck(index)); }); }, size: function() { return this.toArray().length; }, inspect: function() { return '#<Enumerable:' + this.toArray().inspect() + '>'; }};Object.extend(Enumerable, { map: Enumerable.collect, find: Enumerable.detect, select: Enumerable.findAll, filter: Enumerable.findAll, member: Enumerable.include, entries: Enumerable.toArray, every: Enumerable.all, some: Enumerable.any
});function $A(iterable) { if (!iterable) return []; if (iterable.toArray) return iterable.toArray(); var length = iterable.length || 0, results = new Array(length); while (length--) results[length] = iterable[length]; return results;}if (Prototype.Browser.WebKit) { $A = function(iterable) { if (!iterable) return []; if (!(Object.isFunction(iterable) && iterable == '[object NodeList]') &&
 iterable.toArray) return iterable.toArray(); var length = iterable.length || 0, results = new Array(length); while (length--) results[length] = iterable[length]; return results; };}Array.from = $A;Object.extend(Array.prototype, Enumerable);if (!Array.prototype._reverse) Array.prototype._reverse = Array.prototype.reverse;Object.extend(Array.prototype, { _each: function(iterator) { for (var i = 0, length = this.length; i < length; i++) iterator(this[i]); }, clear: function() { this.length = 0; return this; }, first: function() { return this[0]; }, last: function() { return this[this.length - 1]; }, compact: function() { return this.select(function(value) { return value != null; }); }, flatten: function() { return this.inject([], function(array, value) { return array.concat(Object.isArray(value) ?
 value.flatten() : [value]); }); }, without: function() { var values = $A(arguments); return this.select(function(value) { return !values.include(value); }); }, reverse: function(inline) { return (inline !== false ? this : this.toArray())._reverse(); }, reduce: function() { return this.length > 1 ? this : this[0]; }, uniq: function(sorted) { return this.inject([], function(array, value, index) { if (0 == index || (sorted ? array.last() != value : !array.include(value))) array.push(value); return array; }); }, intersect: function(array) { return this.uniq().findAll(function(item) { return array.detect(function(value) { return item === value }); }); }, clone: function() { return [].concat(this); }, size: function() { return this.length; }, inspect: function() { return '[' + this.map(Object.inspect).join(', ') + ']'; }, toJSON: function() { var results = []; this.each(function(object) { var value = Object.toJSON(object); if (!Object.isUndefined(value)) results.push(value); }); return '[' + results.join(', ') + ']'; }});if (Object.isFunction(Array.prototype.forEach)) Array.prototype._each = Array.prototype.forEach;if (!Array.prototype.indexOf) Array.prototype.indexOf = function(item, i) { i || (i = 0); var length = this.length; if (i < 0) i = length + i; for (; i < length; i++) if (this[i] === item) return i; return -1;};if (!Array.prototype.lastIndexOf) Array.prototype.lastIndexOf = function(item, i) { i = isNaN(i) ? this.length : (i < 0 ? this.length + i : i) + 1; var n = this.slice(0, i).reverse().indexOf(item); return (n < 0) ? n : i - n - 1;};Array.prototype.toArray = Array.prototype.clone;function $w(string) { if (!Object.isString(string)) return []; string = string.strip(); return string ? string.split(/\s+/) : [];}if (Prototype.Browser.Opera){ Array.prototype.concat = function() { var array = []; for (var i = 0, length = this.length; i < length; i++) array.push(this[i]); for (var i = 0, length = arguments.length; i < length; i++) { if (Object.isArray(arguments[i])) { for (var j = 0, arrayLength = arguments[i].length; j < arrayLength; j++) array.push(arguments[i][j]); } else { array.push(arguments[i]); } } return array; };}Object.extend(Number.prototype, { toColorPart: function() { return this.toPaddedString(2, 16); }, succ: function() { return this + 1; }, times: function(iterator) { $R(0, this, true).each(iterator); return this; }, toPaddedString: function(length, radix) { var string = this.toString(radix || 10); return '0'.times(length - string.length) + string; }, toJSON: function() { return isFinite(this) ? this.toString() : 'null'; }});$w('abs round ceil floor').each(function(method){ Number.prototype[method] = Math[method].methodize();});function $H(object) { return new Hash(object);};var Hash = Class.create(Enumerable, (function() { function toQueryPair(key, value) { if (Object.isUndefined(value)) return key; return key + '=' + encodeURIComponent(String.interpret(value)); } return { initialize: function(object) { this._object = Object.isHash(object) ? object.toObject() : Object.clone(object); }, _each: function(iterator) { for (var key in this._object) { var value = this._object[key], pair = [key, value]; pair.key = key; pair.value = value; iterator(pair); } }, set: function(key, value) { return this._object[key] = value; }, get: function(key) { return this._object[key]; }, unset: function(key) { var value = this._object[key]; delete this._object[key]; return value; }, toObject: function() { return Object.clone(this._object); }, keys: function() { return this.pluck('key'); }, values: function() { return this.pluck('value'); }, index: function(value) { var match = this.detect(function(pair) { return pair.value === value; }); return match && match.key; }, merge: function(object) { return this.clone().update(object); }, update: function(object) { return new Hash(object).inject(this, function(result, pair) { result.set(pair.key, pair.value); return result; }); }, toQueryString: function() { return this.map(function(pair) { var key = encodeURIComponent(pair.key), values = pair.value; if (values && typeof values == 'object') { if (Object.isArray(values)) return values.map(toQueryPair.curry(key)).join('&'); } return toQueryPair(key, values); }).join('&'); }, inspect: function() { return '#<Hash:{' + this.map(function(pair) { return pair.map(Object.inspect).join(': '); }).join(', ') + '}>'; }, toJSON: function() { return Object.toJSON(this.toObject()); }, clone: function() { return new Hash(this); } }})());Hash.prototype.toTemplateReplacements = Hash.prototype.toObject;Hash.from = $H;var ObjectRange = Class.create(Enumerable, { initialize: function(start, end, exclusive) { this.start = start; this.end = end; this.exclusive = exclusive; }, _each: function(iterator) { var value = this.start; while (this.include(value)) { iterator(value); value = value.succ(); } }, include: function(value) { if (value < this.start) return false; if (this.exclusive) return value < this.end; return value <= this.end; }});var $R = function(start, end, exclusive) { return new ObjectRange(start, end, exclusive);};var Ajax = { getTransport: function() { return Try.these(
 function() {return new XMLHttpRequest()}, function() {return new ActiveXObject('Msxml2.XMLHTTP')}, function() {return new ActiveXObject('Microsoft.XMLHTTP')} ) || false; }, activeRequestCount: 0
};Ajax.Responders = { responders: [], _each: function(iterator) { this.responders._each(iterator); }, register: function(responder) { if (!this.include(responder)) this.responders.push(responder); }, unregister: function(responder) { this.responders = this.responders.without(responder); }, dispatch: function(callback, request, transport, json) { this.each(function(responder) { if (Object.isFunction(responder[callback])) { try { responder[callback].apply(responder, [request, transport, json]); } catch (e) { } } }); }};Object.extend(Ajax.Responders, Enumerable);Ajax.Responders.register({ onCreate: function() { Ajax.activeRequestCount++ }, onComplete: function() { Ajax.activeRequestCount-- }});Ajax.Base = Class.create({ initialize: function(options) { this.options = { method: 'post', asynchronous: true, contentType: 'application/x-www-form-urlencoded', encoding: 'UTF-8', parameters: '', evalJSON: true, evalJS: true
 }; Object.extend(this.options, options || { }); this.options.method = this.options.method.toLowerCase(); if (Object.isString(this.options.parameters)) this.options.parameters = this.options.parameters.toQueryParams(); else if (Object.isHash(this.options.parameters)) this.options.parameters = this.options.parameters.toObject(); }});Ajax.Request = Class.create(Ajax.Base, { _complete: false, initialize: function($super, url, options) { $super(options); this.transport = Ajax.getTransport(); this.request(url); }, request: function(url) { this.url = url; this.method = this.options.method; var params = Object.clone(this.options.parameters); if (!['get', 'post'].include(this.method)) { params['_method'] = this.method; this.method = 'post'; } this.parameters = params; if (params = Object.toQueryString(params)) { if (this.method == 'get') this.url += (this.url.include('?') ? '&' : '?') + params; else if (/Konqueror|Safari|KHTML/.test(navigator.userAgent)) params += '&_='; } try { var response = new Ajax.Response(this); if (this.options.onCreate) this.options.onCreate(response); Ajax.Responders.dispatch('onCreate', this, response); this.transport.open(this.method.toUpperCase(), this.url, this.options.asynchronous); if (this.options.asynchronous) this.respondToReadyState.bind(this).defer(1); this.transport.onreadystatechange = this.onStateChange.bind(this); this.setRequestHeaders(); this.body = this.method == 'post' ? (this.options.postBody || params) : null; this.transport.send(this.body); if (!this.options.asynchronous && this.transport.overrideMimeType) this.onStateChange(); } catch (e) { this.dispatchException(e); } }, onStateChange: function() { var readyState = this.transport.readyState; if (readyState > 1 && !((readyState == 4) && this._complete)) this.respondToReadyState(this.transport.readyState); }, setRequestHeaders: function() { var headers = { 'X-Requested-With': 'XMLHttpRequest', 'X-Prototype-Version': Prototype.Version, 'Accept': 'text/javascript, text/html, application/xml, text/xml, */*'
 }; if (this.method == 'post') { headers['Content-type'] = this.options.contentType +
 (this.options.encoding ? '; charset=' + this.options.encoding : ''); /* Force "Connection: close" for older Mozilla browsers to work
 * around a bug where XMLHttpRequest sends an incorrect
 * Content-length header. See Mozilla Bugzilla #246651.
 */
 if (this.transport.overrideMimeType &&
 (navigator.userAgent.match(/Gecko\/(\d{4})/) || [0,2005])[1] < 2005) headers['Connection'] = 'close'; } if (typeof this.options.requestHeaders == 'object') { var extras = this.options.requestHeaders; if (Object.isFunction(extras.push)) for (var i = 0, length = extras.length; i < length; i += 2) headers[extras[i]] = extras[i+1]; else
 $H(extras).each(function(pair) { headers[pair.key] = pair.value }); } for (var name in headers) this.transport.setRequestHeader(name, headers[name]); }, success: function() { var status = this.getStatus(); return !status || (status >= 200 && status < 300); }, getStatus: function() { try { return this.transport.status || 0; } catch (e) { return 0 } }, respondToReadyState: function(readyState) { var state = Ajax.Request.Events[readyState], response = new Ajax.Response(this); if (state == 'Complete') { try { this._complete = true; (this.options['on' + response.status]
 || this.options['on' + (this.success() ? 'Success' : 'Failure')]
 || Prototype.emptyFunction)(response, response.headerJSON); } catch (e) { this.dispatchException(e); } var contentType = response.getHeader('Content-type'); if (this.options.evalJS == 'force'
 || (this.options.evalJS && this.isSameOrigin() && contentType
 && contentType.match(/^\s*(text|application)\/(x-)?(java|ecma)script(;.*)?\s*$/i))) this.evalResponse(); } try { (this.options['on' + state] || Prototype.emptyFunction)(response, response.headerJSON); Ajax.Responders.dispatch('on' + state, this, response, response.headerJSON); } catch (e) { this.dispatchException(e); } if (state == 'Complete') { this.transport.onreadystatechange = Prototype.emptyFunction; } }, isSameOrigin: function() { var m = this.url.match(/^\s*https?:\/\/[^\/]*/); return !m || (m[0] == '#{protocol}//#{domain}#{port}'.interpolate({ protocol: location.protocol, domain: document.domain, port: location.port ? ':' + location.port : ''
 })); }, getHeader: function(name) { try { return this.transport.getResponseHeader(name) || null; } catch (e) { return null } }, evalResponse: function() { try { return eval((this.transport.responseText || '').unfilterJSON()); } catch (e) { this.dispatchException(e); } }, dispatchException: function(exception) { (this.options.onException || Prototype.emptyFunction)(this, exception); Ajax.Responders.dispatch('onException', this, exception); }});Ajax.Request.Events =
 ['Uninitialized', 'Loading', 'Loaded', 'Interactive', 'Complete'];Ajax.Response = Class.create({ initialize: function(request){ this.request = request; var transport = this.transport = request.transport, readyState = this.readyState = transport.readyState; if((readyState > 2 && !Prototype.Browser.IE) || readyState == 4) { this.status = this.getStatus(); this.statusText = this.getStatusText(); this.responseText = String.interpret(transport.responseText); this.headerJSON = this._getHeaderJSON(); } if(readyState == 4) { var xml = transport.responseXML; this.responseXML = Object.isUndefined(xml) ? null : xml; this.responseJSON = this._getResponseJSON(); } }, status: 0, statusText: '', getStatus: Ajax.Request.prototype.getStatus, getStatusText: function() { try { return this.transport.statusText || ''; } catch (e) { return '' } }, getHeader: Ajax.Request.prototype.getHeader, getAllHeaders: function() { try { return this.getAllResponseHeaders(); } catch (e) { return null } }, getResponseHeader: function(name) { return this.transport.getResponseHeader(name); }, getAllResponseHeaders: function() { return this.transport.getAllResponseHeaders(); }, _getHeaderJSON: function() { var json = this.getHeader('X-JSON'); if (!json) return null; json = decodeURIComponent(escape(json)); try { return json.evalJSON(this.request.options.sanitizeJSON ||
 !this.request.isSameOrigin()); } catch (e) { this.request.dispatchException(e); } }, _getResponseJSON: function() { var options = this.request.options; if (!options.evalJSON || (options.evalJSON != 'force' &&
 !(this.getHeader('Content-type') || '').include('application/json')) ||
 this.responseText.blank()) return null; try { return this.responseText.evalJSON(options.sanitizeJSON ||
 !this.request.isSameOrigin()); } catch (e) { this.request.dispatchException(e); } }});Ajax.Updater = Class.create(Ajax.Request, { initialize: function($super, container, url, options) { this.container = { success: (container.success || container), failure: (container.failure || (container.success ? null : container)) }; options = Object.clone(options); var onComplete = options.onComplete; options.onComplete = (function(response, json) { this.updateContent(response.responseText.replace(/&lt;/g,'<').replace(/&gt;/g,'>')); if (Object.isFunction(onComplete)) onComplete(response, json); }).bind(this); $super(url, options); }, updateContent: function(responseText) { var receiver = this.container[this.success() ? 'success' : 'failure'], options = this.options; if (!options.evalScripts) responseText = responseText.stripScripts(); if (receiver = $(receiver)) { if (options.insertion) { if (Object.isString(options.insertion)) { var insertion = { }; insertion[options.insertion] = responseText; receiver.insert(insertion); } else options.insertion(receiver, responseText); } else receiver.update(responseText); } }});Ajax.PeriodicalUpdater = Class.create(Ajax.Base, { initialize: function($super, container, url, options) { $super(options); this.onComplete = this.options.onComplete; this.frequency = (this.options.frequency || 2); this.decay = (this.options.decay || 1); this.updater = { }; this.container = container; this.url = url; this.start(); }, start: function() { this.options.onComplete = this.updateComplete.bind(this); this.onTimerEvent(); }, stop: function() { this.updater.options.onComplete = undefined; clearTimeout(this.timer); (this.onComplete || Prototype.emptyFunction).apply(this, arguments); }, updateComplete: function(response) { if (this.options.decay) { this.decay = (response.responseText == this.lastText ?
 this.decay * this.options.decay : 1); this.lastText = response.responseText; } this.timer = this.onTimerEvent.bind(this).delay(this.decay * this.frequency); }, onTimerEvent: function() { this.updater = new Ajax.Updater(this.container, this.url, this.options); }});function $(element) { if (arguments.length > 1) { for (var i = 0, elements = [], length = arguments.length; i < length; i++) elements.push($(arguments[i])); return elements; } if (Object.isString(element)) element = document.getElementById(element); return Element.extend(element);}if (Prototype.BrowserFeatures.XPath) { document._getElementsByXPath = function(expression, parentElement) { var results = []; var query = document.evaluate(expression, $(parentElement) || document, null, XPathResult.ORDERED_NODE_SNAPSHOT_TYPE, null); for (var i = 0, length = query.snapshotLength; i < length; i++) results.push(Element.extend(query.snapshotItem(i))); return results; };}if (!window.Node) var Node = { };if (!Node.ELEMENT_NODE) { Object.extend(Node, { ELEMENT_NODE: 1, ATTRIBUTE_NODE: 2, TEXT_NODE: 3, CDATA_SECTION_NODE: 4, ENTITY_REFERENCE_NODE: 5, ENTITY_NODE: 6, PROCESSING_INSTRUCTION_NODE: 7, COMMENT_NODE: 8, DOCUMENT_NODE: 9, DOCUMENT_TYPE_NODE: 10, DOCUMENT_FRAGMENT_NODE: 11, NOTATION_NODE: 12
 });}(function() { var element = this.Element; this.Element = function(tagName, attributes) { attributes = attributes || { }; tagName = tagName.toLowerCase(); var cache = Element.cache; if (Prototype.Browser.IE && attributes.name) { tagName = '<' + tagName + ' name="' + attributes.name + '">'; delete attributes.name; return Element.writeAttribute(document.createElement(tagName), attributes); } if (!cache[tagName]) cache[tagName] = Element.extend(document.createElement(tagName)); return Element.writeAttribute(cache[tagName].cloneNode(false), attributes); }; Object.extend(this.Element, element || { });}).call(window);Element.cache = { };Element.Methods = { visible: function(element) { return $(element).style.display != 'none'; }, toggle: function(element) { element = $(element); Element[Element.visible(element) ? 'hide' : 'show'](element); return element; }, hide: function(element) { $(element).style.display = 'none'; return element; }, show: function(element) { $(element).style.display = ''; return element; }, remove: function(element) { element = $(element); element.parentNode.removeChild(element); return element; }, update: function(element, content) { element = $(element); if (content && content.toElement) content = content.toElement(); if (Object.isElement(content)) return element.update().insert(content); content = Object.toHTML(content); element.innerHTML = content.stripScripts(); content.evalScripts.bind(content).defer(); return element; }, replace: function(element, content) { element = $(element); if (content && content.toElement) content = content.toElement(); else if (!Object.isElement(content)) { content = Object.toHTML(content); var range = element.ownerDocument.createRange(); range.selectNode(element); content.evalScripts.bind(content).defer(); content = range.createContextualFragment(content.stripScripts()); } element.parentNode.replaceChild(content, element); return element; }, insert: function(element, insertions) { element = $(element); if (Object.isString(insertions) || Object.isNumber(insertions) ||
 Object.isElement(insertions) || (insertions && (insertions.toElement || insertions.toHTML))) insertions = {bottom:insertions}; var content, insert, tagName, childNodes; for (var position in insertions) { content = insertions[position]; position = position.toLowerCase(); insert = Element._insertionTranslations[position]; if (content && content.toElement) content = content.toElement(); if (Object.isElement(content)) { insert(element, content); continue; } content = Object.toHTML(content); tagName = ((position == 'before' || position == 'after') ? element.parentNode : element).tagName.toUpperCase(); childNodes = Element._getContentFromAnonymousElement(tagName, content.stripScripts()); if (position == 'top' || position == 'after') childNodes.reverse(); childNodes.each(insert.curry(element)); content.evalScripts.bind(content).defer(); } return element; }, wrap: function(element, wrapper, attributes) { element = $(element); if (Object.isElement(wrapper)) $(wrapper).writeAttribute(attributes || { }); else if (Object.isString(wrapper)) wrapper = new Element(wrapper, attributes); else wrapper = new Element('div', wrapper); if (element.parentNode) element.parentNode.replaceChild(wrapper, element); wrapper.appendChild(element); return wrapper; }, inspect: function(element) { element = $(element); var result = '<' + element.tagName.toLowerCase(); $H({'id': 'id', 'className': 'class'}).each(function(pair) { var property = pair.first(), attribute = pair.last(); var value = (element[property] || '').toString(); if (value) result += ' ' + attribute + '=' + value.inspect(true); }); return result + '>'; }, recursivelyCollect: function(element, property) { element = $(element); var elements = []; while (element = element[property]) if (element.nodeType == 1) elements.push(Element.extend(element)); return elements; }, ancestors: function(element) { return $(element).recursivelyCollect('parentNode'); }, descendants: function(element) { return $(element).select("*"); }, firstDescendant: function(element) { element = $(element).firstChild; while (element && element.nodeType != 1) element = element.nextSibling; return $(element); }, immediateDescendants: function(element) { if (!(element = $(element).firstChild)) return []; while (element && element.nodeType != 1) element = element.nextSibling; if (element) return [element].concat($(element).nextSiblings()); return []; }, previousSiblings: function(element) { return $(element).recursivelyCollect('previousSibling'); }, nextSiblings: function(element) { return $(element).recursivelyCollect('nextSibling'); }, siblings: function(element) { element = $(element); return element.previousSiblings().reverse().concat(element.nextSiblings()); }, match: function(element, selector) { if (Object.isString(selector)) selector = new Selector(selector); return selector.match($(element)); }, up: function(element, expression, index) { element = $(element); if (arguments.length == 1) return $(element.parentNode); var ancestors = element.ancestors(); return Object.isNumber(expression) ? ancestors[expression] :
 Selector.findElement(ancestors, expression, index); }, down: function(element, expression, index) { element = $(element); if (arguments.length == 1) return element.firstDescendant(); return Object.isNumber(expression) ? element.descendants()[expression] :
 element.select(expression)[index || 0]; }, previous: function(element, expression, index) { element = $(element); if (arguments.length == 1) return $(Selector.handlers.previousElementSibling(element)); var previousSiblings = element.previousSiblings(); return Object.isNumber(expression) ? previousSiblings[expression] :
 Selector.findElement(previousSiblings, expression, index); }, next: function(element, expression, index) { element = $(element); if (arguments.length == 1) return $(Selector.handlers.nextElementSibling(element)); var nextSiblings = element.nextSiblings(); return Object.isNumber(expression) ? nextSiblings[expression] :
 Selector.findElement(nextSiblings, expression, index); }, select: function() { var args = $A(arguments), element = $(args.shift()); return Selector.findChildElements(element, args); }, adjacent: function() { var args = $A(arguments), element = $(args.shift()); return Selector.findChildElements(element.parentNode, args).without(element); }, identify: function(element) { element = $(element); var id = element.readAttribute('id'), self = arguments.callee; if (id) return id; do { id = 'anonymous_element_' + self.counter++ } while ($(id)); element.writeAttribute('id', id); return id; }, readAttribute: function(element, name) { element = $(element); if (Prototype.Browser.IE) { var t = Element._attributeTranslations.read; if (t.values[name]) return t.values[name](element, name); if (t.names[name]) name = t.names[name]; if (name.include(':')) { return (!element.attributes || !element.attributes[name]) ? null :
 element.attributes[name].value; } } return element.getAttribute(name); }, writeAttribute: function(element, name, value) { element = $(element); var attributes = { }, t = Element._attributeTranslations.write; if (typeof name == 'object') attributes = name; else attributes[name] = Object.isUndefined(value) ? true : value; for (var attr in attributes) { name = t.names[attr] || attr; value = attributes[attr]; if (t.values[attr]) name = t.values[attr](element, value); if (value === false || value === null) element.removeAttribute(name); else if (value === true) element.setAttribute(name, name); else element.setAttribute(name, value); } return element; }, getHeight: function(element) { return $(element).getDimensions().height; }, getWidth: function(element) { return $(element).getDimensions().width; }, classNames: function(element) { return new Element.ClassNames(element); }, hasClassName: function(element, className) { if (!(element = $(element))) return; var elementClassName = element.className; return (elementClassName.length > 0 && (elementClassName == className ||
 new RegExp("(^|\\s)" + className + "(\\s|$)").test(elementClassName))); }, addClassName: function(element, className) { if (!(element = $(element))) return; if (!element.hasClassName(className)) element.className += (element.className ? ' ' : '') + className; return element; }, removeClassName: function(element, className) { if (!(element = $(element))) return; element.className = element.className.replace(
 new RegExp("(^|\\s+)" + className + "(\\s+|$)"), ' ').strip(); return element; }, toggleClassName: function(element, className) { if (!(element = $(element))) return; return element[element.hasClassName(className) ?
 'removeClassName' : 'addClassName'](className); }, cleanWhitespace: function(element) { element = $(element); var node = element.firstChild; while (node) { var nextNode = node.nextSibling; if (node.nodeType == 3 && !/\S/.test(node.nodeValue)) element.removeChild(node); node = nextNode; } return element; }, empty: function(element) { return $(element).innerHTML.blank(); }, descendantOf: function(element, ancestor) { element = $(element), ancestor = $(ancestor); var originalAncestor = ancestor; if (element.compareDocumentPosition) return (element.compareDocumentPosition(ancestor) & 8) === 8; if (element.sourceIndex && !Prototype.Browser.Opera) { var e = element.sourceIndex, a = ancestor.sourceIndex, nextAncestor = ancestor.nextSibling; if (!nextAncestor) { do { ancestor = ancestor.parentNode; } while (!(nextAncestor = ancestor.nextSibling) && ancestor.parentNode); } if (nextAncestor && nextAncestor.sourceIndex) return (e > a && e < nextAncestor.sourceIndex); } while (element = element.parentNode) if (element == originalAncestor) return true; return false; }, scrollTo: function(element) { element = $(element); var pos = element.cumulativeOffset(); window.scrollTo(pos[0], pos[1]); return element; }, getStyle: function(element, style) { element = $(element); style = style == 'float' ? 'cssFloat' : style.camelize(); var value = element.style[style]; if (!value) { var css = document.defaultView.getComputedStyle(element, null); value = css ? css[style] : null; } if (style == 'opacity') return value ? parseFloat(value) : 1.0; return value == 'auto' ? null : value; }, getOpacity: function(element) { return $(element).getStyle('opacity'); }, setStyle: function(element, styles) { element = $(element); var elementStyle = element.style, match; if (Object.isString(styles)) { element.style.cssText += ';' + styles; return styles.include('opacity') ?
 element.setOpacity(styles.match(/opacity:\s*(\d?\.?\d*)/)[1]) : element; } for (var property in styles) if (property == 'opacity') element.setOpacity(styles[property]); else
 elementStyle[(property == 'float' || property == 'cssFloat') ?
 (Object.isUndefined(elementStyle.styleFloat) ? 'cssFloat' : 'styleFloat') :
 property] = styles[property]; return element; }, setOpacity: function(element, value) { element = $(element); element.style.opacity = (value == 1 || value === '') ? '' :
 (value < 0.00001) ? 0 : value; return element; }, getDimensions: function(element) { element = $(element); var display = $(element).getStyle('display'); if (display != 'none' && display != null) 
 return {width: element.offsetWidth, height: element.offsetHeight}; var els = element.style; var originalVisibility = els.visibility; var originalPosition = els.position; var originalDisplay = els.display; els.visibility = 'hidden'; els.position = 'absolute'; els.display = 'block'; var originalWidth = element.clientWidth; var originalHeight = element.clientHeight; els.display = originalDisplay; els.position = originalPosition; els.visibility = originalVisibility; return {width: originalWidth, height: originalHeight}; }, makePositioned: function(element) { element = $(element); var pos = Element.getStyle(element, 'position'); if (pos == 'static' || !pos) { element._madePositioned = true; element.style.position = 'relative'; if (window.opera) { element.style.top = 0; element.style.left = 0; } } return element; }, undoPositioned: function(element) { element = $(element); if (element._madePositioned) { element._madePositioned = undefined; element.style.position =
 element.style.top =
 element.style.left =
 element.style.bottom =
 element.style.right = ''; } return element; }, makeClipping: function(element) { element = $(element); if (element._overflow) return element; element._overflow = Element.getStyle(element, 'overflow') || 'auto'; if (element._overflow !== 'hidden') element.style.overflow = 'hidden'; return element; }, undoClipping: function(element) { element = $(element); if (!element._overflow) return element; element.style.overflow = element._overflow == 'auto' ? '' : element._overflow; element._overflow = null; return element; }, cumulativeOffset: function(element) { var valueT = 0, valueL = 0; do { valueT += element.offsetTop || 0; valueL += element.offsetLeft || 0; element = element.offsetParent; } while (element); return Element._returnOffset(valueL, valueT); }, positionedOffset: function(element) { var valueT = 0, valueL = 0; do { valueT += element.offsetTop || 0; valueL += element.offsetLeft || 0; element = element.offsetParent; if (element) { if (element.tagName == 'BODY') break; var p = Element.getStyle(element, 'position'); if (p !== 'static') break; } } while (element); return Element._returnOffset(valueL, valueT); }, absolutize: function(element) { element = $(element); if (element.getStyle('position') == 'absolute') return; var offsets = element.positionedOffset(); var top = offsets[1]; var left = offsets[0]; var width = element.clientWidth; var height = element.clientHeight; element._originalLeft = left - parseFloat(element.style.left || 0); element._originalTop = top - parseFloat(element.style.top || 0); element._originalWidth = element.style.width; element._originalHeight = element.style.height; element.style.position = 'absolute'; element.style.top = top + 'px'; element.style.left = left + 'px'; element.style.width = width + 'px'; element.style.height = height + 'px'; return element; }, relativize: function(element) { element = $(element); if (element.getStyle('position') == 'relative') return; element.style.position = 'relative'; var top = parseFloat(element.style.top || 0) - (element._originalTop || 0); var left = parseFloat(element.style.left || 0) - (element._originalLeft || 0); element.style.top = top + 'px'; element.style.left = left + 'px'; element.style.height = element._originalHeight; element.style.width = element._originalWidth; return element; }, cumulativeScrollOffset: function(element) { var valueT = 0, valueL = 0; do { valueT += element.scrollTop || 0; valueL += element.scrollLeft || 0; element = element.parentNode; } while (element); return Element._returnOffset(valueL, valueT); }, getOffsetParent: function(element) { if (element.offsetParent) return $(element.offsetParent); if (element == document.body) return $(element); while ((element = element.parentNode) && element != document.body) if (Element.getStyle(element, 'position') != 'static') return $(element); return $(document.body); }, viewportOffset: function(forElement) { var valueT = 0, valueL = 0; var element = forElement; do { valueT += element.offsetTop || 0; valueL += element.offsetLeft || 0; if (element.offsetParent == document.body &&
 Element.getStyle(element, 'position') == 'absolute') break; } while (element = element.offsetParent); element = forElement; do { if (!Prototype.Browser.Opera || element.tagName == 'BODY') { valueT -= element.scrollTop || 0; valueL -= element.scrollLeft || 0; } } while (element = element.parentNode); return Element._returnOffset(valueL, valueT); }, clonePosition: function(element, source) { var options = Object.extend({ setLeft: true, setTop: true, setWidth: true, setHeight: true, offsetTop: 0, offsetLeft: 0
 }, arguments[2] || { }); source = $(source); var p = source.viewportOffset(); element = $(element); var delta = [0, 0]; var parent = null; if (Element.getStyle(element, 'position') == 'absolute') { parent = element.getOffsetParent(); delta = parent.viewportOffset(); } if (parent == document.body) { delta[0] -= document.body.offsetLeft; delta[1] -= document.body.offsetTop; } if (options.setLeft) element.style.left = (p[0] - delta[0] + options.offsetLeft) + 'px'; if (options.setTop) element.style.top = (p[1] - delta[1] + options.offsetTop) + 'px'; if (options.setWidth) element.style.width = source.offsetWidth + 'px'; if (options.setHeight) element.style.height = source.offsetHeight + 'px'; return element; }};Element.Methods.identify.counter = 1;Object.extend(Element.Methods, { getElementsBySelector: Element.Methods.select, childElements: Element.Methods.immediateDescendants
});Element._attributeTranslations = { write: { names: { className: 'class', htmlFor: 'for'
 }, values: { } }};if (Prototype.Browser.Opera) { Element.Methods.getStyle = Element.Methods.getStyle.wrap(
 function(proceed, element, style) { switch (style) { case 'left': case 'top': case 'right': case 'bottom':
 if (proceed(element, 'position') === 'static') return null; case 'height': case 'width':
 if (!Element.visible(element)) return null; var dim = parseInt(proceed(element, style), 10); if (dim !== element['offset' + style.capitalize()]) return dim + 'px'; var properties; if (style === 'height') { properties = ['border-top-width', 'padding-top', 'padding-bottom', 'border-bottom-width']; } else { properties = ['border-left-width', 'padding-left', 'padding-right', 'border-right-width']; } return properties.inject(dim, function(memo, property) { var val = proceed(element, property); return val === null ? memo : memo - parseInt(val, 10); }) + 'px'; default: return proceed(element, style); } } ); Element.Methods.readAttribute = Element.Methods.readAttribute.wrap(
 function(proceed, element, attribute) { if (attribute === 'title') return element.title; return proceed(element, attribute); } );}else if (Prototype.Browser.IE) { Element.Methods.getOffsetParent = Element.Methods.getOffsetParent.wrap(
 function(proceed, element) { element = $(element); var position = element.getStyle('position'); if (position !== 'static') return proceed(element); element.setStyle({ position: 'relative' }); var value = proceed(element); element.setStyle({ position: position }); return value; } ); $w('positionedOffset viewportOffset').each(function(method) { Element.Methods[method] = Element.Methods[method].wrap(
 function(proceed, element) { element = $(element); var position = element.getStyle('position'); if (position !== 'static') return proceed(element); var offsetParent = element.getOffsetParent(); if (offsetParent && offsetParent.getStyle('position') === 'fixed') offsetParent.setStyle({ zoom: 1 }); element.setStyle({ position: 'relative' }); var value = proceed(element); element.setStyle({ position: position }); return value; } ); }); Element.Methods.getStyle = function(element, style) { element = $(element); style = (style == 'float' || style == 'cssFloat') ? 'styleFloat' : style.camelize(); var value = element.style[style]; if (!value && element.currentStyle) value = element.currentStyle[style]; if (style == 'opacity') { if (value = (element.getStyle('filter') || '').match(/alpha\(opacity=(.*)\)/)) if (value[1]) return parseFloat(value[1]) / 100; return 1.0; } if (value == 'auto') { if ((style == 'width' || style == 'height') && (element.getStyle('display') != 'none')) return element['offset' + style.capitalize()] + 'px'; return null; } return value; }; Element.Methods.setOpacity = function(element, value) { function stripAlpha(filter){ return filter.replace(/alpha\([^\)]*\)/gi,''); } element = $(element); var currentStyle = element.currentStyle; if ((currentStyle && !currentStyle.hasLayout) ||
 (!currentStyle && element.style.zoom == 'normal')) element.style.zoom = 1; var filter = element.getStyle('filter'), style = element.style; if (value == 1 || value === '') { (filter = stripAlpha(filter)) ?
 style.filter = filter : style.removeAttribute('filter'); return element; } else if (value < 0.00001) value = 0; style.filter = stripAlpha(filter) +
 'alpha(opacity=' + (value * 100) + ')'; return element; }; Element._attributeTranslations = { read: { names: { 'class': 'className', 'for': 'htmlFor'
 }, values: { _getAttr: function(element, attribute) { return element.getAttribute(attribute, 2); }, _getAttrNode: function(element, attribute) { var node = element.getAttributeNode(attribute); return node ? node.value : ""; }, _getEv: function(element, attribute) { attribute = element.getAttribute(attribute); return attribute ? attribute.toString().slice(23, -2) : null; }, _flag: function(element, attribute) { return $(element).hasAttribute(attribute) ? attribute : null; }, style: function(element) { return element.style.cssText.toLowerCase(); }, title: function(element) { return element.title; } } } }; Element._attributeTranslations.write = { names: Object.extend({ cellpadding: 'cellPadding', cellspacing: 'cellSpacing'
 }, Element._attributeTranslations.read.names), values: { checked: function(element, value) { element.checked = !!value; }, style: function(element, value) { element.style.cssText = value ? value : ''; } } }; Element._attributeTranslations.has = {}; $w('colSpan rowSpan vAlign dateTime accessKey tabIndex ' +
 'encType maxLength readOnly longDesc').each(function(attr) { Element._attributeTranslations.write.names[attr.toLowerCase()] = attr; Element._attributeTranslations.has[attr.toLowerCase()] = attr; }); (function(v) { Object.extend(v, { href: v._getAttr, src: v._getAttr, type: v._getAttr, action: v._getAttrNode, disabled: v._flag, checked: v._flag, readonly: v._flag, multiple: v._flag, onload: v._getEv, onunload: v._getEv, onclick: v._getEv, ondblclick: v._getEv, onmousedown: v._getEv, onmouseup: v._getEv, onmouseover: v._getEv, onmousemove: v._getEv, onmouseout: v._getEv, onfocus: v._getEv, onblur: v._getEv, onkeypress: v._getEv, onkeydown: v._getEv, onkeyup: v._getEv, onsubmit: v._getEv, onreset: v._getEv, onselect: v._getEv, onchange: v._getEv
 }); })(Element._attributeTranslations.read.values);}else if (Prototype.Browser.Gecko && /rv:1\.8\.0/.test(navigator.userAgent)) { Element.Methods.setOpacity = function(element, value) { element = $(element); element.style.opacity = (value == 1) ? 0.999999 :
 (value === '') ? '' : (value < 0.00001) ? 0 : value; return element; };}else if (Prototype.Browser.WebKit) { Element.Methods.setOpacity = function(element, value) { element = $(element); element.style.opacity = (value == 1 || value === '') ? '' :
 (value < 0.00001) ? 0 : value; if (value == 1) if(element.tagName == 'IMG' && element.width) { element.width++; element.width--; } else try { var n = document.createTextNode(' '); element.appendChild(n); element.removeChild(n); } catch (e) { } return element; }; Element.Methods.cumulativeOffset = function(element) { var valueT = 0, valueL = 0; do { valueT += element.offsetTop || 0; valueL += element.offsetLeft || 0; if (element.offsetParent == document.body) if (Element.getStyle(element, 'position') == 'absolute') break; element = element.offsetParent; } while (element); return Element._returnOffset(valueL, valueT); };}if (Prototype.Browser.IE || Prototype.Browser.Opera) { Element.Methods.update = function(element, content) { element = $(element); if (content && content.toElement) content = content.toElement(); if (Object.isElement(content)) return element.update().insert(content); content = Object.toHTML(content); var tagName = element.tagName.toUpperCase(); if (tagName in Element._insertionTranslations.tags) { $A(element.childNodes).each(function(node) { element.removeChild(node) }); Element._getContentFromAnonymousElement(tagName, content.stripScripts()) .each(function(node) { element.appendChild(node) }); } else element.innerHTML = content.stripScripts(); content.evalScripts.bind(content).defer(); return element; };}if ('outerHTML' in document.createElement('div')) { Element.Methods.replace = function(element, content) { element = $(element); if (content && content.toElement) content = content.toElement(); if (Object.isElement(content)) { element.parentNode.replaceChild(content, element); return element; } content = Object.toHTML(content); var parent = element.parentNode, tagName = parent.tagName.toUpperCase(); if (Element._insertionTranslations.tags[tagName]) { var nextSibling = element.next(); var fragments = Element._getContentFromAnonymousElement(tagName, content.stripScripts()); parent.removeChild(element); if (nextSibling) fragments.each(function(node) { parent.insertBefore(node, nextSibling) }); else
 fragments.each(function(node) { parent.appendChild(node) }); } else element.outerHTML = content.stripScripts(); content.evalScripts.bind(content).defer(); return element; };}Element._returnOffset = function(l, t) { var result = [l, t]; result.left = l; result.top = t; return result;};Element._getContentFromAnonymousElement = function(tagName, html) { var div = new Element('div'), t = Element._insertionTranslations.tags[tagName]; if (t) { div.innerHTML = t[0] + html + t[1]; t[2].times(function() { div = div.firstChild }); } else div.innerHTML = html; return $A(div.childNodes);};Element._insertionTranslations = { before: function(element, node) { element.parentNode.insertBefore(node, element); }, top: function(element, node) { element.insertBefore(node, element.firstChild); }, bottom: function(element, node) { element.appendChild(node); }, after: function(element, node) { element.parentNode.insertBefore(node, element.nextSibling); }, tags: { TABLE: ['<table>', '</table>', 1], TBODY: ['<table><tbody>', '</tbody></table>', 2], TR: ['<table><tbody><tr>', '</tr></tbody></table>', 3], TD: ['<table><tbody><tr><td>', '</td></tr></tbody></table>', 4], SELECT: ['<select>', '</select>', 1]
 }};(function() { Object.extend(this.tags, { THEAD: this.tags.TBODY, TFOOT: this.tags.TBODY, TH: this.tags.TD
 });}).call(Element._insertionTranslations);Element.Methods.Simulated = { hasAttribute: function(element, attribute) { attribute = Element._attributeTranslations.has[attribute] || attribute; var node = $(element).getAttributeNode(attribute); return node && node.specified; }};Element.Methods.ByTag = { };Object.extend(Element, Element.Methods);if (!Prototype.BrowserFeatures.ElementExtensions &&
 document.createElement('div').__proto__) { window.HTMLElement = { }; window.HTMLElement.prototype = document.createElement('div').__proto__; Prototype.BrowserFeatures.ElementExtensions = true;}Element.extend = (function() { if (Prototype.BrowserFeatures.SpecificElementExtensions) return Prototype.K; var Methods = { }, ByTag = Element.Methods.ByTag; var extend = Object.extend(function(element) { if (!element || element._extendedByPrototype ||
 element.nodeType != 1 || element == window) return element; var methods = Object.clone(Methods), tagName = element.tagName, property, value; if (ByTag[tagName]) Object.extend(methods, ByTag[tagName]); for (property in methods) { value = methods[property]; if (Object.isFunction(value) && !(property in element)) element[property] = value.methodize(); } element._extendedByPrototype = Prototype.emptyFunction; return element; }, { refresh: function() { if (!Prototype.BrowserFeatures.ElementExtensions) { Object.extend(Methods, Element.Methods); Object.extend(Methods, Element.Methods.Simulated); } } }); extend.refresh(); return extend;})();Element.hasAttribute = function(element, attribute) { if (element.hasAttribute) return element.hasAttribute(attribute); return Element.Methods.Simulated.hasAttribute(element, attribute);};Element.addMethods = function(methods) { var F = Prototype.BrowserFeatures, T = Element.Methods.ByTag; if (!methods) { Object.extend(Form, Form.Methods); Object.extend(Form.Element, Form.Element.Methods); Object.extend(Element.Methods.ByTag, { "FORM": Object.clone(Form.Methods), "INPUT": Object.clone(Form.Element.Methods), "SELECT": Object.clone(Form.Element.Methods), "TEXTAREA": Object.clone(Form.Element.Methods) }); } if (arguments.length == 2) { var tagName = methods; methods = arguments[1]; } if (!tagName) Object.extend(Element.Methods, methods || { }); else { if (Object.isArray(tagName)) tagName.each(extend); else extend(tagName); } function extend(tagName) { tagName = tagName.toUpperCase(); if (!Element.Methods.ByTag[tagName]) Element.Methods.ByTag[tagName] = { }; Object.extend(Element.Methods.ByTag[tagName], methods); } function copy(methods, destination, onlyIfAbsent) { onlyIfAbsent = onlyIfAbsent || false; for (var property in methods) { var value = methods[property]; if (!Object.isFunction(value)) continue; if (!onlyIfAbsent || !(property in destination)) destination[property] = value.methodize(); } } function findDOMClass(tagName) { var klass; var trans = { "OPTGROUP": "OptGroup", "TEXTAREA": "TextArea", "P": "Paragraph", "FIELDSET": "FieldSet", "UL": "UList", "OL": "OList", "DL": "DList", "DIR": "Directory", "H1": "Heading", "H2": "Heading", "H3": "Heading", "H4": "Heading", "H5": "Heading", "H6": "Heading", "Q": "Quote", "INS": "Mod", "DEL": "Mod", "A": "Anchor", "IMG": "Image", "CAPTION":
 "TableCaption", "COL": "TableCol", "COLGROUP": "TableCol", "THEAD":
 "TableSection", "TFOOT": "TableSection", "TBODY": "TableSection", "TR":
 "TableRow", "TH": "TableCell", "TD": "TableCell", "FRAMESET":
 "FrameSet", "IFRAME": "IFrame"
 }; if (trans[tagName]) klass = 'HTML' + trans[tagName] + 'Element'; if (window[klass]) return window[klass]; klass = 'HTML' + tagName + 'Element'; if (window[klass]) return window[klass]; klass = 'HTML' + tagName.capitalize() + 'Element'; if (window[klass]) return window[klass]; window[klass] = { }; window[klass].prototype = document.createElement(tagName).__proto__; return window[klass]; } if (F.ElementExtensions) { copy(Element.Methods, HTMLElement.prototype); copy(Element.Methods.Simulated, HTMLElement.prototype, true); } if (F.SpecificElementExtensions) { for (var tag in Element.Methods.ByTag) { var klass = findDOMClass(tag); if (Object.isUndefined(klass)) continue; copy(T[tag], klass.prototype); } } Object.extend(Element, Element.Methods); delete Element.ByTag; if (Element.extend.refresh) Element.extend.refresh(); Element.cache = { };};document.viewport = { getDimensions: function() { var dimensions = { }; var B = Prototype.Browser; $w('width height').each(function(d) { var D = d.capitalize(); dimensions[d] = (B.WebKit && !document.evaluate) ? self['inner' + D] :
 (B.Opera) ? document.body['client' + D] : document.documentElement['client' + D]; }); return dimensions; }, getWidth: function() { return this.getDimensions().width; }, getHeight: function() { return this.getDimensions().height; }, getScrollOffsets: function() { return Element._returnOffset(
 window.pageXOffset || document.documentElement.scrollLeft || document.body.scrollLeft, window.pageYOffset || document.documentElement.scrollTop || document.body.scrollTop); }};/* Portions of the Selector class are derived from Jack Slocum�s DomQuery, * part of YUI-Ext version 0.40, distributed under the terms of an MIT-style
 * license. Please see http://www.yui-ext.com/ for more information. */
var Selector = Class.create({ initialize: function(expression) { this.expression = expression.strip(); this.compileMatcher(); }, shouldUseXPath: function() { if (!Prototype.BrowserFeatures.XPath) return false; var e = this.expression; if (Prototype.Browser.WebKit &&
 (e.include("-of-type") || e.include(":empty"))) return false; if ((/(\[[\w-]*?:|:checked)/).test(this.expression)) return false; return true; }, compileMatcher: function() { if (this.shouldUseXPath()) return this.compileXPathMatcher(); var e = this.expression, ps = Selector.patterns, h = Selector.handlers, c = Selector.criteria, le, p, m; if (Selector._cache[e]) { this.matcher = Selector._cache[e]; return; } this.matcher = ["this.matcher = function(root) {", "var r = root, h = Selector.handlers, c = false, n;"]; while (e && le != e && (/\S/).test(e)) { le = e; for (var i in ps) { p = ps[i]; if (m = e.match(p)) { this.matcher.push(Object.isFunction(c[i]) ? c[i](m) :
 new Template(c[i]).evaluate(m)); e = e.replace(m[0], ''); break; } } } this.matcher.push("return h.unique(n);\n}"); eval(this.matcher.join('\n')); Selector._cache[this.expression] = this.matcher; }, compileXPathMatcher: function() { var e = this.expression, ps = Selector.patterns, x = Selector.xpath, le, m; if (Selector._cache[e]) { this.xpath = Selector._cache[e]; return; } this.matcher = ['.//*']; while (e && le != e && (/\S/).test(e)) { le = e; for (var i in ps) { if (m = e.match(ps[i])) { this.matcher.push(Object.isFunction(x[i]) ? x[i](m) :
 new Template(x[i]).evaluate(m)); e = e.replace(m[0], ''); break; } } } this.xpath = this.matcher.join(''); Selector._cache[this.expression] = this.xpath; }, findElements: function(root) { root = root || document; if (this.xpath) return document._getElementsByXPath(this.xpath, root); return this.matcher(root); }, match: function(element) { this.tokens = []; var e = this.expression, ps = Selector.patterns, as = Selector.assertions; var le, p, m; while (e && le !== e && (/\S/).test(e)) { le = e; for (var i in ps) { p = ps[i]; if (m = e.match(p)) { if (as[i]) { this.tokens.push([i, Object.clone(m)]); e = e.replace(m[0], ''); } else { return this.findElements(document).include(element); } } } } var match = true, name, matches; for (var i = 0, token; token = this.tokens[i]; i++) { name = token[0], matches = token[1]; if (!Selector.assertions[name](element, matches)) { match = false; break; } } return match; }, toString: function() { return this.expression; }, inspect: function() { return "#<Selector:" + this.expression.inspect() + ">"; }});Object.extend(Selector, { _cache: { }, xpath: { descendant: "//*", child: "/*", adjacent: "/following-sibling::*[1]", laterSibling: '/following-sibling::*', tagName: function(m) { if (m[1] == '*') return ''; return "[local-name()='" + m[1].toLowerCase() +
 "' or local-name()='" + m[1].toUpperCase() + "']"; }, className: "[contains(concat(' ', @class, ' '), ' #{1} ')]", id: "[@id='#{1}']", attrPresence: function(m) { m[1] = m[1].toLowerCase(); return new Template("[@#{1}]").evaluate(m); }, attr: function(m) { m[1] = m[1].toLowerCase(); m[3] = m[5] || m[6]; return new Template(Selector.xpath.operators[m[2]]).evaluate(m); }, pseudo: function(m) { var h = Selector.xpath.pseudos[m[1]]; if (!h) return ''; if (Object.isFunction(h)) return h(m); return new Template(Selector.xpath.pseudos[m[1]]).evaluate(m); }, operators: { '=': "[@#{1}='#{3}']", '!=': "[@#{1}!='#{3}']", '^=': "[starts-with(@#{1}, '#{3}')]", '$=': "[substring(@#{1}, (string-length(@#{1}) - string-length('#{3}') + 1))='#{3}']", '*=': "[contains(@#{1}, '#{3}')]", '~=': "[contains(concat(' ', @#{1}, ' '), ' #{3} ')]", '|=': "[contains(concat('-', @#{1}, '-'), '-#{3}-')]"
 }, pseudos: { 'first-child': '[not(preceding-sibling::*)]', 'last-child': '[not(following-sibling::*)]', 'only-child': '[not(preceding-sibling::* or following-sibling::*)]', 'empty': "[count(*) = 0 and (count(text()) = 0 or translate(text(), ' \t\r\n', '') = '')]", 'checked': "[@checked]", 'disabled': "[@disabled]", 'enabled': "[not(@disabled)]", 'not': function(m) { var e = m[6], p = Selector.patterns, x = Selector.xpath, le, v; var exclusion = []; while (e && le != e && (/\S/).test(e)) { le = e; for (var i in p) { if (m = e.match(p[i])) { v = Object.isFunction(x[i]) ? x[i](m) : new Template(x[i]).evaluate(m); exclusion.push("(" + v.substring(1, v.length - 1) + ")"); e = e.replace(m[0], ''); break; } } } return "[not(" + exclusion.join(" and ") + ")]"; }, 'nth-child': function(m) { return Selector.xpath.pseudos.nth("(count(./preceding-sibling::*) + 1) ", m); }, 'nth-last-child': function(m) { return Selector.xpath.pseudos.nth("(count(./following-sibling::*) + 1) ", m); }, 'nth-of-type': function(m) { return Selector.xpath.pseudos.nth("position() ", m); }, 'nth-last-of-type': function(m) { return Selector.xpath.pseudos.nth("(last() + 1 - position()) ", m); }, 'first-of-type': function(m) { m[6] = "1"; return Selector.xpath.pseudos['nth-of-type'](m); }, 'last-of-type': function(m) { m[6] = "1"; return Selector.xpath.pseudos['nth-last-of-type'](m); }, 'only-of-type': function(m) { var p = Selector.xpath.pseudos; return p['first-of-type'](m) + p['last-of-type'](m); }, nth: function(fragment, m) { var mm, formula = m[6], predicate; if (formula == 'even') formula = '2n+0'; if (formula == 'odd') formula = '2n+1'; if (mm = formula.match(/^(\d+)$/)) 
 return '[' + fragment + "= " + mm[1] + ']'; if (mm = formula.match(/^(-?\d*)?n(([+-])(\d+))?/)) { 
 if (mm[1] == "-") mm[1] = -1; var a = mm[1] ? Number(mm[1]) : 1; var b = mm[2] ? Number(mm[2]) : 0; predicate = "[((#{fragment} - #{b}) mod #{a} = 0) and " +
 "((#{fragment} - #{b}) div #{a} >= 0)]"; return new Template(predicate).evaluate({ fragment: fragment, a: a, b: b }); } } } }, criteria: { tagName: 'n = h.tagName(n, r, "#{1}", c); c = false;', className: 'n = h.className(n, r, "#{1}", c); c = false;', id: 'n = h.id(n, r, "#{1}", c); c = false;', attrPresence: 'n = h.attrPresence(n, r, "#{1}", c); c = false;', attr: function(m) { m[3] = (m[5] || m[6]); return new Template('n = h.attr(n, r, "#{1}", "#{3}", "#{2}", c); c = false;').evaluate(m); }, pseudo: function(m) { if (m[6]) m[6] = m[6].replace(/"/g, '\\"'); return new Template('n = h.pseudo(n, "#{1}", "#{6}", r, c); c = false;').evaluate(m); }, descendant: 'c = "descendant";', child: 'c = "child";', adjacent: 'c = "adjacent";', laterSibling: 'c = "laterSibling";'
 }, patterns: { laterSibling: /^\s*~\s*/, child: /^\s*>\s*/, adjacent: /^\s*\+\s*/, descendant: /^\s/, tagName: /^\s*(\*|[\w\-]+)(\b|$)?/, id: /^#([\w\-\*]+)(\b|$)/, className: /^\.([\w\-\*]+)(\b|$)/, pseudo:
/^:((first|last|nth|nth-last|only)(-child|-of-type)|empty|checked|(en|dis)abled|not)(\((.*?)\))?(\b|$|(?=\s|[:+~>]))/, attrPresence: /^\[([\w]+)\]/, attr: /\[((?:[\w-]*:)?[\w-]+)\s*(?:([!^$*~|]?=)\s*((['"])([^\4]*?)\4|([^'"][^\]]*?)))?\]/
 }, assertions: { tagName: function(element, matches) { return matches[1].toUpperCase() == element.tagName.toUpperCase(); }, className: function(element, matches) { return Element.hasClassName(element, matches[1]); }, id: function(element, matches) { return element.id === matches[1]; }, attrPresence: function(element, matches) { return Element.hasAttribute(element, matches[1]); }, attr: function(element, matches) { var nodeValue = Element.readAttribute(element, matches[1]); return nodeValue && Selector.operators[matches[2]](nodeValue, matches[5] || matches[6]); } }, handlers: { concat: function(a, b) { for (var i = 0, node; node = b[i]; i++) a.push(node); return a; }, mark: function(nodes) { var _true = Prototype.emptyFunction; for (var i = 0, node; node = nodes[i]; i++) node._countedByPrototype = _true; return nodes; }, unmark: function(nodes) { for (var i = 0, node; node = nodes[i]; i++) node._countedByPrototype = undefined; return nodes; }, index: function(parentNode, reverse, ofType) { parentNode._countedByPrototype = Prototype.emptyFunction; if (reverse) { for (var nodes = parentNode.childNodes, i = nodes.length - 1, j = 1; i >= 0; i--) { var node = nodes[i]; if (node.nodeType == 1 && (!ofType || node._countedByPrototype)) node.nodeIndex = j++; } } else { for (var i = 0, j = 1, nodes = parentNode.childNodes; node = nodes[i]; i++) if (node.nodeType == 1 && (!ofType || node._countedByPrototype)) node.nodeIndex = j++; } }, unique: function(nodes) { if (nodes.length == 0) return nodes; var results = [], n; for (var i = 0, l = nodes.length; i < l; i++) if (!(n = nodes[i])._countedByPrototype) { n._countedByPrototype = Prototype.emptyFunction; results.push(Element.extend(n)); } return Selector.handlers.unmark(results); }, descendant: function(nodes) { var h = Selector.handlers; for (var i = 0, results = [], node; node = nodes[i]; i++) h.concat(results, node.getElementsByTagName('*')); return results; }, child: function(nodes) { var h = Selector.handlers; for (var i = 0, results = [], node; node = nodes[i]; i++) { for (var j = 0, child; child = node.childNodes[j]; j++) if (child.nodeType == 1 && child.tagName != '!') results.push(child); } return results; }, adjacent: function(nodes) { for (var i = 0, results = [], node; node = nodes[i]; i++) { var next = this.nextElementSibling(node); if (next) results.push(next); } return results; }, laterSibling: function(nodes) { var h = Selector.handlers; for (var i = 0, results = [], node; node = nodes[i]; i++) h.concat(results, Element.nextSiblings(node)); return results; }, nextElementSibling: function(node) { while (node = node.nextSibling) if (node.nodeType == 1) return node; return null; }, previousElementSibling: function(node) { while (node = node.previousSibling) if (node.nodeType == 1) return node; return null; }, tagName: function(nodes, root, tagName, combinator) { var uTagName = tagName.toUpperCase(); var results = [], h = Selector.handlers; if (nodes) { if (combinator) { if (combinator == "descendant") { for (var i = 0, node; node = nodes[i]; i++) h.concat(results, node.getElementsByTagName(tagName)); return results; } else nodes = this[combinator](nodes); if (tagName == "*") return nodes; } for (var i = 0, node; node = nodes[i]; i++) if (node.tagName.toUpperCase() === uTagName) results.push(node); return results; } else return root.getElementsByTagName(tagName); }, id: function(nodes, root, id, combinator) { var targetNode = $(id), h = Selector.handlers; if (!targetNode) return []; if (!nodes && root == document) return [targetNode]; if (nodes) { if (combinator) { if (combinator == 'child') { for (var i = 0, node; node = nodes[i]; i++) if (targetNode.parentNode == node) return [targetNode]; } else if (combinator == 'descendant') { for (var i = 0, node; node = nodes[i]; i++) if (Element.descendantOf(targetNode, node)) return [targetNode]; } else if (combinator == 'adjacent') { for (var i = 0, node; node = nodes[i]; i++) if (Selector.handlers.previousElementSibling(targetNode) == node) return [targetNode]; } else nodes = h[combinator](nodes); } for (var i = 0, node; node = nodes[i]; i++) if (node == targetNode) return [targetNode]; return []; } return (targetNode && Element.descendantOf(targetNode, root)) ? [targetNode] : []; }, className: function(nodes, root, className, combinator) { if (nodes && combinator) nodes = this[combinator](nodes); return Selector.handlers.byClassName(nodes, root, className); }, byClassName: function(nodes, root, className) { if (!nodes) nodes = Selector.handlers.descendant([root]); var needle = ' ' + className + ' '; for (var i = 0, results = [], node, nodeClassName; node = nodes[i]; i++) { nodeClassName = node.className; if (nodeClassName.length == 0) continue; if (nodeClassName == className || (' ' + nodeClassName + ' ').include(needle)) results.push(node); } return results; }, attrPresence: function(nodes, root, attr, combinator) { if (!nodes) nodes = root.getElementsByTagName("*"); if (nodes && combinator) nodes = this[combinator](nodes); var results = []; for (var i = 0, node; node = nodes[i]; i++) if (Element.hasAttribute(node, attr)) results.push(node); return results; }, attr: function(nodes, root, attr, value, operator, combinator) { if (!nodes) nodes = root.getElementsByTagName("*"); if (nodes && combinator) nodes = this[combinator](nodes); var handler = Selector.operators[operator], results = []; for (var i = 0, node; node = nodes[i]; i++) { var nodeValue = Element.readAttribute(node, attr); if (nodeValue === null) continue; if (handler(nodeValue, value)) results.push(node); } return results; }, pseudo: function(nodes, name, value, root, combinator) { if (nodes && combinator) nodes = this[combinator](nodes); if (!nodes) nodes = root.getElementsByTagName("*"); return Selector.pseudos[name](nodes, value, root); } }, pseudos: { 'first-child': function(nodes, value, root) { for (var i = 0, results = [], node; node = nodes[i]; i++) { if (Selector.handlers.previousElementSibling(node)) continue; results.push(node); } return results; }, 'last-child': function(nodes, value, root) { for (var i = 0, results = [], node; node = nodes[i]; i++) { if (Selector.handlers.nextElementSibling(node)) continue; results.push(node); } return results; }, 'only-child': function(nodes, value, root) { var h = Selector.handlers; for (var i = 0, results = [], node; node = nodes[i]; i++) if (!h.previousElementSibling(node) && !h.nextElementSibling(node)) results.push(node); return results; }, 'nth-child': function(nodes, formula, root) { return Selector.pseudos.nth(nodes, formula, root); }, 'nth-last-child': function(nodes, formula, root) { return Selector.pseudos.nth(nodes, formula, root, true); }, 'nth-of-type': function(nodes, formula, root) { return Selector.pseudos.nth(nodes, formula, root, false, true); }, 'nth-last-of-type': function(nodes, formula, root) { return Selector.pseudos.nth(nodes, formula, root, true, true); }, 'first-of-type': function(nodes, formula, root) { return Selector.pseudos.nth(nodes, "1", root, false, true); }, 'last-of-type': function(nodes, formula, root) { return Selector.pseudos.nth(nodes, "1", root, true, true); }, 'only-of-type': function(nodes, formula, root) { var p = Selector.pseudos; return p['last-of-type'](p['first-of-type'](nodes, formula, root), formula, root); }, getIndices: function(a, b, total) { if (a == 0) return b > 0 ? [b] : []; return $R(1, total).inject([], function(memo, i) { if (0 == (i - b) % a && (i - b) / a >= 0) memo.push(i); return memo; }); }, nth: function(nodes, formula, root, reverse, ofType) { if (nodes.length == 0) return []; if (formula == 'even') formula = '2n+0'; if (formula == 'odd') formula = '2n+1'; var h = Selector.handlers, results = [], indexed = [], m; h.mark(nodes); for (var i = 0, node; node = nodes[i]; i++) { if (!node.parentNode._countedByPrototype) { h.index(node.parentNode, reverse, ofType); indexed.push(node.parentNode); } } if (formula.match(/^\d+$/)) { 
 formula = Number(formula); for (var i = 0, node; node = nodes[i]; i++) if (node.nodeIndex == formula) results.push(node); } else if (m = formula.match(/^(-?\d*)?n(([+-])(\d+))?/)) { 
 if (m[1] == "-") m[1] = -1; var a = m[1] ? Number(m[1]) : 1; var b = m[2] ? Number(m[2]) : 0; var indices = Selector.pseudos.getIndices(a, b, nodes.length); for (var i = 0, node, l = indices.length; node = nodes[i]; i++) { for (var j = 0; j < l; j++) if (node.nodeIndex == indices[j]) results.push(node); } } h.unmark(nodes); h.unmark(indexed); return results; }, 'empty': function(nodes, value, root) { for (var i = 0, results = [], node; node = nodes[i]; i++) { if (node.tagName == '!' || (node.firstChild && !node.innerHTML.match(/^\s*$/))) continue; results.push(node); } return results; }, 'not': function(nodes, selector, root) { var h = Selector.handlers, selectorType, m; var exclusions = new Selector(selector).findElements(root); h.mark(exclusions); for (var i = 0, results = [], node; node = nodes[i]; i++) if (!node._countedByPrototype) results.push(node); h.unmark(exclusions); return results; }, 'enabled': function(nodes, value, root) { for (var i = 0, results = [], node; node = nodes[i]; i++) if (!node.disabled) results.push(node); return results; }, 'disabled': function(nodes, value, root) { for (var i = 0, results = [], node; node = nodes[i]; i++) if (node.disabled) results.push(node); return results; }, 'checked': function(nodes, value, root) { for (var i = 0, results = [], node; node = nodes[i]; i++) if (node.checked) results.push(node); return results; } }, operators: { '=': function(nv, v) { return nv == v; }, '!=': function(nv, v) { return nv != v; }, '^=': function(nv, v) { return nv.startsWith(v); }, '$=': function(nv, v) { return nv.endsWith(v); }, '*=': function(nv, v) { return nv.include(v); }, '~=': function(nv, v) { return (' ' + nv + ' ').include(' ' + v + ' '); }, '|=': function(nv, v) { return ('-' + nv.toUpperCase() + '-').include('-' + v.toUpperCase() + '-'); } }, split: function(expression) { var expressions = []; expression.scan(/(([\w#:.~>+()\s-]+|\*|\[.*?\])+)\s*(,|$)/, function(m) { expressions.push(m[1].strip()); }); return expressions; }, matchElements: function(elements, expression) { var matches = $$(expression), h = Selector.handlers; h.mark(matches); for (var i = 0, results = [], element; element = elements[i]; i++) if (element._countedByPrototype) results.push(element); h.unmark(matches); return results; }, findElement: function(elements, expression, index) { if (Object.isNumber(expression)) { index = expression; expression = false; } return Selector.matchElements(elements, expression || '*')[index || 0]; }, findChildElements: function(element, expressions) { expressions = Selector.split(expressions.join(',')); var results = [], h = Selector.handlers; for (var i = 0, l = expressions.length, selector; i < l; i++) { selector = new Selector(expressions[i].strip()); h.concat(results, selector.findElements(element)); } return (l > 1) ? h.unique(results) : results; }});if (Prototype.Browser.IE) { Object.extend(Selector.handlers, { concat: function(a, b) { for (var i = 0, node; node = b[i]; i++) if (node.tagName !== "!") a.push(node); return a; }, unmark: function(nodes) { for (var i = 0, node; node = nodes[i]; i++) node.removeAttribute('_countedByPrototype'); return nodes; } });}function $$() { return Selector.findChildElements(document, $A(arguments));}var Form = { reset: function(form) { $(form).reset(); return form; }, serializeElements: function(elements, options) { if (typeof options != 'object') options = { hash: !!options }; else if (Object.isUndefined(options.hash)) options.hash = true; var key, value, submitted = false, submit = options.submit; var data = elements.inject({ }, function(result, element) { if (!element.disabled && element.name) { key = element.name; value = $(element).getValue(); if (value != null && (element.type != 'submit' || (!submitted &&
 submit !== false && (!submit || key == submit) && (submitted = true)))) { if (key in result) { if (!Object.isArray(result[key])) result[key] = [result[key]]; result[key].push(value); } else result[key] = value; } } return result; }); return options.hash ? data : Object.toQueryString(data); }};Form.Methods = { serialize: function(form, options) { return Form.serializeElements(Form.getElements(form), options); }, getElements: function(form) { return $A($(form).getElementsByTagName('*')).inject([], function(elements, child) { if (Form.Element.Serializers[child.tagName.toLowerCase()]) elements.push(Element.extend(child)); return elements; } ); }, getInputs: function(form, typeName, name) { form = $(form); var inputs = form.getElementsByTagName('input'); if (!typeName && !name) return $A(inputs).map(Element.extend); for (var i = 0, matchingInputs = [], length = inputs.length; i < length; i++) { var input = inputs[i]; if ((typeName && input.type != typeName) || (name && input.name != name)) continue; matchingInputs.push(Element.extend(input)); } return matchingInputs; }, disable: function(form) { form = $(form); Form.getElements(form).invoke('disable'); return form; }, enable: function(form) { form = $(form); Form.getElements(form).invoke('enable'); return form; }, findFirstElement: function(form) { var elements = $(form).getElements().findAll(function(element) { return 'hidden' != element.type && !element.disabled; }); var firstByIndex = elements.findAll(function(element) { return element.hasAttribute('tabIndex') && element.tabIndex >= 0; }).sortBy(function(element) { return element.tabIndex }).first(); return firstByIndex ? firstByIndex : elements.find(function(element) { return ['input', 'select', 'textarea'].include(element.tagName.toLowerCase()); }); }, focusFirstElement: function(form) { form = $(form); form.findFirstElement().activate(); return form; }, request: function(form, options) { form = $(form), options = Object.clone(options || { }); var params = options.parameters, action = form.readAttribute('action') || ''; if (action.blank()) action = window.location.href; options.parameters = form.serialize(true); if (params) { if (Object.isString(params)) params = params.toQueryParams(); Object.extend(options.parameters, params); } if (form.hasAttribute('method') && !options.method) options.method = form.method; return new Ajax.Request(action, options); }};Form.Element = { focus: function(element) { $(element).focus(); return element; }, select: function(element) { $(element).select(); return element; }};Form.Element.Methods = { serialize: function(element) { element = $(element); if (!element.disabled && element.name) { var value = element.getValue(); if (value != undefined) { var pair = { }; pair[element.name] = value; return Object.toQueryString(pair); } } return ''; }, getValue: function(element) { element = $(element); var method = element.tagName.toLowerCase(); return Form.Element.Serializers[method](element); }, setValue: function(element, value) { element = $(element); var method = element.tagName.toLowerCase(); Form.Element.Serializers[method](element, value); return element; }, clear: function(element) { $(element).value = ''; return element; }, present: function(element) { return $(element).value != ''; }, activate: function(element) { element = $(element); try { element.focus(); if (element.select && (element.tagName.toLowerCase() != 'input' ||
 !['button', 'reset', 'submit'].include(element.type))) element.select(); } catch (e) { } return element; }, disable: function(element) { element = $(element); element.blur(); element.disabled = true; return element; }, enable: function(element) { element = $(element); element.disabled = false; return element; }};var Field = Form.Element;var $F = Form.Element.Methods.getValue;Form.Element.Serializers = { input: function(element, value) { switch (element.type.toLowerCase()) { case 'checkbox':
 case 'radio':
 return Form.Element.Serializers.inputSelector(element, value); default:
 return Form.Element.Serializers.textarea(element, value); } }, inputSelector: function(element, value) { if (Object.isUndefined(value)) return element.checked ? element.value : null; else element.checked = !!value; }, textarea: function(element, value) { if (Object.isUndefined(value)) return element.value; else element.value = value; }, select: function(element, index) { if (Object.isUndefined(index)) return this[element.type == 'select-one' ?
 'selectOne' : 'selectMany'](element); else { var opt, value, single = !Object.isArray(index); for (var i = 0, length = element.length; i < length; i++) { opt = element.options[i]; value = this.optionValue(opt); if (single) { if (value == index) { opt.selected = true; return; } } else opt.selected = index.include(value); } } }, selectOne: function(element) { var index = element.selectedIndex; return index >= 0 ? this.optionValue(element.options[index]) : null; }, selectMany: function(element) { var values, length = element.length; if (!length) return null; for (var i = 0, values = []; i < length; i++) { var opt = element.options[i]; if (opt.selected) values.push(this.optionValue(opt)); } return values; }, optionValue: function(opt) { return Element.extend(opt).hasAttribute('value') ? opt.value : opt.text; }};Abstract.TimedObserver = Class.create(PeriodicalExecuter, { initialize: function($super, element, frequency, callback) { $super(callback, frequency); this.element = $(element); this.lastValue = this.getValue(); }, execute: function() { var value = this.getValue(); if (Object.isString(this.lastValue) && Object.isString(value) ?
 this.lastValue != value : String(this.lastValue) != String(value)) { this.callback(this.element, value); this.lastValue = value; } }});Form.Element.Observer = Class.create(Abstract.TimedObserver, { getValue: function() { return Form.Element.getValue(this.element); }});Form.Observer = Class.create(Abstract.TimedObserver, { getValue: function() { return Form.serialize(this.element); }});Abstract.EventObserver = Class.create({ initialize: function(element, callback) { this.element = $(element); this.callback = callback; this.lastValue = this.getValue(); if (this.element.tagName.toLowerCase() == 'form') this.registerFormCallbacks(); else
 this.registerCallback(this.element); }, onElementEvent: function() { var value = this.getValue(); if (this.lastValue != value) { this.callback(this.element, value); this.lastValue = value; } }, registerFormCallbacks: function() { Form.getElements(this.element).each(this.registerCallback, this); }, registerCallback: function(element) { if (element.type) { switch (element.type.toLowerCase()) { case 'checkbox':
 case 'radio':
 Event.observe(element, 'click', this.onElementEvent.bind(this)); break; default:
 Event.observe(element, 'change', this.onElementEvent.bind(this)); break; } } }});Form.Element.EventObserver = Class.create(Abstract.EventObserver, { getValue: function() { return Form.Element.getValue(this.element); }});Form.EventObserver = Class.create(Abstract.EventObserver, { getValue: function() { return Form.serialize(this.element); }});if (!window.Event) var Event = { };Object.extend(Event, { KEY_BACKSPACE: 8, KEY_TAB: 9, KEY_RETURN: 13, KEY_ESC: 27, KEY_LEFT: 37, KEY_UP: 38, KEY_RIGHT: 39, KEY_DOWN: 40, KEY_DELETE: 46, KEY_HOME: 36, KEY_END: 35, KEY_PAGEUP: 33, KEY_PAGEDOWN: 34, KEY_INSERT: 45, cache: { }, relatedTarget: function(event) { var element; switch(event.type) { case 'mouseover': element = event.fromElement; break; case 'mouseout': element = event.toElement; break; default: return null; } return Element.extend(element); }});Event.Methods = (function() { var isButton; if (Prototype.Browser.IE) { var buttonMap = { 0: 1, 1: 4, 2: 2 }; isButton = function(event, code) { return event.button == buttonMap[code]; }; } else if (Prototype.Browser.WebKit) { isButton = function(event, code) { switch (code) { case 0: return event.which == 1 && !event.metaKey; case 1: return event.which == 1 && event.metaKey; default: return false; } }; } else { isButton = function(event, code) { return event.which ? (event.which === code + 1) : (event.button === code); }; } return { isLeftClick: function(event) { return isButton(event, 0) }, isMiddleClick: function(event) { return isButton(event, 1) }, isRightClick: function(event) { return isButton(event, 2) }, element: function(event) { var node = Event.extend(event).target; return Element.extend(node.nodeType == Node.TEXT_NODE ? node.parentNode : node); }, findElement: function(event, expression) { var element = Event.element(event); if (!expression) return element; var elements = [element].concat(element.ancestors()); return Selector.findElement(elements, expression, 0); }, pointer: function(event) { return { x: event.pageX || (event.clientX +
 (document.documentElement.scrollLeft || document.body.scrollLeft)), y: event.pageY || (event.clientY +
 (document.documentElement.scrollTop || document.body.scrollTop)) }; }, pointerX: function(event) { return Event.pointer(event).x }, pointerY: function(event) { return Event.pointer(event).y }, stop: function(event) { Event.extend(event); event.preventDefault(); event.stopPropagation(); event.stopped = true; } };})();Event.extend = (function() { var methods = Object.keys(Event.Methods).inject({ }, function(m, name) { m[name] = Event.Methods[name].methodize(); return m; }); if (Prototype.Browser.IE) { Object.extend(methods, { stopPropagation: function() { this.cancelBubble = true }, preventDefault: function() { this.returnValue = false }, inspect: function() { return "[object Event]" } }); return function(event) { if (!event) return false; if (event._extendedByPrototype) return event; event._extendedByPrototype = Prototype.emptyFunction; var pointer = Event.pointer(event); Object.extend(event, { target: event.srcElement, relatedTarget: Event.relatedTarget(event), pageX: pointer.x, pageY: pointer.y
 }); return Object.extend(event, methods); }; } else { Event.prototype = Event.prototype || document.createEvent("HTMLEvents").__proto__; Object.extend(Event.prototype, methods); return Prototype.K; }})();Object.extend(Event, (function() { var cache = Event.cache; function getEventID(element) { if (element._prototypeEventID) return element._prototypeEventID[0]; arguments.callee.id = arguments.callee.id || 1; return element._prototypeEventID = [++arguments.callee.id]; } function getDOMEventName(eventName) { if (eventName && eventName.include(':')) return "dataavailable"; return eventName; } function getCacheForID(id) { return cache[id] = cache[id] || { }; } function getWrappersForEventName(id, eventName) { var c = getCacheForID(id); return c[eventName] = c[eventName] || []; } function createWrapper(element, eventName, handler) { var id = getEventID(element); var c = getWrappersForEventName(id, eventName); if (c.pluck("handler").include(handler)) return false; var wrapper = function(event) { if (!Event || !Event.extend ||
 (event.eventName && event.eventName != eventName)) return false; Event.extend(event); handler.call(element, event); }; wrapper.handler = handler; c.push(wrapper); return wrapper; } function findWrapper(id, eventName, handler) { var c = getWrappersForEventName(id, eventName); return c.find(function(wrapper) { return wrapper.handler == handler }); } function destroyWrapper(id, eventName, handler) { var c = getCacheForID(id); if (!c[eventName]) return false; c[eventName] = c[eventName].without(findWrapper(id, eventName, handler)); } function destroyCache() { for (var id in cache) for (var eventName in cache[id]) cache[id][eventName] = null; } if (window.attachEvent) { window.attachEvent("onunload", destroyCache); } return { observe: function(element, eventName, handler) { element = $(element); var name = getDOMEventName(eventName); var wrapper = createWrapper(element, eventName, handler); if (!wrapper) return element; if (element.addEventListener) { element.addEventListener(name, wrapper, false); } else { element.attachEvent("on" + name, wrapper); } return element; }, stopObserving: function(element, eventName, handler) { element = $(element); var id = getEventID(element), name = getDOMEventName(eventName); if (!handler && eventName) { getWrappersForEventName(id, eventName).each(function(wrapper) { element.stopObserving(eventName, wrapper.handler); }); return element; } else if (!eventName) { Object.keys(getCacheForID(id)).each(function(eventName) { element.stopObserving(eventName); }); return element; } var wrapper = findWrapper(id, eventName, handler); if (!wrapper) return element; if (element.removeEventListener) { element.removeEventListener(name, wrapper, false); } else { element.detachEvent("on" + name, wrapper); } destroyWrapper(id, eventName, handler); return element; }, fire: function(element, eventName, memo) { element = $(element); if (element == document && document.createEvent && !element.dispatchEvent) element = document.documentElement; var event; if (document.createEvent) { event = document.createEvent("HTMLEvents"); event.initEvent("dataavailable", true, true); } else { event = document.createEventObject(); event.eventType = "ondataavailable"; } event.eventName = eventName; event.memo = memo || { }; if (document.createEvent) { element.dispatchEvent(event); } else { element.fireEvent(event.eventType, event); } return Event.extend(event); } };})());Object.extend(Event, Event.Methods);Element.addMethods({ fire: Event.fire, observe: Event.observe, stopObserving: Event.stopObserving
});Object.extend(document, { fire: Element.Methods.fire.methodize(), observe: Element.Methods.observe.methodize(), stopObserving: Element.Methods.stopObserving.methodize(), loaded: false
});(function() { /* Support for the DOMContentLoaded event is based on work by Dan Webb, Matthias Miller, Dean Edwards and John Resig. */
 var timer; function fireContentLoadedEvent() { if (document.loaded) return; if (timer) window.clearInterval(timer); document.fire("dom:loaded"); document.loaded = true; } if (document.addEventListener) { if (Prototype.Browser.WebKit) { timer = window.setInterval(function() { if (/loaded|complete/.test(document.readyState)) fireContentLoadedEvent(); }, 0); Event.observe(window, "load", fireContentLoadedEvent); } else { document.addEventListener("DOMContentLoaded", fireContentLoadedEvent, false); } } else { document.write("<script id=__onDOMContentLoaded defer src=//:><\/script>"); $("__onDOMContentLoaded").onreadystatechange = function() { if (this.readyState == "complete") { this.onreadystatechange = null; fireContentLoadedEvent(); } }; }})();Hash.toQueryString = Object.toQueryString;var Toggle = { display: Element.toggle };Element.Methods.childOf = Element.Methods.descendantOf;var Insertion = { Before: function(element, content) { return Element.insert(element, {before:content}); }, Top: function(element, content) { return Element.insert(element, {top:content}); }, Bottom: function(element, content) { return Element.insert(element, {bottom:content}); }, After: function(element, content) { return Element.insert(element, {after:content}); }};var $continue = new Error('"throw $continue" is deprecated, use "return" instead');var Position = { includeScrollOffsets: false, prepare: function() { this.deltaX = window.pageXOffset
 || document.documentElement.scrollLeft
 || document.body.scrollLeft
 || 0; this.deltaY = window.pageYOffset
 || document.documentElement.scrollTop
 || document.body.scrollTop
 || 0; }, within: function(element, x, y) { if (this.includeScrollOffsets) return this.withinIncludingScrolloffsets(element, x, y); this.xcomp = x; this.ycomp = y; this.offset = Element.cumulativeOffset(element); return (y >= this.offset[1] &&
 y < this.offset[1] + element.offsetHeight &&
 x >= this.offset[0] &&
 x < this.offset[0] + element.offsetWidth); }, withinIncludingScrolloffsets: function(element, x, y) { var offsetcache = Element.cumulativeScrollOffset(element); this.xcomp = x + offsetcache[0] - this.deltaX; this.ycomp = y + offsetcache[1] - this.deltaY; this.offset = Element.cumulativeOffset(element); return (this.ycomp >= this.offset[1] &&
 this.ycomp < this.offset[1] + element.offsetHeight &&
 this.xcomp >= this.offset[0] &&
 this.xcomp < this.offset[0] + element.offsetWidth); }, overlap: function(mode, element) { if (!mode) return 0; if (mode == 'vertical') return ((this.offset[1] + element.offsetHeight) - this.ycomp) /
 element.offsetHeight; if (mode == 'horizontal') return ((this.offset[0] + element.offsetWidth) - this.xcomp) /
 element.offsetWidth; }, cumulativeOffset: Element.Methods.cumulativeOffset, positionedOffset: Element.Methods.positionedOffset, absolutize: function(element) { Position.prepare(); return Element.absolutize(element); }, relativize: function(element) { Position.prepare(); return Element.relativize(element); }, realOffset: Element.Methods.cumulativeScrollOffset, offsetParent: Element.Methods.getOffsetParent, page: Element.Methods.viewportOffset, clone: function(source, target, options) { options = options || { }; return Element.clonePosition(target, source, options); }};if (!document.getElementsByClassName) document.getElementsByClassName = function(instanceMethods){ function iter(name) { return name.blank() ? null : "[contains(concat(' ', @class, ' '), ' " + name + " ')]"; } instanceMethods.getElementsByClassName = Prototype.BrowserFeatures.XPath ?
 function(element, className) { className = className.toString().strip(); var cond = /\s/.test(className) ? $w(className).map(iter).join('') : iter(className); return cond ? document._getElementsByXPath('.//*' + cond, element) : []; } : function(element, className) { className = className.toString().strip(); var elements = [], classNames = (/\s/.test(className) ? $w(className) : null); if (!classNames && !className) return elements; var nodes = $(element).getElementsByTagName('*'); className = ' ' + className + ' '; for (var i = 0, child, cn; child = nodes[i]; i++) { if (child.className && (cn = ' ' + child.className + ' ') && (cn.include(className) ||
 (classNames && classNames.all(function(name) { return !name.toString().blank() && cn.include(' ' + name + ' '); })))) elements.push(Element.extend(child)); } return elements; }; return function(className, parentElement) { return $(parentElement || document.body).getElementsByClassName(className); };}(Element.Methods);Element.ClassNames = Class.create();Element.ClassNames.prototype = { initialize: function(element) { this.element = $(element); }, _each: function(iterator) { this.element.className.split(/\s+/).select(function(name) { return name.length > 0; })._each(iterator); }, set: function(className) { this.element.className = className; }, add: function(classNameToAdd) { if (this.include(classNameToAdd)) return; this.set($A(this).concat(classNameToAdd).join(' ')); }, remove: function(classNameToRemove) { if (!this.include(classNameToRemove)) return; this.set($A(this).without(classNameToRemove).join(' ')); }, toString: function() { return $A(this).join(' '); }};Object.extend(Element.ClassNames.prototype, Enumerable);Element.addMethods();var Cursor_Y = 0;var Cursor_X = 0;var uBrowser = 'Explorer6';function AjaxUpdaterComplete(){ window.setTimeout(function() { var divWebServiceError = $('divWebServiceError'); if (divWebServiceError){ if (divWebServiceError.innerHTML!=''){ var divMsg = $('divMsg'); if (divMsg) { alert(divWebServiceError.innerHTML); divWebServiceError.innerHTML=''; } } } }, 50);}function DeSelect(){ if (window.getSelection) 
 window.getSelection().removeAllRanges(); else if (document.selection) 
 document.selection.empty();}function Msg(msg) { var divMsg = $('divMsg'); if (divMsg) { if (msg!=''){ divMsg.innerHTML = msg; divMsg.style.backgroundColor = 'White'; } else { divMsg.style.backgroundColor = ''; } }}var focusedElem = '';function Getxy(e) { var ev = window.event||window.Event; if('undefined'==typeof ev.pageX) { Cursor_X = e.clientX + ScrollLeft(); Cursor_Y = e.clientY + ScrollTop(); } else { if (document.layers) { Cursor_X = e.pageX + ScrollLeft(); Cursor_Y = e.pageY + ScrollTop(); } else { Cursor_X = event.x + ScrollLeft(); Cursor_Y = event.y + ScrollTop(); } } if (AllowReFocus(SearchBoxName())) 
 DeSelect();}function AllowReFocus(additionalElem){ if (additionalElem) if (focusedElem==additionalElem) return false; if (focusedElem=='inHomeZip') return false; else if (focusedElem=='feedbackSubject') return false; else if (focusedElem=='feedbackEmail') return false; else if (focusedElem=='feedbackText') return false; else if (focusedElem=='inUser') return false; else if (focusedElem=='inPassword') return false; else 
 return true;}var BrowserDetect = {init: function () { this.browser = this.searchString(this.dataBrowser) || "unknown"; this.version = this.searchVersion(navigator.userAgent) || this.searchVersion(navigator.appVersion) || "an unknown version"; this.OS = this.searchString(this.dataOS) || "an unknown OS"; SetBrowserVersion(this.browser, this.version, this.OS); uBrowser = this.browser + this.version;},searchString: function (data) { for (var i=0;i<data.length;i++) { var dataString = data[i].string; var dataProp = data[i].prop; this.versionSearchString = data[i].versionSearch || data[i].identity; if (dataString) { if (dataString.indexOf(data[i].subString) != -1) return data[i].identity; } else if (dataProp) return data[i].identity; }},searchVersion: function (dataString) { var index = dataString.indexOf(this.versionSearchString); if (index == -1) return; return parseFloat(dataString.substring(index+this.versionSearchString.length+1));},dataBrowser: [
 { string: navigator.userAgent, subString: "Chrome", identity: "Chrome"
 }, { string: navigator.userAgent, subString: "OmniWeb", versionSearch: "OmniWeb/", identity: "OmniWeb"
 }, { string: navigator.vendor, subString: "Apple", identity: "Safari"
 }, { prop: window.opera, identity: "Opera"
 }, { string: navigator.vendor, subString: "iCab", identity: "iCab"
 }, { string: navigator.vendor, subString: "KDE", identity: "Konqueror"
 }, { string: navigator.userAgent, subString: "Firefox", identity: "Firefox"
 }, { string: navigator.vendor, subString: "Camino", identity: "Camino"
 }, { 
 string: navigator.userAgent, subString: "Netscape", identity: "Netscape"
 }, { string: navigator.userAgent, subString: "MSIE", identity: "Explorer", versionSearch: "MSIE"
 }, { string: navigator.userAgent, subString: "Gecko", identity: "Mozilla", versionSearch: "rv"
 }, { 
 string: navigator.userAgent, subString: "Mozilla", identity: "Netscape", versionSearch: "Mozilla"
 }],dataOS : [
 { string: navigator.platform, subString: "Win", identity: "Windows"
 }, { string: navigator.platform, subString: "Mac", identity: "Mac"
 }, { string: navigator.platform, subString: "Linux", identity: "Linux"
 }]
};function addEvent(obj, evType, fn){ 
 if (obj.addEventListener){ obj.addEventListener(evType, fn, false); return true; } else if (obj.attachEvent){ var r = obj.attachEvent("on"+evType, fn); return r; } else { Msg('COULD NOT ATTACH' + fn);return false; } 
}function removeEvent(obj, evType, fn){ 
 if (obj.removeEventListener ){ obj.removeEventListener(evType, fn, false); return true; } else if (obj.detachEvent){ var r = obj.detachEvent("on"+evType, fn); return r; } else { return false; } 
}function UpdateHomeZip(ForceUpdate) { var inHomeZip = $('inHomeZip'); if (inHomeZip) { if (inHomeZip.value.length == 5 || ForceUpdate) { divCostOfLiving(inHomeZip.value); } }}var lastInfoOption = '';function SelectInfoOption(InfoOption){ lastInfoOption = InfoOption; var infoOption = $(InfoOption); var imgInfoOption = $('imgInfoOption'); var divInfoOptions = $('divInfoOptions'); if (divInfoOptions && imgInfoOption) { if (GetHeight(divInfoOptions) == 0 || InfoOption=='') { imgInfoOption.src='/images/blank.gif'; return false; } } if (divInfoOptions && infoOption && imgInfoOption && InfoOption!='' && showingInfoOptions==true) { var newTop = GetTop(infoOption) - divInfoOptions.scrollTop + 2; if (newTop >= GetTop(divInfoOptions) && newTop <= GetTop(divInfoOptions) + GetHeight(divInfoOptions)) { imgInfoOption.src='/images/InfoArrow.gif'; imgInfoOption.style.top = newTop + 'px'; imgInfoOption.style.left = GetLeft(divInfoOptions) + 4 + 'px'; return true; } else { imgInfoOption.src='/images/blank.gif'; } } return false;}function startFeedback(){ var feedbackText=$('feedbackText'); 
 if (feedbackText) { 
 feedbackText.style.width = Math.round(BrowserWidth() * 0.7 - 100) + 'px'; 
 feedbackText.style.height = BrowserHeight() / 3 + 'px'; 
 } 
 feedbackSubject.focus();}function submitFeedback(){ var feedbackEmail=$('feedbackEmail'); 
 var feedbackSubject=$('feedbackSubject'); 
 var feedbackText=$('feedbackText'); 
 if (feedbackSubject && feedbackSubject && feedbackText){ divFeedback(feedbackEmail.value, feedbackSubject.value, feedbackText.value); }}function hoverTab(tabName, hover) { var imgLeft = $('img' + tabName + 'left'); var tdRepeat = $('td' + tabName + 'repeat'); var imgRight = $('img' + tabName + 'right'); if (imgLeft && tdRepeat && imgRight) { if (hover == 1){ imgLeft.src = '/images/tab_hover_left.gif'; tdRepeat.className = 'tabButton_hover'; imgRight.src = '/images/tab_hover_right.gif'; } else { imgLeft.src = '/images/tab_left.gif'; tdRepeat.className = 'tabButton'; imgRight.src = '/images/tab_right.gif'; } }}var LoadingMsg = { go: function() { var divLoading = $('divLoading'); var x=Math.round(BrowserWidth() / 2); var y=200; var anchor = $(this.anchor); if (anchor && GetLeft(anchor)){ x=GetLeft(anchor)+Math.round(GetWidth(anchor)/2); y=GetTop(anchor); } if (divLoading) { var divLoadingMsg = $('divLoadingMsg'); if (divLoadingMsg) divLoadingMsg.innerHTML = this.msg; divLoading.style.display='block'; divLoading.style.top=y+'px'; divLoading.style.left=x-Math.round(GetWidth(divLoading)/2)+'px'; } delete this.timeoutID; } ,showing: function(){ var divLoading = $('divLoading'); if (divLoading && divLoading.style && divLoading.style.display && divLoading.style.display!='none') return true; else
 return false; } ,clear: function(){ this.cancel(); 
 var divLoading = $('divLoading'); if (divLoading) divLoading.style.display='none'; } ,init: function(msg, anchor, delay){ if(typeof this.timeoutID!="number"){ this.cancel(); var self=this; this.anchor=anchor; this.msg=msg; if (!delay) delay=0; if (self.showing() || delay==0) self.go(); else
 this.timeoutID=window.setTimeout(function(){self.go();},delay); } } ,cancel: function() {if(typeof this.timeoutID=="number") {window.clearTimeout(this.timeoutID);delete this.timeoutID;}}};var hidePopup = { init: function(timeOut) { this.cancel(); var self = this; this.timeoutID = window.setTimeout(function() {self.hide();}, timeOut); } ,cancel: function() { if (typeof this.timeoutID == "number") { window.clearTimeout(this.timeoutID); delete this.timeoutID;} } 
 ,hide: function() { var divSR = $('divSearchResults'); if (divSR) divSR.className='hidden'; delete this.timeoutID; }};function pageInit() { if (!CheckSize() && SAID > 0) divInformation('',''); window.setTimeout(function(){if (!CheckSize() && SAID > 0) divInformation('','');},500);}var quicksearching=0;var searchLocation='';var QuickSearch = { search: function(qSearch) { 
 if (quickSearchLoading) { 
 StartQuickSearch(); } else { 
 if (qSearch.indexOf('City, State or Zip')<0) QuickSearchRequest(qSearch); } 
 delete this.timeoutID; 
 } ,init: function(qSearch) { this.cancel();if (qSearch) { if (qSearch.length>0) { var self = this; this.timeoutID = window.setTimeout(function() {self.search(qSearch);}, 50); } } } ,cancel: function() {if(typeof this.timeoutID == "number") {window.clearTimeout(this.timeoutID);delete this.timeoutID;}}};var quickSearchLoading = false;var QuickSearchLoading = { load: function() { var divSR = $('divSearchResults'); if (divSR) { divSR.innerHTML = "<table width='100%'><tr><td><img src='/images/loading.gif' style='margin:10px;padding:10px;'/></td><td style='font-size:16px;margin:10px;padding:10px;'>Searching...</td></tr></table>"; ShowQuickSearchResults(); } delete this.timeoutID;} ,init: function() { quickSearchLoading=true; this.cancel(); var self = this; this.timeoutID = window.setTimeout(function() {self.load();}, 500); } ,cancel: function() { if(typeof this.timeoutID == "number") { window.clearTimeout(this.timeoutID); delete this.timeoutID; } quickSearchLoading=false; }};function SearchBoxName() { if (focusedElem == 'inLocation') return 'inLocation'; else if (focusedElem == 'inQuickSearch') return 'inQuickSearch'; else { var inLocation = $('inLocation'); if (inLocation && ScrollTop() > 10) return 'inLocation'; else 
 return 'inQuickSearch'; } 
}function StartQuickSearch() { var inSearch = $(SearchBoxName()); if (inSearch) { if (AllowReFocus(SearchBoxName()) || focusedElem == 'inLocation' || focusedElem == 'inQuickSearch') { QuickSearch.init(inSearch.value); EndQuickSearch_cancel(); inSearch.className = SearchBoxName() + '_Active'; if (quicksearching==0) { inSearch.value = ''; lastQuickSearch = ''; inSearch.focus(); } if (inSearch.value == searchLocation || inSearch.value == 'City, State or Zip' || inSearch.value == 'enter City, State or Zip') { EndQuickSearch(); 
 inSearch.value = ''; 
 lastQuickSearch=''; 
 QuickSearch.cancel(); } 
 var divSR = $('divSearchResults'); 
 if (divSR) { 
 if (inSearch.value!=lastQuickSearch && inSearch.value!='') { QuickSearchLoading.init(); } else if (inSearch.value == '') { EndQuickSearch(); 
 } lastQuickSearch = inSearch.value; } else { 
 EndQuickSearch(); 
 } } }}var lastSearch;function QuickSearchRequest(Search) { QuickSearch.cancel(); EndQuickSearch_cancel(); if (Search == '') { EndQuickSearch(); } else if (Search == lastSearch) { ShowQuickSearchResults(); } else { lastSearch = Search; divSearchResults(Search); delete qslast; delete qslastcell; }}var qsCol = 1;var qsCols = 1;var qsRow = 1;function ShowQuickSearchResults() { QuickSearchLoading.cancel(); EndQuickSearch_cancel(); var divSearchResults = $('divSearchResults'); var searchBoxName = SearchBoxName(); var inSearch = $(searchBoxName); var qrW = qsCols * 75 + 100; if (divSearchResults && inSearch) { if (qrW < GetWidth(inSearch) - 20) qrW = GetWidth(inSearch) - 22; divSearchResults.className='divSearchResults'; divSearchResults.style.width = qrW + 'px'; var searchResultsLeft = GetLeft(inSearch) + GetWidth(inSearch) - GetWidth(divSearchResults); if (GetHeight(inSearch) > 20) searchResultsLeft = searchResultsLeft + 2; if (searchResultsLeft < 0 || searchBoxName.indexOf('inLocation') >= 0) searchResultsLeft = GetLeft(inSearch); divSearchResults.style.left = searchResultsLeft + 'px'; var searchResultsTop = GetTop(inSearch) + GetHeight(inSearch); if (searchBoxName.indexOf('inLocation') >= 0 && (searchResultsTop > ScrollTop() + BrowserHeight() - GetHeight(divSearchResults) || uBrowser == 'Explorer6' ) ) searchResultsTop = GetTop(inSearch) - GetHeight(divSearchResults); if (searchResultsTop != GetTop(inSearch) + GetHeight(inSearch) && searchResultsTop < ScrollTop() && searchBoxName.indexOf('inLocation') >= 0) RHSStartSlide('divSearchResults', 'scroll', ScrollTop(), searchResultsTop - 5, 30, 3); 
 divSearchResults.style.top = searchResultsTop + 'px'; }}function PositionWidgetSearchResults(Align) { var divResults = $('divResults'); var divSearchResults = $('divSearchResults'); if (divResults && divSearchResults) { if (Align=='left') divSearchResults.style.left = '0px'; else
 divSearchResults.style.left = GetWidth(divResults) - GetWidth(divSearchResults) + 'px'; }}var eqsID;function EndQuickSearch() { var divSearchResults = $('divSearchResults'); 
 if (divSearchResults) { divSearchResults.className='hidden'; lastSearch = ''; }}function EndQuickSearch_init() { EndQuickSearch_cancel(); eqsID = window.setTimeout('EndQuickSearch()', 1000);}function EndQuickSearch_cancel() { if(typeof eqsID == "number") { window.clearTimeout(eqsID); delete eqsID; 
 }}var qslast;var qslastcell;function SelectQuickSearchResult(highlightSelected) { if (qslast && qslast.className!='') qslast.className = 'divSearchResult'; if (qslastcell) qslastcell.className = 'tdSearchResult'; var tcell = $('t' + qsCol + '-' + qsRow); var acell = $('a' + qsCol + '-' + qsRow); if (tcell) { if (highlightSelected==1) tcell.className = 'tdSearchResultSelected'; qslastcell = tcell; } if (acell) { qslast = acell; }}function userLogin() { var inUser = $('inUser'); var inPassword = $('inPassword'); if (inUser && inPassword) { if (inUser.value == '') { inUser.focus(); return true; } else if (inPassword.value == '') { inPassword.focus(); return true; } else { UserLogin(inUser.value, inPassword.value); return true; } } else { return false; }}var lastQuickSearch = '';function docKeyDown(e) { var keyCode = 0; e= (window.event)? event : e; keyCode = (e.keyCode)? e.keyCode: e.charCode; if (keyCode == 0) keyCode = 13; var inSearch = $(SearchBoxName()); if (inSearch) { if (quicksearching <= 0) { if (inSearch.value.length > 0 && inSearch.value != lastQuickSearch) { StartQuickSearch(); } else { EndQuickSearch_init(); } } 
 if (keyCode == 13) { if (!userLogin()) { if (qslast) { inSearch.value = ''; lastQuickSearch = ''; QuickSearch.cancel(); EndQuickSearch(); if (window.location.href) { window.location.href=qslast.href; } else { window.location=qslast.href; } } } } else if (keyCode == 39) { if( $('t' + (qsCol + 1) + '-' + qsRow) ) { qsCol=qsCol+1; SelectQuickSearchResult(1); } else if ( $('t' + (qsCol + 2) + '-' + qsRow) ) { qsCol=qsCol+2; SelectQuickSearchResult(1); } } else if (keyCode == 40) { if( $('t' + qsCol + '-' + (qsRow + 1)) ) { qsRow=qsRow+1; SelectQuickSearchResult(1); } } else if (keyCode == 38) { if( $('t' + qsCol + '-' + (qsRow - 1)) ) { qsRow=qsRow-1; SelectQuickSearchResult(1); } } else if (keyCode == 37) { if( $('t' + (qsCol - 1) + '-' + qsRow) ) { qsCol=qsCol-1; SelectQuickSearchResult(1); } else if ( $('t' + (qsCol - 2) + '-' + qsRow) ) { qsCol=qsCol-2; SelectQuickSearchResult(1); } } else if (keyCode == 27) { inSearch.value = ''; lastQuickSearch = ''; focusedElem = ''; EndQuickSearch(); } else if (keyCode == 8) { if (focusedElem!='inUser' && focusedElem!='inPassword') EndQuickSearch_init(); } 
 else { } }}document.onkeydown = function(e) { docKeyDown(e); } ;var minClientHeight = 600;var minClientWidth = 600;function BrowserWidth() {var w = 0;if(!window.innerWidth){ if(!(document.documentElement.clientWidth == 0)) {w = document.documentElement.clientWidth-0;} else 
 {w = document.body.clientWidth-0; }}else {w = window.innerWidth-0;} if (w < minClientWidth) w=minClientWidth;return w;}function BrowserHeight() {var h = 0;if(!window.innerHeight){ if(!(document.documentElement.clientHeight == 0)) {h = document.documentElement.clientHeight;} else 
 {h = document.body.clientHeight; }}else {h = window.innerHeight;} if (h < minClientHeight) h=minClientHeight;return h;}function GetLeft(elm){ var x = 0; x = elm.offsetLeft; elm = elm.offsetParent; while(elm != null) { x = parseInt(x) + parseInt(elm.offsetLeft); elm = elm.offsetParent; } return x;}function GetTop(elm){ var y = 0; y = elm.offsetTop; elm = elm.offsetParent; while(elm != null) { y = parseInt(y) + parseInt(elm.offsetTop); elm = elm.offsetParent; } return y;}function GetHeight(elm){ var y = 0; if (elm) { if (elm.offsetHeight) { y = elm.offsetHeight; } } return y;}function GetWidth(elm){ var x = 0; if (elm) { if (elm.offsetHeight) { x = elm.offsetWidth; } } return x;}function ScrollTop(){ var y = 0; if (self.pageYOffset) 
 y = self.pageYOffset; else if (document.documentElement && document.documentElement.scrollTop) 
 y = document.documentElement.scrollTop; else if (document.body) 
 y = document.body.scrollTop; return y;}function ScrollLeft(){ var x = 0; if (self.pageXOffset) 
 x = self.pageXOffset; else if (document.documentElement && document.documentElement.scrollTop) 
 x = document.documentElement.scrollLeft; else if (document.body) 
 x = document.body.scrollLeft; return x;}var chksize = { check: function() {CheckSize();delete this.timeoutID;} ,init: function() {this.cancel();var self = this;this.timeoutID = window.setTimeout(function() {self.check();}, 200);} ,cancel: function() {if(typeof this.timeoutID == "number") {window.clearTimeout(this.timeoutID);delete this.timeoutID;}}};var cM = 10;function CheckSize() { var retVal = false; var tmpcH = BrowserHeight(); var tmpcW = BrowserWidth(); if (Math.abs(tmpcH - cH) > cM || Math.abs(tmpcW - cW) > cM) { cH = BrowserHeight(); cW = BrowserWidth(); SetClientSize(cH, cW); retVal = true; } var divStatsBar=$('divStatsBar'); var divContent=$('divContent'); 
 if (divContent && divStatsBar) { 
 if (GetTop(divContent) < GetTop(divStatsBar) + GetHeight(divStatsBar)) 
 divStatsBar.style.display='none'; 
 } 
 return retVal;}function SetContentBorders(ContentID, Top, Left, Height, Width) { var divContent = $(ContentID); if (divContent) { divContent.style.top = Top + 'px'; divContent.style.left = Left + 'px'; divContent.style.height = Height + 'px'; divContent.style.width = Width + 'px'; }}function pAC() { pCB('NorthAmerica', 0, 0, 144, 271); pCB('SouthAmerica', 137, 83, 133, 152); pCB('SouthPacific', 163, 461, 107, 139); pCB('Asia', 0, 377, 178, 223); pCB('Europe', 0, 250, 139, 162); pCB('Africa', 94, 262, 176, 125);}function pCB(name, top, left, height, width) { var imgCMap = $('imgCMap'); var imgB = $('i' + name); if (imgCMap && imgB) { imgB.style.top = GetTop(imgCMap) + top * GetHeight(imgCMap) / 270 + 'px'; imgB.style.left = GetLeft(imgCMap) + left * GetWidth(imgCMap) / 600 + 'px'; imgB.style.height = height * GetHeight(imgCMap) / 270 + 'px'; imgB.style.width = width * GetWidth(imgCMap) / 600 + 'px'; }}function sizeDivInfo() { var divM = $('divMap'); var divI = $('divInformation'); if (divM && divI && divI.style.width=='') { if (GetLeft(divI) + GetWidth(divI) > GetLeft(divM)) divI.style.width = GetLeft(divM) - GetLeft(divI) + 'px'; } 
}var RHSSlideID = 0;var RHStID = new Array();var RHSslideObj = new Array();var RHSslideAttrib = new Array();var RHSslideEndPos = new Array();var RHSslideStartPos = new Array();var RHSslideStep = new Array();var RHSslideSteps = new Array();function RHSStartSlide(objname, styleAttrib, startPos, endPos, slideInterval, SlideSteps){ if ($(objname)){ RHSslideObj[RHSSlideID] = $(objname); RHSslideAttrib[RHSSlideID] = styleAttrib; RHSslideEndPos[RHSSlideID] = endPos; if (styleAttrib=='scroll' && RHSslideObj[RHSSlideID] && (!endPos || endPos < 0)) RHSslideEndPos[RHSSlideID] = GetTop(RHSslideObj[RHSSlideID]); if (startPos){ RHSslideStartPos[RHSSlideID] = startPos; } else { if (styleAttrib=='height') RHSslideStartPos[RHSSlideID] = GetHeight(RHSslideObj[RHSSlideID]); else if (styleAttrib=='top') RHSslideStartPos[RHSSlideID] = GetTop(RHSslideObj[RHSSlideID]); else if (styleAttrib=='left') RHSslideStartPos[RHSSlideID] = GetLeft(RHSslideObj[RHSSlideID]); else if (styleAttrib=='width') RHSslideStartPos[RHSSlideID] = GetWidth(RHSslideObj[RHSSlideID]); else if (styleAttrib=='lineheight') RHSslideStartPos[RHSSlideID] = GetHeight(RHSslideObj[RHSSlideID]); else if (styleAttrib=='opacity') RHSslideStartPos[RHSSlideID] = 0; else if (styleAttrib=='scroll') RHSslideStartPos[RHSSlideID] = ScrollTop(); } if (!slideInterval) slideInterval = 50; RHStID[RHSSlideID] = setInterval('RHSSlideTick(' + RHSSlideID + ');',slideInterval); if (!SlideSteps) SlideSteps = 5; RHSslideSteps[RHSSlideID] = SlideSteps; RHSslideStep[RHSSlideID] = 0; RHSSlideID = RHSSlideID + 1; }}function RHSSlideTick(RHSSlideID){ RHSslideStep[RHSSlideID] = RHSslideStep[RHSSlideID] + 1; var newVal = ( (RHSslideStep[RHSSlideID]*RHSslideEndPos[RHSSlideID] + (RHSslideSteps[RHSSlideID]-RHSslideStep[RHSSlideID])*RHSslideStartPos[RHSSlideID]) / RHSslideSteps[RHSSlideID] ); if (RHSslideAttrib[RHSSlideID]=='height') RHSslideObj[RHSSlideID].style.height = newVal + 'px'; else if (RHSslideAttrib[RHSSlideID]=='top') RHSslideObj[RHSSlideID].style.top = newVal + 'px'; else if (RHSslideAttrib[RHSSlideID]=='left') RHSslideObj[RHSSlideID].style.left = newVal + 'px'; else if (RHSslideAttrib[RHSSlideID]=='width') RHSslideObj[RHSSlideID].style.width = newVal + 'px'; else if (RHSslideAttrib[RHSSlideID]=='lineheight') RHSslideObj[RHSSlideID].style.lineHeight = newVal + 'px'; else if (RHSslideAttrib[RHSSlideID]=='paddingtop') RHSslideObj[RHSSlideID].style.paddingTop = newVal + 'px'; else if (RHSslideAttrib[RHSSlideID]=='opacity') { RHSslideObj[RHSSlideID].style.opacity = newVal; RHSslideObj[RHSSlideID].style.filter = 'alpha(opacity=' + Math.round(newVal * 100) + ')'; } else if (RHSslideAttrib[RHSSlideID]=='scroll'){ window.scrollTo(0, newVal); } if (RHSslideStep[RHSSlideID] >= RHSslideSteps[RHSSlideID]){ RHSEndSlide(RHSSlideID); }}function RHSEndSlide(RHSSlideID){ clearInterval(RHStID[RHSSlideID]); delete(RHStID[RHSSlideID]); delete(RHSslideObj[RHSSlideID]); delete(RHSslideAttrib[RHSSlideID]); delete(RHSslideEndPos[RHSSlideID]); delete(RHSslideStartPos[RHSSlideID]); delete(RHSslideStep[RHSSlideID]); delete(RHSslideSteps[RHSSlideID]); return;}function colorFade(id,element,start,end,steps,speed) { var startrgb,endrgb,er,eg,eb,step,rint,gint,bint,step; var target = document.getElementById(id); if (target) { steps = steps || 20; speed = speed || 20; if (target.timer) clearInterval(target.timer); endrgb = colorConv(end); er = endrgb[0]; eg = endrgb[1]; eb = endrgb[2]; if(!target.r) { startrgb = colorConv(start); r = startrgb[0]; g = startrgb[1]; b = startrgb[2]; target.r = r; target.g = g; target.b = b; } rint = Math.round(Math.abs(target.r-er)/steps); gint = Math.round(Math.abs(target.g-eg)/steps); bint = Math.round(Math.abs(target.b-eb)/steps); if(rint == 0) { rint = 1 } if(gint == 0) { gint = 1 } if(bint == 0) { bint = 1 } target.step = 1; target.timer = setInterval( function() { animateColor(id,element,steps,er,eg,eb,rint,gint,bint) }, speed); }}function animateColor(id,element,steps,er,eg,eb,rint,gint,bint) { var target = document.getElementById(id); var color; if (target) { if(target.step <= steps) { var r = target.r; var g = target.g; var b = target.b; if(r >= er) { r = r - rint; } else { r = parseInt(r) + parseInt(rint); } if(g >= eg) { g = g - gint; } else { g = parseInt(g) + parseInt(gint); } if(b >= eb) { b = b - bint; } else { b = parseInt(b) + parseInt(bint); } color = 'rgb(' + r + ',' + g + ',' + b + ')'; if(element == 'background') { target.style.backgroundColor = color; } else if(element == 'border') { target.style.borderColor = color; } else { target.style.color = color; } target.r = r; target.g = g; target.b = b; target.step = target.step + 1; } else { if (target.timer) clearInterval(target.timer); color = 'rgb(' + er + ',' + eg + ',' + eb + ')'; if(element == 'background') { target.style.backgroundColor = color; } else if(element == 'border') { target.style.borderColor = color; } else { target.style.color = color; } } }}function colorConv(color) { var rgb = [parseInt(color.substring(0,2),16), 
 parseInt(color.substring(2,4),16), 
 parseInt(color.substring(4,6),16)]; return rgb;}function scrollToTabs(){ var divLocalDetails = $('divLocalDetails'); if (divLocalDetails) { if (ScrollTop() > GetTop(divLocalDetails)) { RHSStartSlide('divLocalDetails', 'scroll', ScrollTop(), GetTop(divLocalDetails) - 5, 50, 10); } }}var lrpp = 10; 
var llID = 0; 
var llC = ''; 
var llS = ''; 
var lalID = 0; 
var rlID = 0; 
var mrL = 24; 
var rL = []; 
function fARL(ID, imgURL, price, address, city, state, country, fav) { var lC = 0; for (var id in rL){ if (rL[id]) if (rL[id].ID) if (rL[id].ID == ID) 
 delete rL[id]; else 
 lC++; } var ltR = lC - mrL; if (ltR > 0) { for(var i = 0;i < rlID;i++){ if (ltR > 0 && rL[i]) { delete rL[i]; 
 ltR = ltR - 1; } } } rL[rlID] = new RecentListing(ID, imgURL, price, address, city, state, country, fav); rlID = rlID + 1; ShowRecentListings.init();}function RecentListing(ID, imgURL, price, address, city, state, country, fav) { this.ID = ID; this.imgURL = imgURL; this.price = price; this.address = address; 
 this.city = city; this.state = state; this.country = country; this.fav = fav;}var ShowRecentListings = { show: function() { showRecentListings(); showFavListings(); delete this.timeoutID; } ,init: function() { this.cancel(); var self = this; this.timeoutID = window.setTimeout(function() {self.show();}, 100); } ,cancel: function() { if (typeof this.timeoutID == "number") { window.clearTimeout(this.timeoutID); delete this.timeoutID;} } };function clearListings(fav) { if (fav && fav==1) { for (var id in rL){ if (rL[id] && rL[id].fav) rL[id].fav=false; } showFavListings(); showRecentListings(); } else { for (var id in rL){ if (rL[id] && !rL[id].fav) delete rL[id]; } showRecentListings(); } ClearListings(fav);}function showRecentListings() { var divRecentListings = $('divRecentListings'); var divRecentListingsContainer = $('divRecentListingsContainer'); if (divRecentListings && divRecentListingsContainer) { var listingCount = 0; var html = ''; for (var id in rL){ if (rL[id] && rL[id].ID && !rL[id].fav) { html = '<tr onclick="showListing(' + rL[id].ID + ', \'' + rL[id].country + '\', \'' + rL[id].state + '\');"><td><img class="imgRecentThumb" src="' + rL[id].imgURL + '" /></td>'
 + '<td align="left"><b>' + rL[id].price + '</b><br/>' + rL[id].address + '<br/>' + rL[id].city + '</td></tr>' 
 + '<tr><td colspan="2"><div class="divAddFav" onclick="AddFav(' + rL[id].ID + ', \'' + rL[id].country + '\', \'' + rL[id].state + '\')"><input type="checkbox" />add to favorites&nbsp;&nbsp;</div></td></tr>'
 + html; listingCount++; } } divRecentListingsContainer.innerHTML = '<table style="width:100%;">' + html + '</table>'; if (listingCount>0) divRecentListings.className = 'divRecentListings'; else
 divRecentListings.className = 'hidden'; }}function showFavListings() { var divFavListings = $('divFavListings'); var divFavListingsContainer = $('divFavListingsContainer'); if (divFavListings && divFavListingsContainer) { var listingCount = 0; var html = ''; for (var id in rL){ if (rL[id] && rL[id].ID && rL[id].fav) { html = '<tr onclick="showListing(' + rL[id].ID + ', \'' + rL[id].country + '\', \'' + rL[id].state + '\');"><td><img class="imgRecentThumb" src="' + rL[id].imgURL + '" /></td>'
 + '<td align="left"><b>' + rL[id].price + '</b><br/>' + rL[id].address + '<br/>' + rL[id].city + '</td></tr>' 
 + '<tr><td colspan="2"><div class="divRemFav"><span onclick="RemoveFav(' + rL[id].ID + ')">remove&nbsp;&nbsp;</span></div></td></tr>'
 + html; listingCount++; } } divFavListingsContainer.innerHTML = '<table style="width:100%;">' + html + '</table>'; if (listingCount>0) divFavListings.className = 'divRecentListings'; else
 divFavListings.className = 'hidden'; }}function removeFav(ID) { for (var id in rL){ if (rL[id] && rL[id].ID && rL[id].ID==ID && rL[id].fav) { rL[id].fav=false; showFavListings(); showRecentListings(); break; } }}var ShowListing = { show: function() {showListing(llID, llC, llS);delete this.timeoutID;} ,init: function(ListingID, Country, State) { if (ListingID!=llID || Country!=llC || State!=llS) { this.cancel(); var self = this; llID = ListingID; llC = Country; llS = State; this.timeoutID = window.setTimeout(function() {self.show();}, 200); } } ,cancel: function() {if(typeof this.timeoutID == "number") {window.clearTimeout(this.timeoutID);delete this.timeoutID;llID=0;}}};var ShowThumbPopup = { show: function() { showThumbPopup();delete this.timeoutID; } ,init: function() { HideThumbPopup.cancel(); this.cancel(); var self = this; this.timeoutID = window.setTimeout(function() {self.show();}, 100); } ,cancel: function() {if(typeof this.timeoutID == "number") {window.clearTimeout(this.timeoutID);delete this.timeoutID;}}};var HideThumbPopup = { hide: function() { hideThumbPopup(); delete this.timeoutID; } ,init: function() { if(typeof this.timeoutID != "number") { this.cancel(); var self = this; this.timeoutID = window.setTimeout(function() {self.hide();}, 500); } } ,cancel: function() { if(typeof this.timeoutID == "number") {window.clearTimeout(this.timeoutID);delete this.timeoutID;}}};function hideThumbPopup() { var divThumbP = $('divThumbPopup'); 
 if (divThumbP) divThumbP.className = 'hidden';}function showThumbPopup() { var divL = $('divL' + lalID); var divThumbP = $('divThumbPopup'); if (divThumbP) { if (divL && divThumbP.className == 'hidden') { HideThumbPopup.cancel(); if (divThumbP.innerHTML!='') { divThumbP.className = 'divThumbPopup'; divThumbP.style.top = GetTop(divL) + GetHeight(divL) + 22 + 'px'; var popLeft = Math.round((GetLeft(divL) + GetWidth(divL) / 2) - GetWidth(divThumbP) / 2); if (popLeft < 5) popLeft = 5; if (popLeft > BrowserWidth() - GetWidth(divThumbP) - 20) popLeft = BrowserWidth() - GetWidth(divThumbP) - 20; divThumbP.style.left = popLeft + 'px'; } else { divThumbP.className = 'hidden'; } } }}function toggleThumbPopup() { var divThumbP = $('divThumbPopup'); if (divThumbP) { if (divThumbP.className == 'hidden') ShowThumbPopup.init(); else
 hideThumbPopup(); }}function highlightListing(ListingID, highlight) { var divL = $('divL' + ListingID); if (divL){ if (highlight==1) { if (lalID == ListingID) { } else { divL.className = 'divListingResult_hover'; } } else { if (lalID == ListingID) { divL.className = 'divListingResult_selected'; } else { divL.className = 'divListingResult'; } } if (lalID == ListingID && highlight == 1) { HideThumbPopup.cancel(); } else if (lalID != ListingID && highlight == 1) { HideThumbPopup.init(); } } 
}function showListing(ListingID, ListingCountry, ListingState) { if (llID == ListingID) 
 toggleThumbPopup(); else
 hideThumbPopup(); llID = ListingID; divInformation("Listing", ListingID + ":" + ListingCountry + ":" + ListingState); var divL = $('divL' + ListingID); var divLast = $('divL' + lalID); var divCity = $('divRC' + ListingID); var divCityLast = $('divRC' + lalID); if (Markers[lalID]) 
 showHouseMarker(Markers[lalID],1); if (Markers[ListingID]) { showHouseMarker(Markers[ListingID],1); } if (divLast){ divLast.className = 'divListingResult'; } if (divCityLast){ divCityLast.style.color='black'; } if (divL){ divL.className = 'divListingResult_selected'; lalID = ListingID; highlightListing(ListingID, 1); scrollToListings(); } if (divCity){ 
 divCity.style.color='white'; }}function scrollToListings(scrollUp){ var divT = 'Top'; var divt = $(divT); if (!divt) { var divT = 'divListingResults'; var divt = $(divT); } if (divt) { if (ScrollTop() < GetTop(divt) - 10 || (scrollUp && ScrollTop() > GetTop(divt) + 20)) { RHSStartSlide(divT, 'scroll', ScrollTop(), GetTop(divt), 15, 5); } }}function highlightListingAddress(highlight){ var divListingAddress = $('divListingAddress'); if (divListingAddress) { if (highlight == 1) 
 divListingAddress.className = 'divListingAddress_hover'; 
 else
 divListingAddress.className = 'divListingAddress'; }}function SizeListingImage(noDesc) { var maxwidth = 380; var divInformation = $('divInformation'); var divCD = $('divContentDetail'); var imgListingImage = $('imgListingImage'); var divListingDetail = $('divListingDetail'); var imgPropertyDetails = $('imgPropertyDetails'); maxwidth = Math.round(BrowserWidth() / 4); if (divInformation.style.width!='') { maxwidth = GetWidth(divInformation); if (GetLeft(divCD) + GetWidth(divCD) > Math.round(BrowserWidth() * 0.9)) maxwidth = maxwidth - GetLeft(divCD) - GetWidth(divCD) + Math.round(BrowserWidth() * 0.9); if (maxwidth < 150) 
 maxwidth = 150; if (!noDesc) 
 maxwidth = Math.round(maxwidth * 3 / 5); } for( i=0; i < document.images.length; i++) 
 { 
 if (document.images[i].id == 'imgListingImage') { var listingimagewidth = document.images[i].width; 
 var listingimageheight = document.images[i].height; 
 } } 
 
 if (imgListingImage) { if (listingimagewidth > maxwidth) { imgListingImage.style.width = maxwidth + 'px'; listingimageheight = listingimageheight * maxwidth / listingimagewidth; listingimagewidth = maxwidth; imgListingImage.style.height = listingimageheight + 'px'; } else { imgListingImage.style.width = listingimagewidth + 'px'; imgListingImage.style.height = listingimageheight + 'px'; } if (divInformation.style.width=='' && GetWidth(divInformation) > 200 && GetWidth(divInformation) <= 500) divInformation.style.width = GetWidth(divInformation)+'px'; imgListingImage.className = 'imgListingImage'; } 
}function ShowListingImage() { var imgListingImage = $('imgListingImage'); if (imgListingImage) imgListingImage.className = 'imgListingImage';}function UpdateResults() { scrollToListings(true); LoadingMsg.init('Updating Listing Results...', 'divSlideResults', 500); divListingResults();}var map = false;var mapPoint;var milesTokm = 1.60934;var drawBorder = 0;var mradius = 20;var mapOptions = false;var cityZoomLevel = 6; 
var userMap = false;var showBoundaries = true; 
function loadMap() { var divMap = $('divMap'); if (GBrowserIsCompatible() && divMap && !map) { map = new GMap2(divMap); map.setUIToDefault(); map.disableScrollWheelZoom(); GEvent.addListener(map, 'moveend', function(){mapMoved(false);}); GEvent.addListener(map, 'zoomend', function(){mapMoved(true);}); GEvent.addListener(map, 'mouseover', function(){hideBoundary();userMap=true;}); GEvent.addListener(map, 'mouseout', function(){userMap=false;}); GEvent.addListener(map, 'dragstart', function(){userMap=true;mapCrosshairs(true);}); GEvent.addListener(map, 'dragend', function(){userMap=true;mapCrosshairs(false);}); GEvent.addListener(map, 'click', mapClick); }}function unloadMap() { if (GBrowserIsCompatible() && document.getElementById('divMap') && map) 
 GUnload(); 
}function mapClick(Overlay, LatLng, OverlayLatLng) { userMap = true; if (drawBorder == 1 && LatLng) { borderPoints.push(LatLng); drawNewBorder(); }}function showLatLng(Lat, Lng, ZoomLevel) { loadMap(); if (map) { map.setCenter(new GLatLng(Lat, Lng), ZoomLevel); }}function toggleMapOptions() { var inMapOptions = $('inMapOptions'); var divMapOptions = $('divMapOptions'); if (inMapOptions) { if (mapOptions == false) { mapOptions = true; divMapOptions.style.height = '72px'; } else { mapOptions = false; divMapOptions.style.height = '20px'; } inMapOptions.checked = mapOptions; showMapMarkers.init(); ToggleMapOptions(); }}function mapMoved(isZooming) { 
 if (userMap && map && !mapOptions && SAID!=0 && circles && circles.length == 2 && !showBoundaries) { 
 var circleIndex = -1; for (var index in circles) { if (circles[index] && circles[index].point && circles[index].radius) { circleIndex = index; } } var newRadius = circles[circleIndex].radius; if (isZooming) { var bounds = map.getBounds(); newRadius = bounds.getSouthWest().distanceFrom(map.getCenter())/1000/milesTokm; var p1 = new GLatLng(bounds.getSouthWest().lat(), map.getCenter().lng()); var p2 = new GLatLng(map.getCenter().lat(), bounds.getSouthWest().lng()); if (p1.distanceFrom(map.getCenter())/1000/milesTokm < newRadius) newRadius = p1.distanceFrom(map.getCenter())/1000/milesTokm; if (p2.distanceFrom(map.getCenter())/1000/milesTokm < newRadius) newRadius = p2.distanceFrom(map.getCenter())/1000/milesTokm; newRadius = newRadius * 0.8; if (newRadius < 1) newRadius = 1; if (newRadius > 50) newRadius = 50; } if (circleIndex >=0 && (circles[circleIndex].point.distanceFrom(map.getCenter())/1000/milesTokm > circles[circleIndex].radius / 25 || Math.abs(newRadius - circles[circleIndex].radius) > circles[circleIndex].radius / 10)) { updateSearch.init(circleIndex, map.getCenter().lat(), map.getCenter().lng(), newRadius); } else { showMapMarkers.init(); 
 } } else { showMapMarkers.init(); 
 } 
}function mapCrosshairs(show) { if (userMap && map && !mapOptions && SAID!=0 && circles && circles.length == 2 && !showBoundaries) { var imgC = $('imgCrosshair'); if (imgC) { var divM = $('divMap'); if (show && divM) { var cRad = 300; for (var index in circles) { if (circles[index] && circles[index].point && circles[index].closepoint) 
 cRad = (map.fromLatLngToContainerPixel(circles[index].point).y - map.fromLatLngToContainerPixel(circles[index].closepoint).y) * 2; } if (cRad < GetWidth(divM)*2){ imgC.style.width = cRad + 'px'; imgC.style.height = cRad + 'px'; imgC.style.top = GetTop(divM) + Math.round((GetHeight(divM)-cRad) / 2) + 'px'; imgC.style.left = GetLeft(divM) + Math.round((GetWidth(divM)-cRad) / 2) + 'px'; imgC.className='imgCrosshair'; } } else { imgC.className='hidden'; } } }}var updateSearch = { init: function(id, lat, lng, rad) { this.cancel(); var self = this; this.id=id; this.lat=lat; this.lng=lng; this.rad=rad; this.timeoutID = window.setTimeout(function() {self.update();}, 200); } ,cancel: function() { if (typeof this.timeoutID == "number") { window.clearTimeout(this.timeoutID); delete this.timeoutID;} } ,update: function() { if (!LoadingMsg.showing()) LoadingMsg.init('Loading Data...', 'divMap', 200); UpdateSearch(this.id, this.lat, this.lng, this.rad); delete this.timeoutID; } };var showMapMarkers = { init: function() { this.cancel(); var self = this; this.timeoutID = window.setTimeout(function() {self.show();}, 200); } ,cancel: function() { if (typeof this.timeoutID == "number") { window.clearTimeout(this.timeoutID); delete this.timeoutID;} } ,show: function() { 
 if (map && !LoadingMsg.showing()) { if (map.getZoom() < cityZoomLevel) { showBoundaries = true; ClearCities(); CloseHouseMarkers(); closeCircles(); if (!boundaries) { GetMapBoundaries(); } else { drawBoundaries(); } } else { showBoundaries = false; hideBoundary(); clearBoundaries(); window.setTimeout(function() {GetMapCities(map.getBounds(), map.getZoom());}, 100); if (SAID>0) { drawCircles(); ShowHouseMarkers(); } } if (userMap) scrollToListings(); } delete this.timeoutID; 
 } 
};function mapCaption(caption, cTop, cLeft) { var divSR = $('divSearchResults'); 
 var divM = $('divMap'); 
 if (caption && caption!='') { if (divSR && divM) { if (lastSearch) lastSearch = ''; divSR.style.width = ''; hidePopup.cancel(); divSR.innerHTML = caption; divSR.className='divMapCaption'; if (!cTop) cTop = GetTop(divM) - GetHeight(divSR); if (!cLeft) cLeft = Math.round(GetLeft(divM) + (GetWidth(divM) - GetWidth(divSR)) / 2); divSR.style.top = cTop + 'px'; divSR.style.left = cLeft + 'px'; } } else { if (divSR) divSR.className='hidden'; }}function MarkerManager(map, opt_opts) { var me = this; me.map_ = map; me.mapZoom_ = map.getZoom(); me.projection_ = map.getCurrentMapType().getProjection(); opt_opts = opt_opts || {}; me.tileSize_ = MarkerManager.DEFAULT_TILE_SIZE_; var mapTypes = map.getMapTypes(); var mapMaxZoom = mapTypes[0].getMaximumResolution(); for (var i = 0; i < mapTypes.length; i++) { var mapTypeMaxZoom = mapTypes[i].getMaximumResolution(); if (mapTypeMaxZoom > mapMaxZoom) { mapMaxZoom = mapTypeMaxZoom; } } me.maxZoom_ = opt_opts.maxZoom || mapMaxZoom; me.trackMarkers_ = opt_opts.trackMarkers; me.show_ = opt_opts.show || true; var padding; if (typeof opt_opts.borderPadding === "number") { padding = opt_opts.borderPadding; } else { padding = MarkerManager.DEFAULT_BORDER_PADDING_; } me.swPadding_ = new GSize(-padding, padding); me.nePadding_ = new GSize(padding, -padding); me.borderPadding_ = padding; me.gridWidth_ = []; me.grid_ = []; me.grid_[me.maxZoom_] = []; me.numMarkers_ = []; me.numMarkers_[me.maxZoom_] = 0; GEvent.bind(map, "moveend", me, me.onMapMoveEnd_); me.removeOverlay_ = function (marker) { map.removeOverlay(marker); me.shownMarkers_--; }; me.addOverlay_ = function (marker) { if (me.show_) { map.addOverlay(marker); me.shownMarkers_++; } }; me.resetManager_(); me.shownMarkers_ = 0; me.shownBounds_ = me.getMapGridBounds_();}MarkerManager.DEFAULT_TILE_SIZE_ = 1024;MarkerManager.DEFAULT_BORDER_PADDING_ = 100;MarkerManager.MERCATOR_ZOOM_LEVEL_ZERO_RANGE = 256;MarkerManager.prototype.resetManager_ = function () { var me = this; var mapWidth = MarkerManager.MERCATOR_ZOOM_LEVEL_ZERO_RANGE; for (var zoom = 0; zoom <= me.maxZoom_; ++zoom) { me.grid_[zoom] = []; me.numMarkers_[zoom] = 0; me.gridWidth_[zoom] = Math.ceil(mapWidth / me.tileSize_); mapWidth <<= 1; }};MarkerManager.prototype.clearMarkers = function () { var me = this; me.processAll_(me.shownBounds_, me.removeOverlay_); me.resetManager_();};MarkerManager.prototype.getTilePoint_ = function (latlng, zoom, padding) { var pixelPoint = this.projection_.fromLatLngToPixel(latlng, zoom); return new GPoint(
 Math.floor((pixelPoint.x + padding.width) / this.tileSize_), Math.floor((pixelPoint.y + padding.height) / this.tileSize_));};MarkerManager.prototype.addMarkerBatch_ = function (marker, minZoom, maxZoom) { var mPoint = marker.getPoint(); marker.MarkerManager_minZoom = minZoom; if (this.trackMarkers_) { GEvent.bind(marker, "changed", this, this.onMarkerMoved_); } var gridPoint = this.getTilePoint_(mPoint, maxZoom, GSize.ZERO); for (var zoom = maxZoom; zoom >= minZoom; zoom--) { var cell = this.getGridCellCreate_(gridPoint.x, gridPoint.y, zoom); cell.push(marker); gridPoint.x = gridPoint.x >> 1; gridPoint.y = gridPoint.y >> 1; }};MarkerManager.prototype.isGridPointVisible_ = function (point) { var me = this; var vertical = me.shownBounds_.minY <= point.y &&
 point.y <= me.shownBounds_.maxY; var minX = me.shownBounds_.minX; var horizontal = minX <= point.x && point.x <= me.shownBounds_.maxX; if (!horizontal && minX < 0) { var width = me.gridWidth_[me.shownBounds_.z]; horizontal = minX + width <= point.x && point.x <= width - 1; } return vertical && horizontal;};MarkerManager.prototype.onMarkerMoved_ = function (marker, oldPoint, newPoint) { var me = this; var zoom = me.maxZoom_; var changed = false; var oldGrid = me.getTilePoint_(oldPoint, zoom, GSize.ZERO); var newGrid = me.getTilePoint_(newPoint, zoom, GSize.ZERO); while (zoom >= 0 && (oldGrid.x !== newGrid.x || oldGrid.y !== newGrid.y)) { var cell = me.getGridCellNoCreate_(oldGrid.x, oldGrid.y, zoom); if (cell) { if (me.removeFromArray_(cell, marker)) { me.getGridCellCreate_(newGrid.x, newGrid.y, zoom).push(marker); } } if (zoom === me.mapZoom_) { if (me.isGridPointVisible_(oldGrid)) { if (!me.isGridPointVisible_(newGrid)) { me.removeOverlay_(marker); changed = true; } } else { if (me.isGridPointVisible_(newGrid)) { me.addOverlay_(marker); changed = true; } } } oldGrid.x = oldGrid.x >> 1; oldGrid.y = oldGrid.y >> 1; newGrid.x = newGrid.x >> 1; newGrid.y = newGrid.y >> 1; --zoom; } if (changed) { me.notifyListeners_(); }};MarkerManager.prototype.removeMarker = function (marker) { var me = this; var zoom = me.maxZoom_; var changed = false; var point = marker.getPoint(); var grid = me.getTilePoint_(point, zoom, GSize.ZERO); while (zoom >= 0) { var cell = me.getGridCellNoCreate_(grid.x, grid.y, zoom); if (cell) { me.removeFromArray_(cell, marker); } if (zoom === me.mapZoom_) { if (me.isGridPointVisible_(grid)) { me.removeOverlay_(marker); changed = true; } } grid.x = grid.x >> 1; grid.y = grid.y >> 1; --zoom; } if (changed) { me.notifyListeners_(); } me.numMarkers_[marker.MarkerManager_minZoom]--;};MarkerManager.prototype.addMarkers = function (markers, minZoom, opt_maxZoom) { var maxZoom = this.getOptMaxZoom_(opt_maxZoom); for (var i = markers.length - 1; i >= 0; i--) { this.addMarkerBatch_(markers[i], minZoom, maxZoom); } this.numMarkers_[minZoom] += markers.length;};MarkerManager.prototype.getOptMaxZoom_ = function (opt_maxZoom) { return opt_maxZoom || this.maxZoom_;};MarkerManager.prototype.getMarkerCount = function (zoom) { var total = 0; for (var z = 0; z <= zoom; z++) { total += this.numMarkers_[z]; } return total;};MarkerManager.prototype.getMarker = function(lat, lng, zoom) { 
 var me = this; 
 var mPoint = new GLatLng(lat, lng); 
 var gridPoint = me.getTilePoint_(mPoint, zoom, GSize.ZERO); 
 var marker = new GMarker(mPoint); 
 var cellArray = me.getGridCellNoCreate_(gridPoint.x, gridPoint.y, zoom); 
 if(cellArray != undefined){ 
 for (var i = 0; i < cellArray.length; i++) 
 { 
 if(lat == cellArray[i].getLatLng().lat() && 
 lng == cellArray[i].getLatLng().lng()) 
 { 
 marker = cellArray[i]; 
 } 
 } 
 } 
 return marker; 
}; 
MarkerManager.prototype.addMarker = function (marker, minZoom, opt_maxZoom) { var me = this; var maxZoom = this.getOptMaxZoom_(opt_maxZoom); me.addMarkerBatch_(marker, minZoom, maxZoom); var gridPoint = me.getTilePoint_(marker.getPoint(), me.mapZoom_, GSize.ZERO); if (me.isGridPointVisible_(gridPoint) &&
 minZoom <= me.shownBounds_.z &&
 me.shownBounds_.z <= maxZoom) { me.addOverlay_(marker); me.notifyListeners_(); } this.numMarkers_[minZoom]++;};GBounds.prototype.containsPoint = function (point) { var outer = this; return (outer.minX <= point.x &&
 outer.maxX >= point.x &&
 outer.minY <= point.y &&
 outer.maxY >= point.y);};MarkerManager.prototype.getGridCellCreate_ = function (x, y, z) { var grid = this.grid_[z]; if (x < 0) { x += this.gridWidth_[z]; } var gridCol = grid[x]; if (!gridCol) { gridCol = grid[x] = []; return (gridCol[y] = []); } var gridCell = gridCol[y]; if (!gridCell) { return (gridCol[y] = []); } return gridCell;};MarkerManager.prototype.getGridCellNoCreate_ = function (x, y, z) { var grid = this.grid_[z]; if (x < 0) { x += this.gridWidth_[z]; } var gridCol = grid[x]; return gridCol ? gridCol[y] : undefined;};MarkerManager.prototype.getGridBounds_ = function (bounds, zoom, swPadding, nePadding) { zoom = Math.min(zoom, this.maxZoom_); var bl = bounds.getSouthWest(); var tr = bounds.getNorthEast(); var sw = this.getTilePoint_(bl, zoom, swPadding); var ne = this.getTilePoint_(tr, zoom, nePadding); var gw = this.gridWidth_[zoom]; if (tr.lng() < bl.lng() || ne.x < sw.x) { sw.x -= gw; } if (ne.x - sw.x + 1 >= gw) { sw.x = 0; ne.x = gw - 1; } var gridBounds = new GBounds([sw, ne]); gridBounds.z = zoom; return gridBounds;};MarkerManager.prototype.getMapGridBounds_ = function () { var me = this; return me.getGridBounds_(me.map_.getBounds(), me.mapZoom_, me.swPadding_, me.nePadding_);};MarkerManager.prototype.onMapMoveEnd_ = function () { var me = this; me.objectSetTimeout_(this, this.updateMarkers_, 0);};MarkerManager.prototype.objectSetTimeout_ = function (object, command, milliseconds) { return window.setTimeout(function () { command.call(object); }, milliseconds);};MarkerManager.prototype.visible = function () { return this.show_ ? true : false;};MarkerManager.prototype.isHidden = function () { return !this.show_;};MarkerManager.prototype.show = function () { this.show_ = true; this.refresh();};MarkerManager.prototype.hide = function () { this.show_ = false; this.refresh();};MarkerManager.prototype.toggle = function () { this.show_ = !this.show_; this.refresh();};MarkerManager.prototype.refresh = function () { var me = this; if (me.shownMarkers_ > 0) { me.processAll_(me.shownBounds_, me.removeOverlay_); } if (me.show_) { me.processAll_(me.shownBounds_, me.addOverlay_); } me.notifyListeners_();};MarkerManager.prototype.updateMarkers_ = function () { var me = this; me.mapZoom_ = this.map_.getZoom(); var newBounds = me.getMapGridBounds_(); if (newBounds.equals(me.shownBounds_) && newBounds.z === me.shownBounds_.z) { return; } if (newBounds.z !== me.shownBounds_.z) { me.processAll_(me.shownBounds_, me.removeOverlay_); if (me.show_) { me.processAll_(newBounds, me.addOverlay_); } } else { me.rectangleDiff_(me.shownBounds_, newBounds, me.removeCellMarkers_); if (me.show_) { me.rectangleDiff_(newBounds, me.shownBounds_, me.addCellMarkers_); } } me.shownBounds_ = newBounds; me.notifyListeners_();};MarkerManager.prototype.notifyListeners_ = function () { GEvent.trigger(this, "changed", this.shownBounds_, this.shownMarkers_);};MarkerManager.prototype.processAll_ = function (bounds, callback) { for (var x = bounds.minX; x <= bounds.maxX; x++) { for (var y = bounds.minY; y <= bounds.maxY; y++) { this.processCellMarkers_(x, y, bounds.z, callback); } }};MarkerManager.prototype.processCellMarkers_ = function (x, y, z, callback) { var cell = this.getGridCellNoCreate_(x, y, z); if (cell) { for (var i = cell.length - 1; i >= 0; i--) { callback(cell[i]); } }};MarkerManager.prototype.removeCellMarkers_ = function (x, y, z) { this.processCellMarkers_(x, y, z, this.removeOverlay_);};MarkerManager.prototype.addCellMarkers_ = function (x, y, z) { this.processCellMarkers_(x, y, z, this.addOverlay_);};MarkerManager.prototype.rectangleDiff_ = function (bounds1, bounds2, callback) { var me = this; me.rectangleDiffCoords_(bounds1, bounds2, function (x, y) { callback.apply(me, [x, y, bounds1.z]); });};MarkerManager.prototype.rectangleDiffCoords_ = function (bounds1, bounds2, callback) { var minX1 = bounds1.minX; var minY1 = bounds1.minY; var maxX1 = bounds1.maxX; var maxY1 = bounds1.maxY; var minX2 = bounds2.minX; var minY2 = bounds2.minY; var maxX2 = bounds2.maxX; var maxY2 = bounds2.maxY; var x, y; for (x = minX1; x <= maxX1; x++) { for (y = minY1; y <= maxY1 && y < minY2; y++) { callback(x, y); } for (y = Math.max(maxY2 + 1, minY1); y <= maxY1; y++) { callback(x, y); } } for (y = Math.max(minY1, minY2); y <= Math.min(maxY1, maxY2); y++) { for (x = Math.min(maxX1 + 1, minX2) - 1; x >= minX1; x--) { callback(x, y); } for (x = Math.max(minX1, maxX2 + 1); x <= maxX1; x++) { callback(x, y); } }};MarkerManager.prototype.removeFromArray_ = function (array, value, opt_notype) { var shift = 0; for (var i = 0; i < array.length; ++i) { if (array[i] === value || (opt_notype && array[i] === value)) { array.splice(i--, 1); shift++; } } return shift;};var borderPoints = Array();var borderPoly;var boundaries;function createBoundary(boundaryindex, name, points) { borderPoints = Array(); for (var i = 0;i < points.length;i=i+2) { borderPoints.push(new GLatLng(points[i], points[i+1])); } boundaries[boundaryindex] = new Object; boundaries[boundaryindex].borderPoints = borderPoints; boundaries[boundaryindex].name = name;}function drawBoundaries() { loadMap(); 
 if (map && boundaries && boundaries.length > 0) { for (var i in boundaries) { if (boundaries[i].borderPoints && boundaries[i].borderPoints.length > 0) { if (!boundaries[i].borderPoly) { 
 boundaries[i].borderPoly = new GPolygon(boundaries[i].borderPoints,'#0000FF',1,.1,'#0000FF',.1,{clickable:true,mouseOutTolerance:1}); boundaries[i].borderPoly.index = i; GEvent.addListener(boundaries[i].borderPoly, "mouseover", function () { map.getDragObject().setDraggableCursor('pointer'); showBoundary(this.index); } ); GEvent.addListener(boundaries[i].borderPoly, "mouseout", function () { map.getDragObject().setDraggableCursor("url(http://maps.google.com/intl/en_us/mapfiles/openhand.cur),default"); hideBoundary(); } ); map.addOverlay(boundaries[i].borderPoly); } } } }}function showBoundary(i) { if (map && !LoadingMsg.showing()) { if (borderPoly) map.removeOverlay(borderPoly); if (boundaries[i] && boundaries[i].borderPoints && boundaries[i].borderPoints.length > 0) { borderPoly = new GPolygon(boundaries[i].borderPoints,'#0000FF',1,.99,'#0000FF',.15); map.addOverlay(borderPoly); borderPoly.index = i; GEvent.addListener(borderPoly, "click", function () { clickBoundary(this.index); } ); map.buttonMode = true; if (boundaries[i].name) mapCaption(boundaries[i].name); } }}function hideBoundary() { if (map && borderPoly && !LoadingMsg.showing()) { map.removeOverlay(borderPoly); borderPoly = null; hidePopup.init(10); }}function clickBoundary(i) { if (boundaries[i] && !LoadingMsg.showing()) { ClickBoundary(i); if (boundaries[i].borderPoints && boundaries[i].borderPoints.length > 0) { var lat = 0; var lng = 0; for(var j=0;j<boundaries[i].borderPoints.length;j++){ lat+=boundaries[i].borderPoints[j].lat(); lng+=boundaries[i].borderPoints[j].lng(); } lat=lat/boundaries[i].borderPoints.length; lng=lng/boundaries[i].borderPoints.length; map.panTo(new GLatLng(lat,lng)); } if (boundaries[i].name) LoadingMsg.init('Loading Data for <br/><b>' + boundaries[i].name + '</b>', 'divMap', 0); }}function clearBoundaries() { loadMap(); 
 if (map && boundaries && boundaries.length > 0) { for (var i in boundaries) { if (boundaries[i].borderPoly) { map.removeOverlay(boundaries[i].borderPoly); boundaries[i].borderPoly = null; } } }}var totalCitySearches = 0;var CityMarkers = [];var cityM = false;function AddCityMarker(i, name, Latitude, Longitude, Listings) { loadMap(); if (map) { if (!cityM) cityM = new MarkerManager(map); if (!CityMarkers[i]) CityMarkers[i] = new CityMarker(i, name, Latitude, Longitude, Listings); else if (CityMarkers[i].marker && !CityMarkers[i].added) cityM.addMarker(CityMarkers[i].marker, 1, 17); }}function CityMarker(i, name, lat, lng, Listings) { if (!lat) lat = 0; if (!lng) lng = 0; var cityIcon = new GIcon(); cityIcon.image = "/images/city_marker.png"; cityIcon.iconSize = new GSize(12,12); cityIcon.iconAnchor = new GLatLng(6, 6); this.marker = new GMarker(new GLatLng(lat, lng), cityIcon); 
 this.marker.name = name; this.marker.SAID = i; GEvent.addListener(this.marker, 'mouseover', function() { this.setImage('/images/city_marker_selected.png'); if (!LoadingMsg.showing()) { var divM = $('divMap'); if (map && divM) { mapCaption(this.name, GetTop(divM) + map.fromLatLngToContainerPixel(this.getLatLng()).y - 15, GetLeft(divM) + map.fromLatLngToContainerPixel(this.getLatLng()).x + 15); } } } ); GEvent.addListener(this.marker, 'mouseout', function() { this.setImage('/images/city_marker.png'); if (!LoadingMsg.showing()) hidePopup.init(10) } ); GEvent.addListener(this.marker, 'click', function() { clickCity( this.SAID ) } ); cityM.addMarker(this.marker, 1, 17); this.added = true;}function ShowCities() { loadMap(); if (map) { if (cityM) { 
 for (var i in CityMarkers){ if (CityMarkers[i]) { for (var index in circles) { if (circles[index] && circles[index].point) { if (CityMarkers[i].marker && CityMarkers[i].marker.getLatLng().distanceFrom(circles[index].point) / 1000 / milesTokm <= circles[index].radius) { try{cityM.removeMarker(CityMarkers[i].marker);} catch(err) {} CityMarkers[i].added = false; } } } } } cityM.show(); } }}function ClearCities() { loadMap(); if (map) 
 if (cityM) cityM.hide();}function clickCity(i) { if (CityMarkers[i] && !LoadingMsg.showing()) { ClickCity(i); if (CityMarkers[i].lat && CityMarkers[i].lng) map.panTo(new GLatLng(CityMarkers[i].lat,CityMarkers[i].lng)); if (CityMarkers[i].marker && CityMarkers[i].marker.name) LoadingMsg.init('Loading Data for <br/><b>' + CityMarkers[i].marker.name + '</b>', 'divMap', 0); }}var Markers = [];var lastMarker;var GettingCoords=0;var minDistToSA = 100;var hM1 = '/images/house1.gif';var hM2 = '/images/house2.gif';var hM3 = '/images/house3.gif';var hM4 = '/images/house4.gif';function Marker(ID, lat, lng, SearchID, Address, LatLngName, isFav, CountryCD, StateProvinceCD, dLat, dLng) { if (!lat) lat = 0; if (!lng) lng = 0; if (!dLat) dLat = 0; if (!dLng) dLng = 0; if (!Address) Address=''; if (!LatLngName) LatLngName=''; if (!isFav) isFav=0; this.id = ID; this.lat = lat; this.lng = lng; this.dLat = dLat; this.dLng = dLng; this.CountryCD = CountryCD; this.StateProvinceCD = StateProvinceCD; this.SearchID = SearchID; this.Address = Address; this.LatLngName = LatLngName; this.isFav=isFav; this.importance=0; this.marker=null; 
}function addHouseMarker(ListingID, Latitude, Longitude, SearchID, Address, LatLngName, isFav, CountryCD, StateProvinceCD, dLat, dLng) { if (!Markers[ListingID]) 
 Markers[ListingID] = new Marker(ListingID, Latitude, Longitude, SearchID, Address, LatLngName, isFav, CountryCD, StateProvinceCD, dLat, dLng);}function importanceOrder (marker,b) { 
 return marker.importance; 
} 
function ResetLastMarker(newMarker) { if (newMarker && lastMarker) { if (newMarker == lastMarker) return 0; } if (lastMarker) { if (lastMarker) { lastMarker.importance=0; if (lastMarker.marker) { if (!lastMarker.marker.isHidden()) { try { if (lastMarker.isFav==1) { lastMarker.marker.setImage(hM3); 
 } else { lastMarker.marker.setImage(hM1); 
 } lastMarker.marker.disableDragging(); } catch(err) { 
 } } } } delete lastMarker; } lastMarker=newMarker;}function CloseHouseMarkers(index, remove) { ResetLastMarker(); var RemoveOverlay = 0; for (markerindex in Markers) { if (Markers[markerindex].marker) { RemoveOverLay = 1; if (Markers[markerindex].SearchID) if (index) if (Markers[markerindex].SearchID==index) if (Markers[markerindex].marker) RemoveOverLay = 1; else
 RemoveOverLay = 1; else
 RemoveOverLay = 1; if (RemoveOverLay == 1) { map.removeOverlay(Markers[markerindex].marker); if (remove) delete Markers[markerindex]; } } }}function ShowHouseMarkers() { loadMap(); if (map){ var markCount = 0; for (markerindex in Markers) { if (Markers[markerindex].id) { if (!Markers[markerindex].shown) Markers[markerindex].shown=false; if (Markers[markerindex].lat!=0 && Markers[markerindex].lng!=0) { var IsInSearch = false; var Lpoint = new GLatLng(Markers[markerindex].lat, Markers[markerindex].lng); if (mapPoint) { Markers[markerindex].Dist = Lpoint.distanceFrom(mapPoint); } else { Markers[markerindex].Dist = 0; } Markers[markerindex].SearchID=-1; var mbounds = map.getBounds(); if (mbounds.containsLatLng(Lpoint)) { if (Markers[markerindex].isFav==1) { IsInSearch = true; } else { for (var index in circles) { if (circles[index].point) { if (Lpoint.distanceFrom(circles[index].point) / 1000 / milesTokm <= circles[index].radius) { Markers[markerindex].SearchID=index; IsInSearch=true; } } } } } else { 
 IsInSearch=false; } if (IsInSearch==true) { Markers[markerindex].enabled=true; } else { Markers[markerindex].enabled=false; } if (Markers[markerindex].enabled==true) markCount = markCount + 1; } } } for (markerindex in Markers) { if (!Markers[markerindex].enabled) Markers[markerindex].enabled = false; 
 if (Markers[markerindex].enabled==true && Markers[markerindex].shown==false) { showHouseMarker(Markers[markerindex]); } else if (Markers[markerindex].enabled==false && Markers[markerindex].shown==true) { map.removeOverlay(Markers[markerindex].marker); Markers[markerindex].shown=false; } else if (Markers[markerindex].enabled==false && Markers[markerindex].shown==false) { if (Markers[markerindex].lat!=0 && Markers[markerindex].lng!=0) delete Markers[markerindex]; } } getHouseCoords(); }}function houseIcon() { var mapIcon = new GIcon(); mapIcon.image = hM1; mapIcon.shadow = "http://misc.leadingre.com/RHS2/images/house_shadow.png"; mapIcon.iconSize = new GSize(25,22); mapIcon.shadowSize = new GSize(25,22); mapIcon.iconAnchor = new GLatLng(25, 22); return mapIcon;}function showHouseMarker(marker, reset) { if (marker && map) { if (marker.marker) { if (reset==1 || marker.marker.importance<marker.importance) { map.removeOverlay(marker.marker); marker.shown=false; delete marker.marker; } } if (!marker.marker && marker.lat!=0 && marker.lng!=0) { marker.marker = new GMarker(new GLatLng(marker.lat, marker.lng),{icon:houseIcon(), zIndexProcess:importanceOrder, draggable:false}); marker.marker.importance=marker.importance; } 
 if (marker.marker) { if (marker.marker.getIcon) { if (!marker.shown) { map.addOverlay(marker.marker); if (marker.id) { GEvent.addListener(marker.marker, 'click', function() { if (lastMarker!=marker) showListing(marker.id, marker.CountryCD, marker.StateProvinceCD ); } ); } if (marker.id==llID && marker.isFav==1) { 
 marker.marker.setImage(hM4); } else if (marker.id==llID) { 
 marker.marker.setImage(hM2); } else if (marker.isFav==1) { 
 marker.marker.setImage(hM3); } else { 
 marker.marker.setImage(hM1); } marker.shown=true; } } } }}function getHouseCoords(AutoCycle) { if (AutoCycle || GettingCoords==0) { GettingCoords=1; for (var ID in Markers) { if (!Markers[ID].LatLngCheck) { Markers[ID].LatLngCheck=true; if (Markers[ID].Address!='' && (Markers[ID].lat==0 || Markers[ID].lng==0)) { getAddressCoords(Markers[ID].Address, Markers[ID].LatLngName, ID); window.setTimeout(function () { getHouseCoords(1); } ,500); GettingCoords=0; return 0; 
 } } } } GettingCoords=0;}function getAddressCoords(Address, LatLngName, MarkerID, newZoom, Lat, Lng, Radius) { var geocoder = new GClientGeocoder(); geocoder.getLatLng(
 Address
 , function(point) { if (point) { if (Markers[MarkerID] && map.isLoaded()) { if (point.distanceFrom( new GLatLng(Markers[MarkerID].dLat, Markers[MarkerID].dLng) ) / 1000 / milesTokm <= minDistToSA) { Markers[MarkerID].lat = point.lat(); Markers[MarkerID].lng = point.lng(); if (Markers[MarkerID].marker) { map.removeOverlay(Markers[MarkerID].marker); Markers[MarkerID].shown=false; Markers[MarkerID].marker.setLatLng(point); } 
 showHouseMarker(Markers[MarkerID]); } else { LatLngName = ''; } } else if (newZoom) { loadMap(); if (map) 
 map.setCenter(point, newZoom); } if (!LatLngName) LatLngName=''; if (LatLngName!='') { SaveLatLng(LatLngName, point); } } } );}var circles = [];var dragcircle = -1;var selectedcircle;var circleRadius = 10;function createCircle(index, point, radius, color, zoomToCircle) { if (circles[index]) { mouseoutCircle(index); map.removeOverlay(circles[index].polygon); CloseHouseMarkers(index); delete circles[index]; } CloseHouseMarkers(-1); circles[index] = new Object; circles[index].radius = radius; circles[index].point = point; circles[index].color = color; circleRadius = radius; showMapMarkers.init(); if (zoomToCircle) if (zoomToCircle==1) zoomToSearchRadius(index); 
}function drawCircles() { for (var index in circles) { if (circles[index] && circles[index].point) 
 drawCircle(index); } ShowCities();}function drawCircle(index) { loadMap(); 
 if (map) { var polyPoints = Array(); var polyNumSides = 43; if (uBrowser.indexOf('Explorer') >= 0) polyNumSides = 27; var polySideLength = 360 / polyNumSides; var latConv = circles[index].point.distanceFrom(new GLatLng(circles[index].point.lat()+0.1, circles[index].point.lng()))/100/milesTokm; var lngConv = circles[index].point.distanceFrom(new GLatLng(circles[index].point.lat(), circles[index].point.lng()+0.1))/100/milesTokm; if (circles[index] && circles[index].polygon) { if (!circles[index].show) { map.addOverlay(circles[index].polygon); } } else { for (var a = 0; a<(polyNumSides+1); a++) { var aRad = polySideLength*a*(Math.PI/180); var polyPoint = new GLatLng(circles[index].point.lat() + (circles[index].radius / latConv * Math.cos(aRad)), circles[index].point.lng() + (circles[index].radius / lngConv * Math.sin(aRad))); polyPoints.push(polyPoint); } circles[index].polygon = new GPolygon(polyPoints,circles[index].color,1,.35,circles[index].color,.07); circles[index].polygon.index = index; map.addOverlay(circles[index].polygon); circles[index].closepoint = new GLatLng(circles[index].point.lat() + (circles[index].radius / latConv), circles[index].point.lng()); circles[index].radiuspoint = new GLatLng(circles[index].point.lat(), circles[index].point.lng() + (circles[index].radius / lngConv)); } circles[index].show = true; mouseoverCircle(index); }}var DrawCircle = { draw: function() { drawCircle(this.index); delete this.timeoutID; this.index=-1; } ,init: function(circleIndex) {this.cancel(); var self = this; hideCircle(circleIndex); this.index=circleIndex; this.timeoutID = window.setTimeout(function() {self.draw();} , 250); } ,cancel: function() { if(typeof this.timeoutID == "number") {window.clearTimeout(this.timeoutID);delete this.timeoutID;}}};function zoomToSearchRadius(SearchID) { loadMap(); if (map) { if (circles[SearchID]) { if (circles[SearchID].point) { var Lat1 = circles[SearchID].point.lat() - circles[SearchID].radius / 60; var Lat2 = circles[SearchID].point.lat() + circles[SearchID].radius / 60; var Lng1 = circles[SearchID].point.lng() - circles[SearchID].radius / 60; var Lng2 = circles[SearchID].point.lng() + circles[SearchID].radius / 60; var bnds = new GLatLngBounds(new GLatLng(Lat1,Lng1), new GLatLng(Lat2,Lng2)); var zoomLevel = map.getBoundsZoomLevel(bnds); map.setCenter(circles[SearchID].point,zoomLevel); } } }}function closeCircles() { if (circles && circles.length>0) { for (var index in circles) { closeCircle(index); } }}function closeCircle(index, removeSearch) { if (circles[index]) { mouseoutCircle(index); if (circles[index].polygon && circles[index].show) { map.removeOverlay(circles[index].polygon); circles[index].show = false; } CloseHouseMarkers(index, removeSearch); if (removeSearch) { delete circles[index]; RemoveSearch(index); } }}function hideCircle(index) { if (circles[index]) if (circles[index].polygon) circles[index].polygon.hide();}function dragCircle(index) { dragcircle = index; circles[index].point = mapPoint; if (circles[index].closeicon) map.removeOverlay(circles[index].closeicon); if (circles[index].radiusicon) map.removeOverlay(circles[index].radiusicon); DrawCircle.init(index); mouseoverCircle(index);}function dragRadius(index) { dragcircle = index; circles[index].radius = circles[index].point.distanceFrom(mapPoint)/1000/milesTokm; if (circles[index].radius>50) { circles[index].radius=50; window.setTimeout('dragendCircle(' + index + ')',50); } mradius = circles[index].radius; if (circles[index].closeicon) map.removeOverlay(circles[index].closeicon); if (circles[index].moveicon) map.removeOverlay(circles[index].moveicon); DrawCircle.init(index); mouseoverCircle(index);}function dragendCircle(index) { dragcircle = -1; if (circles[index].radiusicon) map.removeOverlay(circles[index].radiusicon); if (circles[index].moveicon) map.removeOverlay(circles[index].moveicon); drawCircle(index); var mpoint = circles[index].point; var mlat = mpoint.lat(); var mlng = mpoint.lng(); UpdateSearch(index, mlat, mlng, circles[index].radius);}function circleIcon(Image, xOffset, yOffset) { if (!xOffset) xOffset=0; if (!yOffset) yOffset=0; cmIcon = new GIcon(); cmIcon.image = Image; cmIcon.iconSize = new GSize(21,17); cmIcon.shadowSize = new GSize(0, 0); cmIcon.iconAnchor = new GPoint(xOffset, yOffset); return cmIcon;}function mouseoverCircle(index) { selectedcircle = index; if (dragcircle!=index) { loadMap(); if (map && circles[index]) { if (mapOptions) { circles[index].moveicon = new GMarker(circles[index].point,{icon:circleIcon('http://misc.leadingre.com/RHS2/images/centerArrow1.gif',11,9), zIndexProcess:importanceOrder, draggable:true}); 
 circles[index].moveicon.importance = 99999; circles[index].moveicon.index = index; GEvent.addListener(circles[index].moveicon, "click", function() { zoomToSearchRadius(this.index);}); GEvent.addListener(circles[index].moveicon, "drag", function(point) {dragCircle(this.index);}); GEvent.addListener(circles[index].moveicon, "dragend", function() {dragendCircle(this.index);}); GEvent.addListener(circles[index].moveicon, "mouseover", function() {this.setImage('http://misc.leadingre.com/RHS2/images/centerArrow2.gif');}); GEvent.addListener(circles[index].moveicon, "mouseout", function() {this.setImage('http://misc.leadingre.com/RHS2/images/centerArrow1.gif');}); map.addOverlay(circles[index].moveicon); circles[index].radiusicon = new GMarker(circles[index].radiuspoint,{icon:circleIcon('http://misc.leadingre.com/RHS2/images/resize_radius1.gif',22,9), zIndexProcess:importanceOrder, draggable:true, autoPan:false}); 
 circles[index].radiusicon.importance = 9999; circles[index].radiusicon.index = index; GEvent.addListener(circles[index].radiusicon, "click", function() {zoomToSearchRadius(this.index);}); GEvent.addListener(circles[index].radiusicon, "drag", function(point) {dragRadius(this.index);}); GEvent.addListener(circles[index].radiusicon, "dragend", function() {dragendCircle(this.index);}); GEvent.addListener(circles[index].radiusicon, "mouseover", function() {this.setImage('http://misc.leadingre.com/RHS2/images/resize_radius2.gif');}); GEvent.addListener(circles[index].radiusicon, "mouseout", function() {this.setImage('http://misc.leadingre.com/RHS2/images/resize_radius1.gif');}); map.addOverlay(circles[index].radiusicon); if (circles.length > 2) { circles[index].closeicon = new GMarker(circles[index].closepoint,{icon:circleIcon('http://misc.leadingre.com/RHS2/images/close_button1.gif',11,-2), zIndexProcess:importanceOrder}); 
 circles[index].closeicon.importance = 999; circles[index].closeicon.index = index; GEvent.addListener(circles[index].closeicon, "click", function() {closeCircle(this.index, 1);}); GEvent.addListener(circles[index].closeicon, "mouseover", function() {this.setImage('http://misc.leadingre.com/RHS2/images/close_button2.gif');}); GEvent.addListener(circles[index].closeicon, "mouseout", function() {this.setImage('http://misc.leadingre.com/RHS2/images/close_button1.gif');}); map.addOverlay(circles[index].closeicon); } } 
 if ($('searchcenter' + index)) { var searchcenter = $('searchcenter' + index); searchcenter.className = 'searchcenter_selected'; } } }}function mouseoutCircle(index) { loadMap(); if (map) { delete selectedcircle; if (dragcircle!=index) { if (circles[index]) { if (circles[index].moveicon) map.removeOverlay(circles[index].moveicon); if (circles[index].closeicon) map.removeOverlay(circles[index].closeicon); if (circles[index].radiusicon) map.removeOverlay(circles[index].radiusicon); } } if ($('searchcenter' + index)) { var searchcenter = $('searchcenter' + index); searchcenter.className = 'searchcenter'; } }}var totalSchoolSearches = 0;var SchoolMarkers = [];function AddSchoolMarker(id, name, Latitude, Longitude, pin) { loadMap(); if (map) if (!SchoolMarkers[id]) 
 SchoolMarkers[id] = new SchoolMarker(id, name, Latitude, Longitude, pin); else
 SchoolMarkers[id].pin = pin;}function SchoolMarker(id, name, lat, lng, pin) { if (!lat) lat = 0; if (!lng) lng = 0; var schoolIcon = new GIcon(); schoolIcon.image = "/images/School.gif"; schoolIcon.iconSize = new GSize(25,35); schoolIcon.shadowSize = new GSize(25, 35); schoolIcon.iconAnchor = new GLatLng(12, 35); this.id = id; this.lat = lat; this.lng = lng; this.marker = new GMarker(new GLatLng(lat, lng),schoolIcon); 
 this.marker.name = name; this.pin = pin;}function ShowSchools() { for (var id in SchoolMarkers){ if (SchoolMarkers[id].marker){ if (SchoolMarkers[id].pin==1) showSchool(id, 1); else
 showSchool(id, 0); } }}function showSchool(id, show){ loadMap(); if (map) { if (SchoolMarkers[id].marker.getIcon) { map.removeOverlay(SchoolMarkers[id].marker); if (show && show==1){ SchoolMarkers[id].marker.setLatLng(new GLatLng(SchoolMarkers[id].lat, SchoolMarkers[id].lng)); if (map.getBounds().containsLatLng(SchoolMarkers[id].marker.getLatLng())) { map.addOverlay(SchoolMarkers[id].marker); SchoolMarkers[id].marker.id = id; GEvent.addListener(SchoolMarkers[id].marker, 'mouseover', function() { schoolCaption(this.id); } ); GEvent.addListener(SchoolMarkers[id].marker, 'mouseout', function() { schoolCaption(); } ); } } } }}function schoolCaption(id) { loadMap(); if (map){ if (!LoadingMsg.showing()) { 
 if (SchoolMarkers[id] && SchoolMarkers[id].marker) { var divM = $('divMap'); if (map && divM) { if (map.getBounds().containsLatLng(SchoolMarkers[id].marker.getLatLng())) { mapCaption(SchoolMarkers[id].marker.name, GetTop(divM) + map.fromLatLngToContainerPixel(SchoolMarkers[id].marker.getLatLng()).y - 15, GetLeft(divM) + map.fromLatLngToContainerPixel(SchoolMarkers[id].marker.getLatLng()).x - 10); } } } else { hidePopup.init(10) } } }}function ClearSchools(ID) { loadMap(); if (!ID) ID=0; if (map) { for (var id in SchoolMarkers) { if ((id==0||id==ID)&&SchoolMarkers[id].marker){ map.removeOverlay(SchoolMarkers[id].marker); SchoolMarkers[id].pin=0; } } }}var MaxResultsPosition = 0;var PricePoints;var innerSlideWidth = 0;var lastSlidePos = 0;var lastListingPos = 0;var mouseDown = 0;function SetSlidePosition(pos){ var divOuterSlide = $('divOuterSlide'); var divInnerSlide = $('divInnerSlide'); if (divOuterSlide && divInnerSlide) { lastSlidePos = Math.round(pos * (GetWidth(divInnerSlide) - GetWidth(divOuterSlide))); if (lastSlidePos < 0) lastSlidePos = 0; if (lastSlidePos > GetWidth(divInnerSlide) - GetWidth(divOuterSlide)) lastSlidePos = GetWidth(divInnerSlide) - GetWidth(divOuterSlide); lastListingPos = lastSlidePos; divOuterSlide.scrollLeft = lastSlidePos; } 
}function ScrollListings(){ var divOuterSlide = $('divOuterSlide'); if (divOuterSlide){ var newPos = divOuterSlide.scrollLeft; if (lastSlidePos!=newPos) { lastSlidePos = newPos; listingsSlide.init(); updateSliding(newPos); } }}function MoveSlideResults(movePos, newPos) { if (!LoadingMsg.showing()) LoadingMsg.init('Loading property listings...', 'divSlideResults', 500); divSlideResults(movePos, newPos);}function updateSliding(newPos){ var msg = 'Loading property listings...'; var divOuterSlide = $('divOuterSlide'); var divInnerSlide = $('divInnerSlide'); if (PricePoints && divOuterSlide && divInnerSlide) { var priceIndex = Math.round(newPos / (GetWidth(divInnerSlide) - GetWidth(divOuterSlide)) * 100); if (PricePoints[priceIndex]) 
 if (PricePoints[priceIndex]!='') 
 msg = 'Loading properties in the<br /><b>' + PricePoints[priceIndex] + '</b> price range.'; } LoadingMsg.init(msg, 'divSlideResults', 500);}var listingsSlide = { go: function() {continueSliding();delete this.timeoutID;} ,init: function() {this.cancel(); var self = this; this.timeoutID = window.setTimeout(function() {self.go();}, 300);} ,cancel: function() {if(typeof this.timeoutID == "number") {window.clearTimeout(this.timeoutID);delete this.timeoutID;}}};function setMouseState(mouseState){ mouseDown=mouseState;}function continueSliding(){ if (mouseDown==0) doneSliding(); else
 listingsSlide.init();}function doneSliding(){ var divOuterSlide = $('divOuterSlide'); var divInnerSlide = $('divInnerSlide'); if (divOuterSlide && divInnerSlide) { if (Math.abs(lastListingPos - lastSlidePos) <= GetWidth(divOuterSlide) * 1.1){ if (lastListingPos < lastSlidePos){ MoveSlideResults(lrpp, 0); } else if (lastListingPos > lastSlidePos){ MoveSlideResults(-1 * lrpp, 0); } else { MoveSlideResults(1, 0); } } else { MoveSlideResults(0, Math.round(lastSlidePos / (GetWidth(divInnerSlide) - GetWidth(divOuterSlide)) * MaxResultsPosition)); } } else { MoveSlideResults(1, 0); } listingsSlide.cancel(); lastListingPos = lastSlidePos;}function showSpotPrice(price) { var divSpotPrice = $('divSpotPrice'); var tdSpotPrice = $('tdSpotPrice'); var divSpotlight = $('divSpotlight'); if (divSpotPrice && tdSpotPrice && divSpotlight) { if (price && price!='') { divSpotPrice.style.opacity = 0.01; divSpotPrice.style.filter = 'alpha(opacity=01)'; divSpotPrice.className = ''; tdSpotPrice.innerHTML = price; divSpotPrice.style.top = GetTop(divSpotlight) + 35 + 'px'; divSpotPrice.style.left = GetLeft(divSpotlight) + GetWidth(divSpotlight) * 0.95 - GetWidth(divSpotPrice) + 'px'; RHSStartSlide('divSpotPrice', 'opacity', 0, 1, 50, 5); } else { divSpotPrice.className = 'hidden'; } }}function SizeSpotlightImage() { var divSpotlight = $('divSpotlight'); var imgSpotlight = $('imgSpotlight'); var divImgSpotlight = $('divImgSpotlight'); if (divSpotlight && imgSpotlight) { imgSpotlight.style.width = ''; imgSpotlight.style.height = ''; var maxheight = 500; var maxwidth = Math.round(GetWidth(divSpotlight)*0.9); var listingimagewidth = Math.round(GetWidth(divSpotlight)*0.9); 
 var listingimageheight = maxheight; 
 for( i=0; i < document.images.length; i++) 
 { 
 if (document.images[i].id == 'imgSpotlight') { listingimagewidth = document.images[i].width; 
 listingimageheight = document.images[i].height; 
 } } 
 if (listingimageheight > maxheight) { imgSpotlight.style.height = maxheight + 'px'; listingimagewidth = listingimagewidth * maxheight / listingimageheight; listingimageheight = maxheight; imgSpotlight.style.width = listingimagewidth + 'px'; } else { imgSpotlight.style.width = listingimagewidth + 'px'; imgSpotlight.style.height = listingimageheight + 'px'; } if (listingimagewidth > maxwidth) { imgSpotlight.style.width = maxwidth + 'px'; listingimageheight = listingimageheight * maxwidth / listingimagewidth; listingimagewidth = maxwidth; imgSpotlight.style.height = listingimageheight + 'px'; } if (divImgSpotlight) { RHSStartSlide('divImgSpotlight', 'height', GetHeight(divImgSpotlight), listingimageheight, 50, 3); } }}function fixSpotLinks() { var spotImg = $('spotImg'); var spotCity = $('spotCity'); var spotMore = $('spotMore'); if (spotImg && spotImg.href) spotImg.href=spotImg.href.replace('&amp;','&'); if (spotCity && spotCity.href) spotCity.href=spotCity.href.replace('&amp;','&'); if (spotMore && spotMore.href) spotMore.href=spotMore.href.replace('&amp;','&');}function logoOverlay() { var imgLGL = $('imgLGL'); var tdLGL = $('tdLGL'); if (imgLGL && tdLGL) { imgLGL.style.left = GetLeft(tdLGL) + 'px'; imgLGL.style.top = GetTop(tdLGL) + 'px'; imgLGL.style.width = GetWidth(tdLGL) + 'px'; imgLGL.style.height = GetHeight(tdLGL) + 'px'; imgLGL.className = ''
 }}
 var WebServiceURL = 'http://www.relohomesearch.com/RHSWebService.asmx'; function divMain(){new Ajax.Updater({success:'divMain',failure:'divWebServiceError'},WebServiceURL+'/divMain',{method:'post',onComplete:AjaxUpdaterComplete(),evalScripts:true,parameters:{UserID:3405841,Locale:CtryCD+','+StCD+','+SAID+','+TbPos}});} function divSearchResults(SearchString){new Ajax.Updater({success:'divSearchResults',failure:'divWebServiceError'},WebServiceURL+'/divSearchResults',{method:'post',onComplete:AjaxUpdaterComplete(),evalScripts:true,parameters:{SearchString:SearchString}});} function SetClientSize(cH,cW){new Ajax.Updater({success:'divWebService',failure:'divWebServiceError'},WebServiceURL+'/SetClientSize',{method:'post',onComplete:AjaxUpdaterComplete(),evalScripts:true,parameters:{UserID:3405841,Locale:CtryCD+','+StCD+','+SAID+','+TbPos,cH:cH,cW:cW}});} function UserLogin(UserName,Password){new Ajax.Updater({success:'divWebService',failure:'divWebServiceError'},WebServiceURL+'/UserLogin',{method:'post',onComplete:AjaxUpdaterComplete(),evalScripts:true,parameters:{UserID:3405841,UserName:UserName,Password:Password}});} function divListingResults(){new Ajax.Updater({success:'divListingResults',failure:'divWebServiceError'},WebServiceURL+'/divListingResults',{method:'post',onComplete:AjaxUpdaterComplete(),evalScripts:true,parameters:{UserID:3405841,Locale:CtryCD+','+StCD+','+SAID+','+TbPos}});} function ClearFilters(){new Ajax.Updater({success:'divWebService',failure:'divWebServiceError'},WebServiceURL+'/ClearFilters',{method:'post',onComplete:AjaxUpdaterComplete(),evalScripts:true,parameters:{UserID:3405841,Locale:CtryCD+','+StCD+','+SAID+','+TbPos}});} function ClearListings(Fav){new Ajax.Updater({success:'divWebService',failure:'divWebServiceError'},WebServiceURL+'/ClearListings',{method:'post',onComplete:AjaxUpdaterComplete(),evalScripts:true,parameters:{UserID:3405841,Locale:CtryCD+','+StCD+','+SAID+','+TbPos,Fav:Fav}});} function divSlideResults(MovePosition,SetPosition){new Ajax.Updater({success:'divSlideResults',failure:'divWebServiceError'},WebServiceURL+'/divSlideResults',{method:'post',onComplete:AjaxUpdaterComplete(),evalScripts:true,parameters:{UserID:3405841,Locale:CtryCD+','+StCD+','+SAID+','+TbPos,MovePosition:MovePosition,SetPosition:SetPosition}});} function divCaption(){new Ajax.Updater({success:'divCaption',failure:'divWebServiceError'},WebServiceURL+'/divCaption',{method:'post',onComplete:AjaxUpdaterComplete(),evalScripts:true,parameters:{UserID:3405841,Locale:CtryCD+','+StCD+','+SAID+','+TbPos}});} function divBreadCrumbTrail(){new Ajax.Updater({success:'divBreadCrumbTrail',failure:'divWebServiceError'},WebServiceURL+'/divBreadCrumbTrail',{method:'post',onComplete:AjaxUpdaterComplete(),evalScripts:true,parameters:{UserID:3405841,Locale:CtryCD+','+StCD+','+SAID+','+TbPos}});} function divInformation(InformationSelection,Param){new Ajax.Updater({success:'divInformation',failure:'divWebServiceError'},WebServiceURL+'/divInformation',{method:'post',onComplete:AjaxUpdaterComplete(),evalScripts:true,parameters:{UserID:3405841,Locale:CtryCD+','+StCD+','+SAID+','+TbPos,InformationSelection:InformationSelection,Param:Param}});} function GetMapCities(MapBounds,zoomlevel){new Ajax.Updater({success:'divWebService',failure:'divWebServiceError'},WebServiceURL+'/GetMapCities',{method:'post',onComplete:AjaxUpdaterComplete(),evalScripts:true,parameters:{UserID:3405841,Locale:CtryCD+','+StCD+','+SAID+','+TbPos,MapBounds:MapBounds,zoomlevel:zoomlevel}});} function UpdateSearch(searchID,latitude,longitude,radius){new Ajax.Updater({success:'divWebService',failure:'divWebServiceError'},WebServiceURL+'/UpdateSearch',{method:'post',onComplete:AjaxUpdaterComplete(),evalScripts:true,parameters:{UserID:3405841,Locale:CtryCD+','+StCD+','+SAID+','+TbPos,searchID:searchID,latitude:latitude,longitude:longitude,radius:radius}});} function SaveLatLng(LatLngName,point){new Ajax.Updater({success:'divWebService',failure:'divWebServiceError'},WebServiceURL+'/SaveLatLng',{method:'post',onComplete:AjaxUpdaterComplete(),evalScripts:true,parameters:{UserID:3405841,LatLngName:LatLngName,point:point}});} function SetBrowserVersion(Browser,BrowserVersion,OS){new Ajax.Updater({success:'divWebService',failure:'divWebServiceError'},WebServiceURL+'/SetBrowserVersion',{method:'post',onComplete:AjaxUpdaterComplete(),evalScripts:true,parameters:{UserID:3405841,Locale:CtryCD+','+StCD+','+SAID+','+TbPos,Browser:Browser,BrowserVersion:BrowserVersion,OS:OS}});} function divRefineBox(){new Ajax.Updater({success:'divRefineBox',failure:'divWebServiceError'},WebServiceURL+'/divRefineBox',{method:'post',onComplete:AjaxUpdaterComplete(),evalScripts:true,parameters:{UserID:3405841,Locale:CtryCD+','+StCD+','+SAID+','+TbPos}});} function divInfoOptions(){new Ajax.Updater({success:'divInfoOptions',failure:'divWebServiceError'},WebServiceURL+'/divInfoOptions',{method:'post',onComplete:AjaxUpdaterComplete(),evalScripts:true,parameters:{UserID:3405841,Locale:CtryCD+','+StCD+','+SAID+','+TbPos}});} function divBusinessCards(){new Ajax.Updater({success:'divBusinessCards',failure:'divWebServiceError'},WebServiceURL+'/divBusinessCards',{method:'post',onComplete:AjaxUpdaterComplete(),evalScripts:true,parameters:{UserID:3405841,Locale:CtryCD+','+StCD+','+SAID+','+TbPos}});} function SelPriceMin(Price){new Ajax.Updater({success:'divWebService',failure:'divWebServiceError'},WebServiceURL+'/SelPriceMin',{method:'post',onComplete:AjaxUpdaterComplete(),evalScripts:true,parameters:{UserID:3405841,Locale:CtryCD+','+StCD+','+SAID+','+TbPos,Price:Price}});} function SelPriceMax(Price){new Ajax.Updater({success:'divWebService',failure:'divWebServiceError'},WebServiceURL+'/SelPriceMax',{method:'post',onComplete:AjaxUpdaterComplete(),evalScripts:true,parameters:{UserID:3405841,Locale:CtryCD+','+StCD+','+SAID+','+TbPos,Price:Price}});} function SelBeds(Beds){new Ajax.Updater({success:'divWebService',failure:'divWebServiceError'},WebServiceURL+'/SelBeds',{method:'post',onComplete:AjaxUpdaterComplete(),evalScripts:true,parameters:{UserID:3405841,Locale:CtryCD+','+StCD+','+SAID+','+TbPos,Beds:Beds}});} function SelBaths(Baths){new Ajax.Updater({success:'divWebService',failure:'divWebServiceError'},WebServiceURL+'/SelBaths',{method:'post',onComplete:AjaxUpdaterComplete(),evalScripts:true,parameters:{UserID:3405841,Locale:CtryCD+','+StCD+','+SAID+','+TbPos,Baths:Baths}});} function ShowListingDetails(){new Ajax.Updater({success:'divWebService',failure:'divWebServiceError'},WebServiceURL+'/ShowListingDetails',{method:'post',onComplete:AjaxUpdaterComplete(),evalScripts:true,parameters:{UserID:3405841,Locale:CtryCD+','+StCD+','+SAID+','+TbPos}});} function ToggleMapOptions(){new Ajax.Updater({success:'divWebService',failure:'divWebServiceError'},WebServiceURL+'/ToggleMapOptions',{method:'post',onComplete:AjaxUpdaterComplete(),evalScripts:true,parameters:{UserID:3405841,Locale:CtryCD+','+StCD+','+SAID+','+TbPos}});} function divSpotlight(MovePosition){new Ajax.Updater({success:'divSpotlight',failure:'divWebServiceError'},WebServiceURL+'/divSpotlight',{method:'post',onComplete:AjaxUpdaterComplete(),evalScripts:true,parameters:{UserID:3405841,Locale:CtryCD+','+StCD+','+SAID+','+TbPos,MovePosition:MovePosition}});} function UpdateSpotlight(MovePosition){new Ajax.Updater({success:'divWebService',failure:'divWebServiceError'},WebServiceURL+'/UpdateSpotlight',{method:'post',onComplete:AjaxUpdaterComplete(),evalScripts:true,parameters:{UserID:3405841,Locale:CtryCD+','+StCD+','+SAID+','+TbPos,MovePosition:MovePosition}});} function GetMapBoundaries(){new Ajax.Updater({success:'divWebService',failure:'divWebServiceError'},WebServiceURL+'/GetMapBoundaries',{method:'post',onComplete:AjaxUpdaterComplete(),evalScripts:true,parameters:{UserID:3405841,Locale:CtryCD+','+StCD+','+SAID+','+TbPos}});} function RemoveSearch(SearchID){new Ajax.Updater({success:'divWebService',failure:'divWebServiceError'},WebServiceURL+'/RemoveSearch',{method:'post',onComplete:AjaxUpdaterComplete(),evalScripts:true,parameters:{UserID:3405841,Locale:CtryCD+','+StCD+','+SAID+','+TbPos,SearchID:SearchID}});} function divCostOfLiving(Zipcode){new Ajax.Updater({success:'divCostOfLiving',failure:'divWebServiceError'},WebServiceURL+'/divCostOfLiving',{method:'post',onComplete:AjaxUpdaterComplete(),evalScripts:true,parameters:{UserID:3405841,Locale:CtryCD+','+StCD+','+SAID+','+TbPos,Zipcode:Zipcode}});} function divFeedback(Email,Subject,Text){new Ajax.Updater({success:'divFeedback',failure:'divWebServiceError'},WebServiceURL+'/divFeedback',{method:'post',onComplete:AjaxUpdaterComplete(),evalScripts:true,parameters:{UserID:3405841,Email:Email,Subject:Subject,Text:Text}});} function ClickBoundary(BoundaryIndex){new Ajax.Updater({success:'divWebService',failure:'divWebServiceError'},WebServiceURL+'/ClickBoundary',{method:'post',onComplete:AjaxUpdaterComplete(),evalScripts:true,parameters:{BoundaryIndex:BoundaryIndex}});} function ClickCity(ServiceAreaID){new Ajax.Updater({success:'divWebService',failure:'divWebServiceError'},WebServiceURL+'/ClickCity',{method:'post',onComplete:AjaxUpdaterComplete(),evalScripts:true,parameters:{UserID:3405841,Locale:CtryCD+','+StCD+','+SAID+','+TbPos,ServiceAreaID:ServiceAreaID}});} function AddFav(ListingID,CountryCD,StateProvinceCD){new Ajax.Updater({success:'divWebService',failure:'divWebServiceError'},WebServiceURL+'/AddFav',{method:'post',onComplete:AjaxUpdaterComplete(),evalScripts:true,parameters:{UserID:3405841,Locale:CtryCD+','+StCD+','+SAID+','+TbPos,ListingID:ListingID,CountryCD:CountryCD,StateProvinceCD:StateProvinceCD}});} function RemoveFav(ListingID){new Ajax.Updater({success:'divWebService',failure:'divWebServiceError'},WebServiceURL+'/RemoveFav',{method:'post',onComplete:AjaxUpdaterComplete(),evalScripts:true,parameters:{UserID:3405841,Locale:CtryCD+','+StCD+','+SAID+','+TbPos,ListingID:ListingID}});} function ShowSchool(SchoolID,ShowHide){new Ajax.Updater({success:'divWebService',failure:'divWebServiceError'},WebServiceURL+'/ShowSchool',{method:'post',onComplete:AjaxUpdaterComplete(),evalScripts:true,parameters:{UserID:3405841,Locale:CtryCD+','+StCD+','+SAID+','+TbPos,SchoolID:SchoolID,ShowHide:ShowHide}});} function ShowAllSchools(ShowHide){new Ajax.Updater({success:'divWebService',failure:'divWebServiceError'},WebServiceURL+'/ShowAllSchools',{method:'post',onComplete:AjaxUpdaterComplete(),evalScripts:true,parameters:{UserID:3405841,Locale:CtryCD+','+StCD+','+SAID+','+TbPos,ShowHide:ShowHide}});} function SchoolDiv(UpdateDiv,SchoolID,ShowHide){new Ajax.Updater({success:UpdateDiv,failure:'divWebServiceError'},WebServiceURL+'/SchoolDiv',{method:'post',onComplete:AjaxUpdaterComplete(),evalScripts:true,parameters:{SchoolID:SchoolID,ShowHide:ShowHide}});}BrowserDetect.init();