/*******************************************************************************
../contentflow/contentflow_src.js
*******************************************************************************/
/* ContentFlow, version 1.0.2
* (c) 2007 - 2010 Sebastian Kutsch
*
*
* ContentFlow is distributed under the terms of the MIT license.
* (see http://www.jacksasylum.eu/ContentFlow/LICENSE)
*
*--------------------------------------------------------------------------*/
/*
* ============================================================
* Global configutaion and initilization object
* ============================================================
*/
var ContentFlowGlobal = {
Flows: new Array,
AddOns: {},
scriptName: 'contentflow.js',
scriptElement: null,
Browser: new (function () {
this.Opera = window.opera ? true : false;
this.IE = document.all && !this.Opera ? true : false;
this.IE6 = this.IE && typeof(window.XMLHttpRequest) == "undefined" ? true : false;
this.IE8 = this.IE && typeof(document.querySelectorAll) != "undefined" ? true : false;
this.IE7 = this.IE && ! this.IE6 && !this.IE8 ? true : false;
this.WebKit = /WebKit/i.test(navigator.userAgent) ? true : false,
this.iPhone = /iPhone|iPod/i.test(navigator.userAgent)? true : false;
this.Chrome = /Chrome/i.test(navigator.userAgent) ? true : false;
this.Safari = /Safari/i.test(navigator.userAgent) && !this.Chrome ? true : false;
this.Konqueror = navigator.vendor == "KDE" ? true : false;
this.Konqueror4 = this.Konqueror && /native code/.test(document.getElementsByClassName) ? true : false;
this.Gecko = !this.WebKit && navigator.product == "Gecko" ? true : false;
this.Gecko19 = this.Gecko && Array.reduce ? true : false;
})(),
getAddOnConf: function(name) {
if(this.AddOns[name])
return this.AddOns[name].conf;
else
return {};
},
setAddOnConf: function (name, conf) {
this.AddOns[name].setConfig(conf);
},
getScriptElement:function (scriptName) {
var regex = new RegExp(scriptName);
var scripts = document.getElementsByTagName('script');
for (var i=0; i<\/script>');
}
else {
var script = document.createElement('script');
script.src = path;
script.setAttribute('type', 'text/javascript');
document.getElementsByTagName('head')[0].appendChild(script);
}
},
addScripts: function (basePath, filenames) {
for (var i=0; i');
}
},
addStylesheets: function (basePath, filenames) {
for (var i=0; i<\/script>");
var script = document.getElementById("__ie_cf_onload");
script.onreadystatechange = function() {
if (this.readyState == "complete") {
CFG.onloadInit(); // call the onload handler
}
};
}
/* for all other browsers */
window.addEvent('load', CFG.onloadInit, false);
/* ================================================================== */
},
onloadInit: function () {
// quit if this function has already been called
if (arguments.callee.done) return;
for (var i=0; i< ContentFlowGlobal.loadAddOns.length; i++) {
var a = ContentFlowGlobal.loadAddOns[i];
if (!ContentFlowGlobal.AddOns[a]) {
var CFG = ContentFlowGlobal;
window.setTimeout( CFG.onloadInit, 10);
return;
}
}
// flag this function so we don't do the same thing twice
arguments.callee.done = true;
/* fix for mootools */
if (window.Element && Element.implement && document.all && !window.opera) {
for (var prop in window.CFElement.prototype) {
if(!window.Element.prototype[prop]) {
var implement = {};
implement[prop] = window.CFElement.prototype[prop];
Element.implement(implement);
}
}
}
/* init all manualy created flows */
for (var i=0; i< ContentFlowGlobal.Flows.length; i++) {
ContentFlowGlobal.Flows[i].init();
}
/* init the rest */
var divs = document.getElementsByTagName('div');
DIVS: for (var i = 0; i < divs.length; i++) {
if (divs[i].className.match(/\bContentFlow\b/)) {
for (var j=0; j 0) {
this.addReflection();
}
this.initClick();
CFobj._addItemCueProcess(true);
}.bind(this);
if (this.content.complete && this.content.width > 0)
window.setTimeout(foobar, 100);
else if (this.Browser.IE && !this.content.onload) {
var self = this;
var t = window.setInterval( function () {
if (self.content.complete && self.content.width > 0) {
window.clearInterval(t);
foobar();
}
}, 10);
}
else
this.content.onload = window.setTimeout(foobar, 100);
}
else {
this.initClick();
CFobj._addItemCueProcess(true);
}
};
ContentFlowItem.prototype = {
Browser: ContentFlowGlobal.Browser,
makeActive: function () {
this.element.addClassName('active');
this.CFobj.conf.onMakeActive(this);
},
makeInactive: function () {
this.element.removeClassName('active');
this.CFobj.conf.onMakeInactive(this);
},
initClick: function () {
var cItem = this.clickItem;
this[this._activeElement].addEvent('click', cItem, false);
},
setImageFormat: function (img) {
/*if (this.Browser.IE6 || this.Browser.IE7) img.style.width = "auto";
img.origProportion = img.width / img.height;
img.setAttribute('origProportion', img.width / img.height);
if (this.Browser.IE6 || this.Browser.IE7) img.style.width = "";
//img.origWidth = img.width;
//img.origHeight = img.height;
if (img.origProportion <= 1)
img.addClassName('portray');
else
img.addClassName('landscape');*/
if (this.Browser.IE6 || this.Browser.IE7 || this.Browser.IE8) {
img.style.width = "auto";
img.width = 351;
img.height = 264;
}
img.origProportion = img.width / img.height;
img.setAttribute('origProportion', img.width / img.height);
if (img.origProportion <= 1)
img.addClassName('portray');
else
img.addClassName('landscape');
},
/*
* add reflection to item
*/
addReflection: function() {
var CFobj = this.CFobj;
var reflection;
var image = this.content;
var deviceAgent = navigator.userAgent.toLowerCase();
var agentID = deviceAgent.match(/(iphone|ipod|ipad)/);
if (agentID) {
//return;
}
if (this.Browser.IE) {
var filterString = 'progid:DXImageTransform.Microsoft.BasicImage(rotation=2, mirror=1)';
if (CFobj._reflectionColorRGB) {
// transparent gradient
if (CFobj.conf.reflectionColor == "transparent") {
var RefImg = reflection = this.reflection = document.createElement('img');
reflection.src = image.src;
}
// color gradient
else {
reflection = this.reflection = document.createElement('div');
var RefImg = document.createElement('img');
RefImg.src = image.src;
reflection.width = RefImg.width;
reflection.height = RefImg.height;
RefImg.style.width = '100%';
RefImg.style.height = '100%';
var color = CFobj._reflectionColorRGB;
reflection.style.backgroundColor = '#'+color.hR+color.hG+color.hB;
reflection.appendChild(RefImg);
}
filterString += ' progid:DXImageTransform.Microsoft.Alpha(opacity=0, finishOpacity=50, style=1, finishX=0, startY='+CFobj.conf.reflectionHeight*100+' finishY=0)';
} else {
var RefImg = reflection = this.reflection = document.createElement('img');
reflection.src = image.src;
}
// crop image (streches and crops (clip on default dimensions), original proportions will be restored through CSS)
filterString += ' progid:DXImageTransform.Microsoft.Matrix(M11=1, M12=0, M21=0, M22='+1/CFobj.conf.reflectionHeight+')';
if (ContentFlowGlobal.Browser.IE6) {
if (image.src.match(/\.png$/) ) {
image.style.filter = "progid:DXImageTransform.Microsoft.AlphaImageLoader(src='"+image.src+"', sizingMethod=scale )";
image.filterString = "progid:DXImageTransform.Microsoft.AlphaImageLoader(src='"+image.src+"', sizingMethod=scale )";
filterString += " progid:DXImageTransform.Microsoft.AlphaImageLoader(src='"+image.src+"', sizingMethod=scale )";
image.origSrc = image.src;
image.src='img/blank.gif';
RefImg.src="img/blank.gif";
}
}
reflection.filterString = filterString;
RefImg.style.filter = filterString;
} else {
if (CFobj._reflectionWithinImage)
var canvas = this.canvas = $CF(document.createElement('canvas'));
else
var canvas = reflection = this.reflection = document.createElement('canvas');
if (canvas.getContext) {
if (CFobj._reflectionWithinImage) {
for (var i=0; i vI) {
if (diff > 0) {
var stepwidth = diff - vI;
} else {
var stepwidth = diff + vI;
}
} else if (vI >= this.items.length) {
var stepwidth = diff / items;
} else {
var stepwidth = diff * ( vI / items);
//var stepwidth = diff/absDiff * Math.max(diff * diff,Math.min(absDiff,0.3)) * ( vI / this.items.length);
//var stepwidth = this.flowSpeedFactor * diff / this.visibleItems;
//var stepwidth = this.flowSpeedFactor * diff * ( this.visibleItems / this.items.length)
//var stepwidth = this.flowSpeedFactor * diff / this._millisecondsPerStep * 2; // const. speed
}
return stepwidth;
},
calcSize: function (item) {
var rP = item.relativePosition;
//var rPN = relativePositionNormed;
//var vI = this.conf.visibleItems;
var h = 1/(Math.abs(rP)+1);
var w = h;
return {width: w, height: h};
},
calcCoordinates: function (item) {
var rP = item.relativePosition;
//var rPN = item.relativePositionNormed;
var vI = this.conf.visibleItems;
var f = 1 - 1/Math.exp( Math.abs(rP)*0.75);
var x = item.side * vI/(vI+1)* f;
var y = 1;
return {x: x, y: y};
},
/*
calcRelativeItemPosition: function (item) {
var x = 0;
var y = -1;
return {x: x, y: y};
},
*/
calcZIndex: function (item) {
return -Math.abs(item.relativePositionNormed);
},
calcFontSize: function (item) {
return item.size.height;
},
calcOpacity: function (item) {
return Math.max(1 - ((1 - this.conf.endOpacity ) * Math.sqrt(Math.abs(item.relativePositionNormed))), this.conf.endOpacity);
}
},
/* ---------- end of defaultConf ---------- */
/*
* ==================== index helper methods ====================
*/
/*
* checks if index is within the index range of the this.items array
* returns a value that is within this range
*/
_checkIndex: function (index) {
index = Math.max(index, 0);
index = Math.min(index, this.itemsLastIndex);
return index;
},
/*
* sets the object property itemsLastIndex
*/
_setLastIndex: function () {
this.itemsLastIndex = this.items.length - 1;
},
/*
*/
_getItemByIndex: function (index) {
return this.items[this._checkIndex(index)];
},
_getItemByPosition: function (position) {
return this._getItemByIndex(this._getIndexByPosition(position));
},
/* returns the position of an item-index relative to current position */
_getPositionByIndex: function(index) {
if (!this.conf.circularFlow) return this._checkIndex(index);
var cI = this._getIndexByPosition(this._currentPosition);
var dI = index - cI;
if (Math.abs(dI) > dI+this.items.length)
dI += this.items.length;
else if (Math.abs(dI) > (Math.abs(dI-this.items.length)))
dI -= this.items.length;
return this._currentPosition + dI;
},
/* returns the index an item at position p would have */
_getIndexByPosition: function (position) {
if (position < 0) var mod = 0;
else var mod = 1;
var I = (Math.round(position) + mod) % this.items.length;
if (I>0) I -= mod;
else if(I<0) I += this.items.length - mod;
else if(position<0) I = 0;
else I = this.items.length - 1;
return I;
},
_getIndexByKeyWord: function (keyword, relativeTo, check) {
if (relativeTo)
var index = relativeTo;
else if (this._activeItem)
var index = this._activeItem.index;
else
var index = 0;
if (isNaN(keyword)) {
switch (keyword) {
case "first":
case "start":
index = 0;
break;
case "last":
case "end":
index = this.itemsLastIndex;
break;
case "middle":
case "center":
index = Math.round(this.itemsLastIndex/2);
break;
case "right":
case "next":
index += 1;
break;
case "left":
case "pre":
case "previous":
index -= 1;
break;
case 'visible':
case 'visiblePre':
case 'visibleLeft':
index -= this.conf.visibleItems;
break;
case 'visibleNext':
case 'visibleRight':
index += this.conf.visibleItems;
break;
default:
index = index;
}
}
else {
index = keyword;
}
if (check != false)
index = this._checkIndex(index);
return index;
},
_setCaptionLabel: function (index) {
if(this.Position && !this.Slider.locked)
this.Position.setLabel(index);
this._setGlobalCaption();
},
/*
* ==================== public methods ====================
*/
getAddOnConf: function(name) {
return ContentFlowGlobal.getAddOnConf(name);
},
setAddOnConf: function(name, conf) {
ContentFlowGlobal.setAddOnConf(name, conf);
},
/*
* calls _init() if ContentFlow has not been initialized before
* needed if ContentFlow is not automatically initialized on window.load
*/
init: function () {
if(this.isInit) return;
this._init();
},
/*
* parses configuration object and initializes configuration values
*/
setConfig: function(config) {
if (!config) return;
var dC = this._defaultConf;
for (var option in config) {
if (dC[option] == "undefined" ) continue;
switch (option) {
case "scrollInFrom":
case "startItem":
if (typeof(config[option]) == "number" || typeof(config[option]) == "string") {
//this["_"+option] = config[option];
this.conf[option] = config[option];
}
break;
default:
if (typeof(dC[option] == config[option])) {
//this["_"+option] = config[option];
if (typeof config[option] == "function") {
this.conf[option] = config[option].bind(this);
}
else {
this.conf[option] = config[option];
}
}
}
}
switch (this.conf.reflectionColor) {
case this.conf.reflectionColor.search(/#[0-9a-fA-F]{6}/)>= 0?this.conf.reflectionColor:this.conf.reflectionColor+"x":
this._reflectionColorRGB = {
hR: this.conf.reflectionColor.slice(1,3),
hG: this.conf.reflectionColor.slice(3,5),
hB: this.conf.reflectionColor.slice(5,7),
iR: parseInt(this.conf.reflectionColor.slice(1,3), 16),
iG: parseInt(this.conf.reflectionColor.slice(3,5), 16),
iB: parseInt(this.conf.reflectionColor.slice(5,7), 16)
};
break;
case "none":
case "transparent":
default:
this._reflectionColor = "transparent";
this._reflectionColorRGB = {
hR: 0, hG: 0, hB:0,
iR: 0, iG: 0, iB:0
};
break;
}
if (this.items) {
if (this.conf.visibleItems < 0)
this.conf.visibleItems = Math.round(Math.sqrt(this.items.length));
this.conf.visibleItems = Math.min(this.conf.visibleItems, this.items.length - 1);
}
if (this.conf.relativeItemPosition) {
var calcRP = {
x: {
left: function(size) {return -1},
center: function(size) {return 0},
right: function(size) {return 1}
},
y: {
top: function(size) {return -1},
center: function(size) {return 0},
bottom: function(size) {return 1}
}
};
var iP = this.conf.relativeItemPosition;
iP = iP.replace(/above/,"top").replace(/below/,"bottom");
var x, y = null;
x = iP.match(/left|right/);
y = iP.match(/top|bottom/);
c = iP.match(/center/);
if (!x) {
if (c) x = "center";
else x = "center";
}
if (!y) {
if (c) y = "center";
else y = "top";
}
var calcX = calcRP.x[x];
var calcY = calcRP.y[y];
this.conf.calcRelativeItemPosition = function (item) {
var x = calcX(item.size);
var y = calcY(item.size);
return {x: x, y: y};
};
this.conf.relativeItemPosition = null;
}
if (this._reflectionType && this._reflectionType != "clientside") {
this.conf.reflectionHeight = 0;
}
},
getItem: function (index) {
return this.items[this._checkIndex(Math.round(index))];
},
/*
* returns the index number of the active item
*/
getActiveItem: function() {
return this._activeItem;
},
/*
* returns the number of items the flow contains
*/
getNumberOfItems: function () {
return this.items.length;
},
/*
* reinitializes sizes.
* called on window.resize
*/
resize: function () {
this._initSizes();
this._initStep();
},
/*
* scrolls flow to item i
*/
moveToPosition: function (p, holdPos) {
if (!this.conf.circularFlow) p = this._checkIndex(p);
this._targetPosition = p;
this.conf.onMoveTo(this._getItemByPosition(p));
this._initStep(false, holdPos);
},
moveToIndex: function (index) {
this._targetPosition = Math.round(this._getPositionByIndex(this._getIndexByKeyWord(index, this._activeItem.index, !this.conf.circularFlow)));
this.conf.onMoveTo(this._getItemByPosition(this._targetPosition));
this._initStep();
},
moveToItem: function (item) {
var i;
if (item.itemIndex) i = item.itemIndex;
else i = item.index;
this.moveToIndex(i);
},
moveTo: function (i) {
if (typeof i == "object") this.moveToItem(i);
else if (isNaN(i) || (i == Math.floor(i) && i < this.items.length) ) this.moveToIndex(i);
else this.moveToPosition(i);
},
/*
* initializes item and adds it at index position
*/
_addItemCue: [],
_addItemCueProcess: function (deleteFirst) {
var c = this._addItemCue;
if (deleteFirst == true)
c.shift();
if (c.length > 0 && ! c[0].p) {
c[0].p = true;
var self = this;
var t = c.length > 5 ? 1 : 40;
window.setTimeout(function () {self._addItem(c[0].el, c[0].i)}, t) ;
}
},
addItem: function(el, index) {
this._addItemCue.push({el: el, i: index, p: false});
if (this._addItemCue.length == 1)
this._addItemCueProcess();
},
_addItem: function(el, index) {
if (typeof index == "string") {
switch (index) {
case "first":
case "start":
index = 0;
break;
case "last":
case "end":
index = isNaN(this.itemsLastIndex) ? 0 : this.itemsLastIndex;
index += 1;
break;
default:
index = this._getIndexByKeyWord(index);
}
}
index = Math.max(index, 0);
index = Math.min(index, this.itemsLastIndex + 1);
index = isNaN(index) ? 0 : index;
this.Flow.appendChild(el);
/* init item after insertion. that way it's part of the document and all styles are applied */
var item = new ContentFlowItem(this, el, index);
if (this.items.length == 0 ) {
this.resize();
if (this.conf.circularFlow) {
item.pre = item;
item.next = item;
}
}
else {
if (index == this.itemsLastIndex + 1) {
item.pre = this.items[this.itemsLastIndex];
item.next = item.pre.next;
}
else {
item.next = this.items[index];
item.pre = item.next.pre;
}
if (item.pre) item.pre.next = item;
if (item.next) item.next.pre = item;
}
this.items.splice(index,0, item);
/* adjust item indices */
for (var i = index; i < this.items.length; i++) {
this.items[i].setIndex(i);
}
this._setLastIndex();
if (this.conf.origVisibleItems < 0) {
this.conf.visibleItems = Math.round(Math.sqrt(this.items.length));
}
this.conf.visibleItems = Math.min(this.conf.visibleItems, this.items.length - 1);
/* adjust targetItem, currentPos so that current view does not change*/
if (Math.round(this._getPositionByIndex(index)) <= Math.round(this._targetPosition)) {
this._targetPosition++;
if (!this.conf.circularFlow)
this._targetPosition = Math.min(this._targetPosition, this.itemsLastIndex);
}
if (this._getPositionByIndex(index) <= this._currentPosition) {
this._currentPosition++;
if (!this.conf.circularFlow)
this._currentPosition = Math.min(this._currentPosition, this.itemsLastIndex);
}
// avoid display errors (wrong sizing)
var CF = this;
window.setTimeout(function () {
if(CF.items.length == 1 ) {
CF._currentPosition = -0.01;
CF._targetPosition = 0;
CF.resize();
}
else {
CF._initStep();
}
}, 100);
return index;
},
/*
* removes item at index position, cleans it up and returns it
*/
rmItem: function(index) {
if (index == "undefined") index = this._activeItem.index;
index = this._getIndexByKeyWord(index);
if (!this.items[index]) return null;
var item = this.items[index];
if (item.pre) item.pre.next = item.next;
if (item.next) item.next.pre = item.pre;
this.items.splice(index,1);
/* adjust item indices */
for (var i = index ; i < this.items.length; i++) {
this.items[i].setIndex(i);
}
this._setLastIndex();
/* adjust targetItem, currentPos and activeItem so that current view does not change*/
if (Math.round(this._getPositionByIndex(index)) < Math.round(this._targetPosition)) {
this._targetPosition--;
if (!this.conf.circularFlow)
this._targetPosition = this._checkIndex(this._targetPosition);
}
if (this._getPositionByIndex(index) < this._currentPosition) {
this._currentPosition--;
if (!this.conf.circularFlow)
this._currentPosition = this._checkIndex(this._currentPosition);
}
this._activeItem = this._getItemByPosition(this._currentPosition);
/* remove item from DOM tree, take the next step and return removed item */
var removedItem = item.element.parentNode.removeChild(item.element);
// avoid display errors (wrong sizing)
var CF = this;
window.setTimeout(function () {CF._initStep()}, 10);
return removedItem;
},
/*
* ==================== initialization ====================
*/
/* -------------------- main init -------------------- */
_init: function () {
if (typeof(this.Container) == 'string') { // no node
var container = document.getElementById(this.Container);
if (container) {
this.Container = container;
} else {
throw ('ContentFlow ERROR: No element with id \''+this.Container+'\' found!');
return;
}
}
/* ---------- reserve CSS namespace */
$CF(this.Container).addClassName('ContentFlow');
/* ---------- detect GUI elements */
var flow = $CF(this.Container).getChildrenByClassName('flow')[0];
if (!flow) {
throw ('ContentFlow ERROR: No element with class\'flow\' found!');
return;
}
this.Flow = new ContentFlowGUIElement(this, flow);
var scrollbar = this.Container.getChildrenByClassName('scrollbar')[0];
if (scrollbar) {
this.Scrollbar = new ContentFlowGUIElement(this, scrollbar);
var slider = this.Scrollbar.getChildrenByClassName('slider')[0];
if (slider) {
this.Slider = new ContentFlowGUIElement(this, slider);
var position = this.Slider.getChildrenByClassName('position')[0];
if (position) {
this.Position = new ContentFlowGUIElement(this, position);
}
}
}
/* ---------- init configuration */
this.setConfig(this._defaultConf);
this._initAddOns(); /* init AddOns */
this.setConfig(this._userConf);
this._initSizes(); // ......
/* ---------- init item lists ---------- */
var items = this.Flow.getChildrenByClassName('item');
this.items = new Array();
for (var i=0; i 0) {
item.pre = this.items[i-1];
item.pre.next = item;
}
}
this._setLastIndex();
if (this.conf.circularFlow && this.items.length > 0) {
var s = this.items[0];
s.pre = this.items[this.items.length-1];
s.pre.next = s;
}
/* ---------- init GUI */
this._initGUI();
/* ---------- init start parameters ---------- */
if (this._activeElement != "content")
this._activeElement = "element";
this.conf.origVisibleItems = this.conf.visibleItems;
if (this.conf.visibleItems < 0) {
this.conf.visibleItems = Math.round(Math.sqrt(this.items.length));
}
this.conf.visibleItems = Math.min(this.conf.visibleItems, this.items.length - 1);
this._targetPosition = this._getIndexByKeyWord(this.conf.startItem, 0);
var index = this._getIndexByKeyWord(this.conf.scrollInFrom, this._targetPosition);
switch (this.conf.scrollInFrom) {
case "next":
case "right":
index -= 0.5;
break;
case "pre":
case "previous":
case "left":
index += 0.5;
break;
}
this._currentPosition = index;
/* ---------- wait till all images are loaded or
* grace time is up to show all and take the first step
*/
var now = new Date();
var cf = this;
var timer = window.setInterval (
function() {
if ( cf._imagesToLoad == 0 || new Date() - now > cf._loadingTimeout ) {
clearInterval(timer);
cf._activeItem = cf.getItem(cf._currentPosition);
if (cf._activeItem) {
cf._activeItem.makeActive();
cf._setCaptionLabel(cf._activeItem.index);
}
cf.Flow.style.visibility = "visible"; // show flow after images are loaded
if (cf.loadIndicator) cf.loadIndicator.style.display = "none";
if (cf.Scrollbar) cf.Scrollbar.style.visibility = "visible";
cf.resize();
for (var i=0; i < cf._loadedAddOns.length; i++) {
var a = ContentFlowGlobal.AddOns[cf._loadedAddOns[i]];
if (a.methods.afterContentFlowInit)
a.methods.afterContentFlowInit(cf);
}
cf.conf.onInit();
}
}, 10
);
this.isInit = true;
},
/* ---------- init AddOns ---------- */
_initAddOns: function () {
// get an array of names of all AddOns that should be used
var loadAddOns = [];
if (this._userConf.useAddOns) {
if (typeof this._userConf.useAddOns == "string") {
loadAddOns = this._userConf.useAddOns.split(" ");
}
else if (typeof this._userConf.useAddOns == "array") {
loadAddOns = this._userConf.useAddOns;
}
}
else if (this.Container.getAttribute("useAddOns")) {
loadAddOns = this.Container.getAttribute("useAddOns").split(" ");
}
else {
loadAddOns = this.conf.useAddOns.split(' ');
}
// check the names for keywords
for (var i=0; i 0) key(event) ;
});
} else {
window.addEvent('keydown', function (event) {
if (mouseoverCheck.offsetLeft > 0) key(event) ;
});
}
}
else {
this.Container.addEvent('keydown', key);
}
}
else {
this.Container.onkeydown = key;
}
}
// Flow object
if (this.conf.flowDragFriction > 0) {
var onDrag = function (event) {
var e = event;
if (event.touches) e = event.touches[0];
var mouseX = e.clientX;
var mouseY = e.clientY;
if (this.conf.verticalFlow) {
var dist = mouseY - this.Flow.mouseY; // px / or px per sec because _dragFlow wil be called in shorter intervalls if draged fast
var dim = this.Flow.dimensions.height;
}
else {
var dist = mouseX - this.Flow.mouseX; // px / or px per sec because _dragFlow wil be called in shorter intervalls if draged fast
var dim = this.Flow.dimensions.width;
}
var itemDist = (dist / dim )* (2*this.conf.visibleItems +1); // items
var target = this._currentPosition - itemDist * 2*this.conf.visibleItems / this.conf.flowDragFriction ;
this.Flow.mouseX = mouseX;
this.Flow.mouseY = mouseY;
this.moveToPosition(target, true);
}.bind(this);
var beforeDrag = function () {};
var afterDrag = function (event) {
var t = Math.round(this._targetPosition);
if (Math.abs( t - this._currentPosition) > 0.001 )
this.moveToPosition(t);
}.bind(this);
this.Flow.makeDraggable(onDrag, beforeDrag, afterDrag);
}
// Scrollbar Object
if (this.Scrollbar) {
var click = function(event) {
if (!event) var event = window.event;
if (!this.Scrollbar.clickLocked) {
var mouseX = event.clientX;
var positionOnScrollbar = mouseX - this.Scrollbar.position.left;
var targetIndex = Math.round(positionOnScrollbar/this.Scrollbar.dimensions.width * this.itemsLastIndex);
this.moveToIndex(targetIndex);
}
else
this.Scrollbar.clickLocked = false;
}.bind(this);
this.Scrollbar.addObserver('click', click);
}
// Slider Object
if (this.Slider) {
if (this.Browser.IE6) {
var virtualSlider = document.createElement('div');
virtualSlider.className = 'virtualSlider';
this.Slider.appendChild(virtualSlider);
}
// position slider on scrollbar
this.Slider.setPosition = function (relPos) {
relPos = relPos - Math.floor(relPos) + this._getIndexByPosition(Math.floor(relPos));
if (Math.round(relPos) < 0)
relPos = this.itemsLastIndex;
else if (relPos <= 0)
relPos = 0;
else if (Math.round(relPos) > this.itemsLastIndex)
relPos = 0;
else if (relPos >= this.itemsLastIndex)
relPos = this.itemsLastIndex;
if (this.items.length > 1) {
var sPos = (relPos / this.itemsLastIndex)* this.Scrollbar.dimensions.width;
} else {
var sPos = 0.5 * this.Scrollbar.dimensions.width;
}
this.Slider.style.left = sPos - this.Slider.center.x+ "px";
this.Slider.style.top = this.Scrollbar.center.y - this.Slider.center.y +"px";
}.bind(this);
// make slider draggable
var beforeDrag = function (event) {
this.Scrollbar.clickLocked = true;
}.bind(this);
var onDrag = function (event) {
var e = event;
if (event.touches) e = event.touches[0];
var selectedIndex = this._checkIndex((e.clientX - this.Scrollbar.position.left) / this.Scrollbar.dimensions.width * this.itemsLastIndex);
this._targetPosition = this._getPositionByIndex(selectedIndex);
this.Slider.setPosition(selectedIndex);
if (this.Position) this.Position.setLabel(selectedIndex);
this._initStep(true, true);
}.bind(this);
var afterDrag = function (event) {
this._targetPosition = Math.round(this._targetPosition);
this.conf.onMoveTo(this._getItemByPosition(this._targetPosition));
this._initStep(true);
}.bind(this);
this.Slider.makeDraggable(onDrag, beforeDrag, afterDrag);
}
// Position object
if (this.Position) {
this.Position.setLabel = function (index) {
index = this._checkIndex(Math.round(index));
if (this.items && this.items[index].label)
this.Position.innerHTML = this.items[index].label.innerHTML;
else
this.Position.innerHTML = index + 1;
}.bind(this);
}
this.globalCaption = this.Container.getChildrenByClassName('globalCaption')[0];
this.loadIndicator = this.Container.getChildrenByClassName('loadIndicator')[0];
},
/* ---------- init element sizes ---------- */
_initSizes: function (x) {
//if (this.Browser.Konqueror4 && x != true) {
//var t = this;
//window.setTimeout( function () { t._initSizes(true) }, 0);
//return;
//}
// sets this.maxHeight
this._initMaxHeight();
var scrollbarHeight = this._initScrollbarSize();
// reduce maxHeit if container has a fixed height
if (!this.conf.verticalFlow && this.Container.style.height && this.Container.style.height != "auto")
this.maxHeight -= scrollbarHeight;
if (!this._activeItem) return;
var mFS = this._findBiggestItem();
var pF = this.Flow.findPos();
/* set height / width of flow */
if (this.conf.verticalFlow) {
this.Flow.style.width = mFS.width.width+"px";
this.Flow.style.height =3* mFS.width.width * (1 + this.conf.reflectionHeight + this.conf.reflectionGap) + "px";
} else {
this.Flow.style.height = mFS.height.height +(mFS.height.top - pF.top)+"px";
}
/* remove gap */
var s = this.conf.verticalFlow ? mFS.width.width : mFS.height.height;
var cH = s /(1 + this.conf.reflectionHeight + this.conf.reflectionGap);
this.Flow.style.marginBottom = - (s - cH)+ "px";
this.Flow.dimensions = this.Flow.getDimensions();
if (!this.Browser.IE6) {
if (this.conf.verticalFlow && this.Container.clientWidth < this.Flow.dimensions.width) {
//this.Container.style.width = this.Flow.dimensions.width+"px";
}
else if (this.Container.clientHeight < this.Flow.dimensions.height) {
this.Container.style.height = this.Flow.dimensions.height+"px";
}
}
if (this.conf.verticalFlow) {
this.Flow.center = {x: this.Flow.dimensions.height/2, y:mFS.width.width/2};
} else {
this.Flow.center = {x: this.Flow.dimensions.width/2, y:mFS.height.height/2};
}
},
/* -------------------------------------------------------------------------------- */
_initScrollbarSize: function () {
var SB;
var SL;
var PO;
if (SB = this.Scrollbar) {
SB.setDimensions();
var scrollbarHeight = SB.dimensions.height;
if (SL = this.Slider) {
SL.setDimensions();
scrollbarHeight += SL.dimensions.height;
if (PO = this.Position) {
var oldLabel = PO.innerHTML;
var maxH = maxW = 0;
PO.style.width = "auto";
if (this.items) {
for (var i=0; i < this.items.length; i++) {
var item = this.items[i];
if (item.label) {
PO.innerHTML = item.label.innerHTML;
}
else {
PO.innerHTML = item.index;
}
var h = PO.clientHeight;
var w = PO.clientWidth;
if ( h > maxH) maxH = h;
if ( w > maxW) maxW = w;
}
}
else {
PO.innerHTML = " ";
maxH = PO.clientHeight;
maxW = PO.clientWidth;
}
PO.innerHTML = oldLabel;
PO.setDimensions();
PO.style.width = maxW +"px";
PO.style.left = (SL.dimensions.width - maxW)/2 + "px";
var extraSpace = PO.position.top - SL.position.top;
if (extraSpace > 0) {
extraSpace += -SB.dimensions.height + maxH;
SB.style.marginBottom = extraSpace + "px";
}
else {
extraSpace *= -1;
SB.style.marginTop = extraSpace + "px";
}
scrollbarHeight += extraSpace;
}
}
}
else {
scrollbarHeight = 0;
}
return scrollbarHeight;
},
/* -------------------------------------------------------------------------------- */
_initMaxHeight: function () {
if (this.conf.verticalFlow) {
var proportion = 1680/1024; //BH: screen.width/screen.height;
var Csd = this.Container.style.width;
var Cdim = this.Container.clientWidth;
var Fsd = this.Flow.style.width;
var Fdim = this.Flow.clientWidth;
var Fdim_o = this.Flow.clientHeight;
} else {
var proportion = 1024/1680; //BH: screen.height/screen.width;
var Csd = this.Container.style.height;
var Cdim = this.Container.clientHeight;
var Fsd = this.Flow.style.height;
var Fdim = this.Flow.clientHeight;
var Fdim_o = this.Flow.clientWidth;
}
// set height of container and flow
if (this.ContainerOldDim)
Csd = this.ContainerOldDim;
if (this.FlowOldDim)
Fsd = this.FlowOldDim;
this.ContainerOldDim = "auto";
this.FlowOldDim = "auto";
/* calc maxHeight */
if (this.conf.maxItemHeight <= 0) {
this.maxHeight = Fdim_o / 3 * proportion/1 * this.conf.scaleFactor; // divided by 3 because of left/center/right, yes it's a magic number
if (this.conf.verticalFlow && (this.maxHeight == 0 || this.maxHeight > Fdim)) {
this.maxHeight = Fdim;
}
if (Csd && Csd != "auto") {
var gap = this.conf.verticalFlow ? 0 : this.conf.reflectionGap;
var rH = this.conf.verticalFlow ? 0 : this.conf.reflectionHeight;
this.maxHeight = Cdim/ (this.conf.scaleFactor* (1 + rH + gap));
this.ContainerOldDim = Csd;
}
else if (Fsd && Fsd != "auto") {
var gap = this.conf.verticalFlow ? 0 : this.conf.reflectionGap;
this.maxHeight = Fdim / (this.conf.scaleFactor* (1 + this.conf.reflectionHeight + gap));
this.FlowOldDim = Fsd;
}
}
else {
this.maxHeight = this.conf.maxItemHeight;
}
},
/* -------------------------------------------------------------------------------- */
_findBiggestItem: function () {
var currentItem = this._activeItem;
var itemP = currentItem.pre;
var itemN = currentItem.next;
var mFS = maxFlowSize = {
width: {width: 0, left: 0, height:0, top: 0, item: null, rI: 0},
height: {width: 0, left: 0, height:0, top: 0, item: null, rI: 0}
}
var checkMax = function (item, rI) {
var el = item.element;
el.style.display = "block";
var p = el.findPos();
var h = el.clientHeight;
var w = el.clientWidth;
if (h + p.top >= mFS.height.height + mFS.height.top) {
mFS.height.height = h;
mFS.height.top = p.top;
mFS.height.item = item;
mFS.height.rI = rI;
}
if (w + p.left >= mFS.width.width + mFS.width.left) {
mFS.width.width = w;
mFS.width.left = p.left;
mFS.width.item = item;
mFS.width.rI = rI;
}
el.style.display = "none";
}
var ocp = this._currentPosition;
this._currentPosition = this.conf.visibleItems+1;
// find the position with highest y-value
for (var i=-this.conf.visibleItems; i <= this.conf.visibleItems; i++) {
currentItem.element.style.display = "none";
this._positionItem(currentItem, i, true);
checkMax(currentItem, i);
}
// find the biggest item
var index = mFS.height.rI;
for (var i=0; i < this.items.length; i++) {
var item = this.items[i];
item.element.style.display = "none";
this._positionItem(item, index, true);
checkMax(item, index);
}
this._currentPosition = ocp;
return mFS
},
/*
* ==================== Key strok ====================
*/
/*
* handles keystroke events
*/
_keyStroke: function(event) {
if(!event) var event = window.event;
if (event.which) {
var keyCode = event.which;
} else if (event.keyCode) {
var keyCode = event.keyCode;
}
if (this.conf.keys[keyCode]) {
this.conf.keys[keyCode].bind(this)();
return Event.stop(event);
}
else {
return true;
}
},
/*
* ==================== mouse wheel ====================
* Event handler for mouse wheel event
* http://adomas.org/javascript-mouse-wheel/
*/
_wheel: function (event) {
if (!event) var event = window.event; // MS
var delta = 0;
if (event.wheelDelta) {
delta = event.wheelDelta/120;
} else if (event.detail) {
delta = -event.detail/3;
}
if (delta) {
var target = this._targetPosition ;
if (delta < 0 ) {
target += (1 * this.conf.scrollWheelSpeed);
} else {
target -= (1 * this.conf.scrollWheelSpeed);
}
this.moveToPosition(Math.round(target));
}
return Event.stop(event);
},
/*
* ==================== set global Caption ====================
*/
_setGlobalCaption: function () {
if (this.globalCaption) {
this.globalCaption.innerHTML = '';
if(this._activeItem && this._activeItem.caption)
this.globalCaption.appendChild(this._activeItem.caption.cloneNode(true));
}
},
/*
* ==================== move items ====================
*/
/*
* intend to make a step
*/
_initStep: function (holdSlider, holdPos) {
if (this.Slider) {
if(holdSlider) {
this.Slider.locked = true;
} else {
this.Slider.locked = false;
}
}
this._holdPos = holdPos == true ? true : false;
if (!this._stepLock) {
this._stepLock = true;
this._step();
}
},
/*
* make a step
*/
_step: function () {
var diff = this._targetPosition - this._currentPosition;
var absDiff = Math.abs(diff);
if ( absDiff > 0.1) { // till activeItem is nearly at position 0
this._currentPosition += this.conf.flowSpeedFactor * this.conf.calcStepWidth(diff, absDiff, this.items.length, this.conf.visibleItems);
var AI = this.items[(this._getIndexByPosition(this._currentPosition))];
if (AI && AI != this._activeItem) {
if (this._activeItem) this._activeItem.makeInactive();
this._activeItem = AI;
this._activeItem.makeActive();
this._setCaptionLabel(this._activeItem.index);
if (Math.abs(this._targetPosition - this._currentPosition) <= 0.5 ) this.conf.onReachTarget(this._activeItem);
}
this._positionItems(false);
var st = this._step.bind(this);
window.setTimeout(st,this._millisecondsPerStep);
} else if (!this._holdPos) {
if (this.Slider) this.Slider.locked = false;
this._currentPosition = Math.round(this._currentPosition);
if(this.Position && !this.Slider.locked && this._activeItem) {
this._setCaptionLabel(this._activeItem.index);
}
this._positionItems(false);
this._stepLock = false;
} else {
this._stepLock = false;
}
if (this.Slider && !this.Slider.locked) {
this.Slider.setPosition(this._currentPosition);
}
if(this._stepLock == false) {
this._positionItems(true);
}
},
/* ------------------------------------------------------------------------------------------------------ */
/*
* position items
*/
_positionItems: function (bFullPixels) {
if (this._lastStart) {
var item = this._lastStart;
while (item) {
item.element.style.display="none";
item = item.next;
if (item == this._lastStart) break;
if (item && item.pre == this._lastEnd) break;
}
}
else {
this._lastStart = this._activeItem;
}
if (!this._activeItem) return;
var currentItem = this._activeItem;
var itemP = currentItem.pre;
var itemN = currentItem.next;
this._positionItem(currentItem, 0, bFullPixels);
for (var i=1; i <= this.conf.visibleItems && 2*i < this.items.length ; i++) {
if (itemP) {
this._positionItem(itemP, -i, bFullPixels);
this._lastStart = itemP;
itemP = itemP.pre;
}
if (itemN) {
this._positionItem(itemN, i, bFullPixels);
this._lastEnd = itemN;
itemN = itemN.next;
}
}
},
_positionItem: function (item, relativeIndex, bFullPixels) {
var conf = this.conf;
var vF = conf.verticalFlow;
var els = item.element.style;
//els.display =" none";
//if (els.display != "none") return;
/* Index and position relative to activeItem */
var p = item.position = this._currentPosition + relativeIndex;
var relativePosition = item.relativePosition = Math.round(p) - this._currentPosition;
var relativePositionNormed = item.relativePositionNormed = conf.visibleItems > 0 ? relativePosition/conf.visibleItems : 0;
var side = relativePosition < 0 ? -1 : 1;
side *= relativePosition == 0 ? 0 : 1;
item.side = side;
var size = conf.calcSize(item);
size.height = Math.max(size.height, 0);
size.width = Math.max(size.width, 0);
if (item.content.origProportion) size = this._scaleImageSize(item, size);
item.size = size;
var coords = item.coordinates = conf.calcCoordinates (item);
var relItemPos = item.relativeItemPosition = conf.calcRelativeItemPosition(item);
var zIndex = item.zIndex = conf.calcZIndex (item);
var fontSize = item.fontSize = conf.calcFontSize (item);
var opacity = item.opacity = conf.calcOpacity(item);
size.height *= this.maxHeight;
size.width *= this.maxHeight;
/* set position */
var sA = vF ? size.height : size.width;
var sB = vF ? size.width : size.height;
var pX = this.Flow.center.x * ( 1 + coords.x ) + (relItemPos.x - 1) * sA/2;
var pY = this.maxHeight/2 * ( 1 + coords.y ) + (relItemPos.y - 1 )* sB/2;
if(bFullPixels) {
pX = Math.floor(pX);
pY = Math.floor(pY);
fontSize = Math.floor(fontSize);
}
els.left = (vF ? pY : pX)+"px";
els.top = (vF ? pX : pY)+"px";
this._setItemSize(item, size, bFullPixels);
/* set opacity */
if (conf.endOpacity != 1) {
this._setItemOpacity(item);
}
/* set font size */
if (!this.Browser.IE) els.fontSize = (fontSize * 100) +"%";
/* set z-index */
els.zIndex = 32768 + Math.round(zIndex * this.items.length); // just for FF
conf.onDrawItem(item);
els.visibility = "visible";
els.display = "block";
},
_scaleImageSize: function (item, size, max) {
var sFL = this.conf.scaleFactorLandscape;
var sFP = this.conf.scaleFactorPortrait;
var vF = this.conf.verticalFlow;
var prop = item.content.origProportion;
var width = size.width;
var height = size.height;
var c = item.content;
if (vF) {
if (prop <= 1) {
if (sFL != "max" && sFL != 1) {
height *= sFL;
width = Math.min(height * prop, max ? max : 1 );
}
height = width / prop;
}
else if (prop > 1) {
if (sFP == "max") {
height = max ? max : 1;
}
else if (sFP != 1) {
width *= sFP;
height = Math.min(width/prop, max ? max : 1)
}
else {
height = width / prop;
}
width = height * prop;
}
}
else {
if (prop > 1) {
if (sFL != "max" && sFL != 1) {
width *= sFL;
height = Math.min(width / prop, max ? max : 1);
}
width = height * prop;
}
else if (prop <= 1) {
if (sFP == "max") {
width = max ? max : 1;
}
else if (sFP != 1) {
height *= sFP;
width = Math.min(height*prop, max ? max : 1);
}
else {
width = height * prop;
}
height = width / prop;
}
}
height = isNaN(height) ? 0 : height;
width = isNaN(width) ? 0 : width;
if (!max && this.conf.fixItemSize) {
var propS = size.width / size.height;
var max = Math.max(size.width, size.height);
var s = this._scaleImageSize(item, {width: max, height: max}, max);
if (propS < 1) {
height = s.height/size.height;
width = height * prop / propS;
}
else {
width = s.width/size.width;
height = width / prop * propS;
}
var h = height * 100;
var w = width * 100;
var mL= (1 - width)/2 * 100;
var mT= ( 1 - height ) / propS * 100 * (vF ? 0.5 : 1 );
c.style.height = h+"%";
if (item.reflection) item.reflection.style.height = h*this.conf.reflectionHeight+"%";
c.style.width = w+"%";
if (item.reflection) item.reflection.style.width = w+"%";
c.style.marginLeft = mL+"%";
if (item.reflection) item.reflection.style.marginLeft = mL+"%";
c.style.marginTop = mT+"%";
item.element.style.overflow = "hidden";
return size;
}
else {
return {width: width, height: height};
}
},
_setItemSize: (function () {
if (ContentFlowGlobal.Browser.IE) {
var _setItemSize = function (item, size, bFullPixels) {
if (!this.conf.fixItemSize) {
item.content.style.height = size.height+"px";
}
else if (ContentFlowGlobal.Browser.IE6) {
var h = parseInt(item.content.style.height)/100;
item.content.style.height = size.height*h+"px";
var mT = parseInt(item.content.style.marginTop)/100;
item.content.style.marginTop = size.height*mT+"px";
}
if (item.reflection) {
var h = parseInt(item.content.style.height);
item.reflection.style.height = h*this.conf.reflectionHeight+"px";
item.reflection.style.marginTop = h * this.conf.reflectionGap + "px";
}
if(bFullPixels) {
item.element.style.width = Math.floor(size.width) +"px";
item.element.style.height = Math.floor(size.height*(1+this.conf.reflectionHeight+this.conf.reflectionGap))+"px";
}
else {
item.element.style.width = size.width +"px";
item.element.style.height = size.height*(1+this.conf.reflectionHeight+this.conf.reflectionGap)+"px";
}
}
}
else {
var _setItemSize = function (item, size, bFullPixels) {
if(bFullPixels) {
if (item.reflection) {
item.element.style.height = Math.floor(size.height*(1+this.conf.reflectionHeight + this.conf.reflectionGap)) +"px";
item.reflection.style.marginTop = Math.floor(size.height * this.conf.reflectionGap) + "px";
}
else if (this._reflectionWithinImage) {
item.element.style.height = Math.floor(size.height*(1+this.conf.reflectionHeight + this.conf.reflectionGap)) +"px";
}
else {
item.element.style.height = Math.floor(size.height) +"px";
}
item.element.style.width = Math.floor(size.width) +"px";
}
else {
if (item.reflection) {
item.element.style.height = size.height*(1+this.conf.reflectionHeight + this.conf.reflectionGap) +"px";
item.reflection.style.marginTop = size.height * this.conf.reflectionGap + "px";
}
else if (this._reflectionWithinImage) {
item.element.style.height = size.height*(1+this.conf.reflectionHeight + this.conf.reflectionGap) +"px";
}
else {
item.element.style.height = size.height +"px";
}
item.element.style.width = size.width +"px";
}
}
}
return _setItemSize;
})(),
_setItemOpacity: (function () {
if (ContentFlowGlobal.Browser.IE6) {
var _setItemOpacity = function (item) {
if (item.content.origSrc && item.content.origSrc.match(/\.png$/) ) {
var s = item.content.src;
item.content.src = item.content.origSrc;
item.content.style.filter = item.content.filterString+" progid:DXImageTransform.Microsoft.BasicImage(opacity="+item.opacity+")";
item.content.src = s;
}
else {
item.content.style.filter = "progid:DXImageTransform.Microsoft.BasicImage(opacity="+item.opacity+")";
}
if (item.reflection) item.reflection.style.filter = item.reflection.filterString+"progid:DXImageTransform.Microsoft.BasicImage(opacity="+item.opacity+")";
}
}
else if (ContentFlowGlobal.Browser.IE) {
var _setItemOpacity = function (item) {item.element.style.filter = "progid:DXImageTransform.Microsoft.BasicImage(opacity="+item.opacity+")";}
}
else {
var _setItemOpacity = function (item) {item.element.style.opacity = item.opacity;}
}
return _setItemOpacity;
})()
};
/* ==================== extendig javascript/DOM objects ==================== */
/*
* adds bind method to Function class
* http://www.digital-web.com/articles/scope_in_javascript/
*/
if (!Function.bind) {
Function.prototype.bind = function(obj) {
var method = this;
return function () {
return method.apply(obj, arguments);
};
};
}
/*
* extending Math object
*/
if (!Math.erf2) {
// error function (http://en.wikipedia.org/wiki/Error_function), implemented as erf(x)^2
Math.erf2 = function (x) {
var a = - (8*(Math.PI -3)/(3*Math.PI*(Math.PI -4)));
var x2 = x*x;
var f = 1 - Math.pow(Math.E, -x2 * (4/Math.PI + a*x2)/(1+a*x2));
return f;
};
}
if (!Math._2PI05) {
Math._2PI05 = Math.sqrt(2*Math.PI);
}
if (!Math.normDist) {
// normal distribution
Math.normDist = function (x, sig, mu) {
if (!sig) var sig = 1;
if (!mu) var mu = 0;
if (!x) var x = - mu;
return 1/(sig * Math._2PI05) * Math.pow(Math.E, - (x-mu)*(x-mu)/(2*sig*sig) );
};
}
if (!Math.normedNormDist) {
Math.normedNormDist = function (x, sig, mu) {
return this.normDist(x, sig, mu)/this.normDist(mu, sig, mu);
};
}
if (!Math.exp) {
Math.exp = function(x) {
return Math.pow(Math.E, x);
};
}
if (!Math.ln) {
Math.ln = Math.log;
}
if (!Math.log2) {
Math.log2 = function (x) {
return Math.log(x)/Math.LN2;
};
}
if (!Math.log10) {
Math.log10 = function (x) {
return Math.log(x)/Math.LN10;
};
}
if (!Math.logerithm) {
Math.logerithm = function (x, b) {
if (!b || b == Math.E)
return Math.log(x);
else if (b == 2)
return Math.log2(x);
else if (b == 10)
return Math.log10(x);
else
return Math.log(x)/Math.log(b);
};
}
/*
* extending Event object
*/
if (!Event) var Event = {};
if (!Event.stop) {
Event.stop = function (event) {
event.cancelBubble = true;
if (event.preventDefault) event.preventDefault();
if (event.stopPropagation) event.stopPropagation();
return false;
};
}
/*
* extending Element object
*/
if (document.all && !window.opera) {
window.$CF = function (el) {
if (typeof el == "string") {
return window.$CF(document.getElementById(el));
}
else {
if (CFElement.prototype.extend && el && !el.extend) CFElement.prototype.extend(el);
}
return el;
};
} else {
window.$CF = function (el) {
return el;
};
}
if (!window.HTMLElement) {
CFElement = {};
CFElement.prototype = {};
CFElement.prototype.extend = function (el) {
for (var method in this) {
if (!el[method]) el[method] = this[method];
}
};
}
else {
CFElement = window.HTMLElement;
}
/*
* Thanks to Peter-Paul Koch
* http://www.quirksmode.org/js/findpos.html
*/
if (!CFElement.findPos) {
CFElement.prototype.findPos = function() {
var obj = this;
var curleft = curtop = 0;
try {
if (obj.offsetParent) {
curleft = obj.offsetLeft;
curtop = obj.offsetTop;
while (obj = obj.offsetParent) {
curleft += obj.offsetLeft;
curtop += obj.offsetTop;
}
}
}
catch (ex) {}
return {left:curleft, top:curtop};
};
}
//BH: if (!CFElement.getDimensions) {
CFElement.prototype.getDimensions = function() {
return {width: /*BH: this.clientWidth*/1300, height: /*BH: this.clientHeight*/406};
};
//BH: }
/*
* checks if an element has the class className
*/
if (!CFElement.hasClassName) {
CFElement.prototype.hasClassName = function(className) {
return (new RegExp('\\b'+className+'\\b').test(this.className));
};
}
/*
* adds the class className to the element
*/
if (!CFElement.addClassName) {
CFElement.prototype.addClassName = function(className) {
if(!this.hasClassName(className)) {
this.className += (this.className ? ' ':'') + className ;
}
};
}
/*
* removes the class className from the element el
*/
if (!CFElement.removeClassName) {
CFElement.prototype.removeClassName = function(className) {
this.className = this.className.replace(new RegExp('\\b'+className+'\\b'), '').replace(/\s\s/g,' ');
};
}
/*
* removes or adds the class className from/to the element el
* depending if the element has the class className or not.
*/
if (!CFElement.toggleClassName) {
CFElement.prototype.toggleClassName = function(className) {
if(this.hasClassName(className)) {
this.removeClassName(className);
} else {
this.addClassName(className);
}
};
}
/*
* returns all children of element el, which have the class className
*/
if (!CFElement.getChildrenByClassName) {
CFElement.prototype.getChildrenByClassName = function(className) {
var children = new Array();
for (var i=0; i < this.childNodes.length; i++) {
var c = this.childNodes[i];
if (c.nodeType == 1 && $CF(c).hasClassName(className)) {
children.push(c);
}
}
return children;
};
}
/*
* Browser independent event handling method.
* adds the eventListener eventName to element el and attaches the function method to it.
*/
if (!CFElement.addEvent) {
CFElement.prototype.addEvent = function(eventName, method, capture) {
if (this.addEventListener)
this.addEventListener(eventName, method, capture);
else
this.attachEvent('on'+eventName, method);
};
}
/*
* Browser independent event handling method.
* removes the eventListener eventName with the attached function method from element el.
*/
if (!CFElement.removeEvent) {
CFElement.prototype.removeEvent = function(eventName, method, capture) {
if (this.removeEventListener)
this.removeEventListener(eventName, method, capture);
else
this.detachEvent('on'+eventName, method);
};
}
/*
* Browser independent event handling method.
* adds the eventListener eventName to element el and attaches the function method to it.
*/
if (!window.addEvent) {
window.addEvent = function(eventName, method, capture) {
if (this.addEventListener) {
this.addEventListener(eventName, method, capture);
} else {
if (eventName != 'load' && eventName != 'resize')
document.attachEvent('on'+eventName, method);
else
this.attachEvent('on'+eventName, method);
}
};
}
/*
* Browser independent event handling method.
* removes the eventListener eventName with the attached function method from element el.
*/
if (!window.removeEvent) {
window.removeEvent = function(eventName, method, capture) {
if (this.removeEventListener) {
this.removeEventListener(eventName, method, capture);
} else {
if (eventName != 'load' && eventName != 'resize')
document.detachEvent('on'+eventName, method);
else
this.detachEvent('on'+eventName, method);
}
};
}
/* ==================== start it all up ==================== */
ContentFlowGlobal.init();
/*******************************************************************************
jquery-1.5.2.min.js
*******************************************************************************/
/*!
* jQuery JavaScript Library v1.5.2
* http://jquery.com/
*
* Copyright 2011, John Resig
* Dual licensed under the MIT or GPL Version 2 licenses.
* http://jquery.org/license
*
* Includes Sizzle.js
* http://sizzlejs.com/
* Copyright 2011, The Dojo Foundation
* Released under the MIT, BSD, and GPL Licenses.
*
* Date: Thu Mar 31 15:28:23 2011 -0400
*/
(function(a,b){function ci(a){return d.isWindow(a)?a:a.nodeType===9?a.defaultView||a.parentWindow:!1}function cf(a){if(!b_[a]){var b=d("<"+a+">").appendTo("body"),c=b.css("display");b.remove();if(c==="none"||c==="")c="block";b_[a]=c}return b_[a]}function ce(a,b){var c={};d.each(cd.concat.apply([],cd.slice(0,b)),function(){c[this]=a});return c}function b$(){try{return new a.ActiveXObject("Microsoft.XMLHTTP")}catch(b){}}function bZ(){try{return new a.XMLHttpRequest}catch(b){}}function bY(){d(a).unload(function(){for(var a in bW)bW[a](0,1)})}function bS(a,c){a.dataFilter&&(c=a.dataFilter(c,a.dataType));var e=a.dataTypes,f={},g,h,i=e.length,j,k=e[0],l,m,n,o,p;for(g=1;g=0===c})}function P(a){return!a||!a.parentNode||a.parentNode.nodeType===11}function H(a,b){return(a&&a!=="*"?a+".":"")+b.replace(t,"`").replace(u,"&")}function G(a){var b,c,e,f,g,h,i,j,k,l,m,n,o,p=[],q=[],s=d._data(this,"events");if(a.liveFired!==this&&s&&s.live&&!a.target.disabled&&(!a.button||a.type!=="click")){a.namespace&&(n=new RegExp("(^|\\.)"+a.namespace.split(".").join("\\.(?:.*\\.)?")+"(\\.|$)")),a.liveFired=this;var t=s.live.slice(0);for(i=0;ic)break;a.currentTarget=f.elem,a.data=f.handleObj.data,a.handleObj=f.handleObj,o=f.handleObj.origHandler.apply(f.elem,arguments);if(o===!1||a.isPropagationStopped()){c=f.level,o===!1&&(b=!1);if(a.isImmediatePropagationStopped())break}}return b}}function E(a,c,e){var f=d.extend({},e[0]);f.type=a,f.originalEvent={},f.liveFired=b,d.event.handle.call(c,f),f.isDefaultPrevented()&&e[0].preventDefault()}function y(){return!0}function x(){return!1}function i(a){for(var b in a)if(b!=="toJSON")return!1;return!0}function h(a,c,e){if(e===b&&a.nodeType===1){e=a.getAttribute("data-"+c);if(typeof e==="string"){try{e=e==="true"?!0:e==="false"?!1:e==="null"?null:d.isNaN(e)?g.test(e)?d.parseJSON(e):e:parseFloat(e)}catch(f){}d.data(a,c,e)}else e=b}return e}var c=a.document,d=function(){function G(){if(!d.isReady){try{c.documentElement.doScroll("left")}catch(a){setTimeout(G,1);return}d.ready()}}var d=function(a,b){return new d.fn.init(a,b,g)},e=a.jQuery,f=a.$,g,h=/^(?:[^<]*(<[\w\W]+>)[^>]*$|#([\w\-]+)$)/,i=/\S/,j=/^\s+/,k=/\s+$/,l=/\d/,m=/^<(\w+)\s*\/?>(?:<\/\1>)?$/,n=/^[\],:{}\s]*$/,o=/\\(?:["\\\/bfnrt]|u[0-9a-fA-F]{4})/g,p=/"[^"\\\n\r]*"|true|false|null|-?\d+(?:\.\d*)?(?:[eE][+\-]?\d+)?/g,q=/(?:^|:|,)(?:\s*\[)+/g,r=/(webkit)[ \/]([\w.]+)/,s=/(opera)(?:.*version)?[ \/]([\w.]+)/,t=/(msie) ([\w.]+)/,u=/(mozilla)(?:.*? rv:([\w.]+))?/,v=navigator.userAgent,w,x,y,z=Object.prototype.toString,A=Object.prototype.hasOwnProperty,B=Array.prototype.push,C=Array.prototype.slice,D=String.prototype.trim,E=Array.prototype.indexOf,F={};d.fn=d.prototype={constructor:d,init:function(a,e,f){var g,i,j,k;if(!a)return this;if(a.nodeType){this.context=this[0]=a,this.length=1;return this}if(a==="body"&&!e&&c.body){this.context=c,this[0]=c.body,this.selector="body",this.length=1;return this}if(typeof a==="string"){g=h.exec(a);if(!g||!g[1]&&e)return!e||e.jquery?(e||f).find(a):this.constructor(e).find(a);if(g[1]){e=e instanceof d?e[0]:e,k=e?e.ownerDocument||e:c,j=m.exec(a),j?d.isPlainObject(e)?(a=[c.createElement(j[1])],d.fn.attr.call(a,e,!0)):a=[k.createElement(j[1])]:(j=d.buildFragment([g[1]],[k]),a=(j.cacheable?d.clone(j.fragment):j.fragment).childNodes);return d.merge(this,a)}i=c.getElementById(g[2]);if(i&&i.parentNode){if(i.id!==g[2])return f.find(a);this.length=1,this[0]=i}this.context=c,this.selector=a;return this}if(d.isFunction(a))return f.ready(a);a.selector!==b&&(this.selector=a.selector,this.context=a.context);return d.makeArray(a,this)},selector:"",jquery:"1.5.2",length:0,size:function(){return this.length},toArray:function(){return C.call(this,0)},get:function(a){return a==null?this.toArray():a<0?this[this.length+a]:this[a]},pushStack:function(a,b,c){var e=this.constructor();d.isArray(a)?B.apply(e,a):d.merge(e,a),e.prevObject=this,e.context=this.context,b==="find"?e.selector=this.selector+(this.selector?" ":"")+c:b&&(e.selector=this.selector+"."+b+"("+c+")");return e},each:function(a,b){return d.each(this,a,b)},ready:function(a){d.bindReady(),x.done(a);return this},eq:function(a){return a===-1?this.slice(a):this.slice(a,+a+1)},first:function(){return this.eq(0)},last:function(){return this.eq(-1)},slice:function(){return this.pushStack(C.apply(this,arguments),"slice",C.call(arguments).join(","))},map:function(a){return this.pushStack(d.map(this,function(b,c){return a.call(b,c,b)}))},end:function(){return this.prevObject||this.constructor(null)},push:B,sort:[].sort,splice:[].splice},d.fn.init.prototype=d.fn,d.extend=d.fn.extend=function(){var a,c,e,f,g,h,i=arguments[0]||{},j=1,k=arguments.length,l=!1;typeof i==="boolean"&&(l=i,i=arguments[1]||{},j=2),typeof i!=="object"&&!d.isFunction(i)&&(i={}),k===j&&(i=this,--j);for(;j0)return;x.resolveWith(c,[d]),d.fn.trigger&&d(c).trigger("ready").unbind("ready")}},bindReady:function(){if(!x){x=d._Deferred();if(c.readyState==="complete")return setTimeout(d.ready,1);if(c.addEventListener)c.addEventListener("DOMContentLoaded",y,!1),a.addEventListener("load",d.ready,!1);else if(c.attachEvent){c.attachEvent("onreadystatechange",y),a.attachEvent("onload",d.ready);var b=!1;try{b=a.frameElement==null}catch(e){}c.documentElement.doScroll&&b&&G()}}},isFunction:function(a){return d.type(a)==="function"},isArray:Array.isArray||function(a){return d.type(a)==="array"},isWindow:function(a){return a&&typeof a==="object"&&"setInterval"in a},isNaN:function(a){return a==null||!l.test(a)||isNaN(a)},type:function(a){return a==null?String(a):F[z.call(a)]||"object"},isPlainObject:function(a){if(!a||d.type(a)!=="object"||a.nodeType||d.isWindow(a))return!1;if(a.constructor&&!A.call(a,"constructor")&&!A.call(a.constructor.prototype,"isPrototypeOf"))return!1;var c;for(c in a){}return c===b||A.call(a,c)},isEmptyObject:function(a){for(var b in a)return!1;return!0},error:function(a){throw a},parseJSON:function(b){if(typeof b!=="string"||!b)return null;b=d.trim(b);if(n.test(b.replace(o,"@").replace(p,"]").replace(q,"")))return a.JSON&&a.JSON.parse?a.JSON.parse(b):(new Function("return "+b))();d.error("Invalid JSON: "+b)},parseXML:function(b,c,e){a.DOMParser?(e=new DOMParser,c=e.parseFromString(b,"text/xml")):(c=new ActiveXObject("Microsoft.XMLDOM"),c.async="false",c.loadXML(b)),e=c.documentElement,(!e||!e.nodeName||e.nodeName==="parsererror")&&d.error("Invalid XML: "+b);return c},noop:function(){},globalEval:function(a){if(a&&i.test(a)){var b=c.head||c.getElementsByTagName("head")[0]||c.documentElement,e=c.createElement("script");d.support.scriptEval()?e.appendChild(c.createTextNode(a)):e.text=a,b.insertBefore(e,b.firstChild),b.removeChild(e)}},nodeName:function(a,b){return a.nodeName&&a.nodeName.toUpperCase()===b.toUpperCase()},each:function(a,c,e){var f,g=0,h=a.length,i=h===b||d.isFunction(a);if(e){if(i){for(f in a)if(c.apply(a[f],e)===!1)break}else for(;g1?f.call(arguments,0):c,--g||h.resolveWith(h,f.call(b,0))}}var b=arguments,c=0,e=b.length,g=e,h=e<=1&&a&&d.isFunction(a.promise)?a:d.Deferred();if(e>1){for(;ca";var e=b.getElementsByTagName("*"),f=b.getElementsByTagName("a")[0],g=c.createElement("select"),h=g.appendChild(c.createElement("option")),i=b.getElementsByTagName("input")[0];if(e&&e.length&&f){d.support={leadingWhitespace:b.firstChild.nodeType===3,tbody:!b.getElementsByTagName("tbody").length,htmlSerialize:!!b.getElementsByTagName("link").length,style:/red/.test(f.getAttribute("style")),hrefNormalized:f.getAttribute("href")==="/a",opacity:/^0.55$/.test(f.style.opacity),cssFloat:!!f.style.cssFloat,checkOn:i.value==="on",optSelected:h.selected,deleteExpando:!0,optDisabled:!1,checkClone:!1,noCloneEvent:!0,noCloneChecked:!0,boxModel:null,inlineBlockNeedsLayout:!1,shrinkWrapBlocks:!1,reliableHiddenOffsets:!0,reliableMarginRight:!0},i.checked=!0,d.support.noCloneChecked=i.cloneNode(!0).checked,g.disabled=!0,d.support.optDisabled=!h.disabled;var j=null;d.support.scriptEval=function(){if(j===null){var b=c.documentElement,e=c.createElement("script"),f="script"+d.now();try{e.appendChild(c.createTextNode("window."+f+"=1;"))}catch(g){}b.insertBefore(e,b.firstChild),a[f]?(j=!0,delete a[f]):j=!1,b.removeChild(e)}return j};try{delete b.test}catch(k){d.support.deleteExpando=!1}!b.addEventListener&&b.attachEvent&&b.fireEvent&&(b.attachEvent("onclick",function l(){d.support.noCloneEvent=!1,b.detachEvent("onclick",l)}),b.cloneNode(!0).fireEvent("onclick")),b=c.createElement("div"),b.innerHTML="";var m=c.createDocumentFragment();m.appendChild(b.firstChild),d.support.checkClone=m.cloneNode(!0).cloneNode(!0).lastChild.checked,d(function(){var a=c.createElement("div"),b=c.getElementsByTagName("body")[0];if(b){a.style.width=a.style.paddingLeft="1px",b.appendChild(a),d.boxModel=d.support.boxModel=a.offsetWidth===2,"zoom"in a.style&&(a.style.display="inline",a.style.zoom=1,d.support.inlineBlockNeedsLayout=a.offsetWidth===2,a.style.display="",a.innerHTML="",d.support.shrinkWrapBlocks=a.offsetWidth!==2),a.innerHTML="";var e=a.getElementsByTagName("td");d.support.reliableHiddenOffsets=e[0].offsetHeight===0,e[0].style.display="",e[1].style.display="none",d.support.reliableHiddenOffsets=d.support.reliableHiddenOffsets&&e[0].offsetHeight===0,a.innerHTML="",c.defaultView&&c.defaultView.getComputedStyle&&(a.style.width="1px",a.style.marginRight="0",d.support.reliableMarginRight=(parseInt(c.defaultView.getComputedStyle(a,null).marginRight,10)||0)===0),b.removeChild(a).style.display="none",a=e=null}});var n=function(a){var b=c.createElement("div");a="on"+a;if(!b.attachEvent)return!0;var d=a in b;d||(b.setAttribute(a,"return;"),d=typeof b[a]==="function");return d};d.support.submitBubbles=n("submit"),d.support.changeBubbles=n("change"),b=e=f=null}}();var g=/^(?:\{.*\}|\[.*\])$/;d.extend({cache:{},uuid:0,expando:"jQuery"+(d.fn.jquery+Math.random()).replace(/\D/g,""),noData:{embed:!0,object:"clsid:D27CDB6E-AE6D-11cf-96B8-444553540000",applet:!0},hasData:function(a){a=a.nodeType?d.cache[a[d.expando]]:a[d.expando];return!!a&&!i(a)},data:function(a,c,e,f){if(d.acceptData(a)){var g=d.expando,h=typeof c==="string",i,j=a.nodeType,k=j?d.cache:a,l=j?a[d.expando]:a[d.expando]&&d.expando;if((!l||f&&l&&!k[l][g])&&h&&e===b)return;l||(j?a[d.expando]=l=++d.uuid:l=d.expando),k[l]||(k[l]={},j||(k[l].toJSON=d.noop));if(typeof c==="object"||typeof c==="function")f?k[l][g]=d.extend(k[l][g],c):k[l]=d.extend(k[l],c);i=k[l],f&&(i[g]||(i[g]={}),i=i[g]),e!==b&&(i[c]=e);if(c==="events"&&!i[c])return i[g]&&i[g].events;return h?i[c]:i}},removeData:function(b,c,e){if(d.acceptData(b)){var f=d.expando,g=b.nodeType,h=g?d.cache:b,j=g?b[d.expando]:d.expando;if(!h[j])return;if(c){var k=e?h[j][f]:h[j];if(k){delete k[c];if(!i(k))return}}if(e){delete h[j][f];if(!i(h[j]))return}var l=h[j][f];d.support.deleteExpando||h!=a?delete h[j]:h[j]=null,l?(h[j]={},g||(h[j].toJSON=d.noop),h[j][f]=l):g&&(d.support.deleteExpando?delete b[d.expando]:b.removeAttribute?b.removeAttribute(d.expando):b[d.expando]=null)}},_data:function(a,b,c){return d.data(a,b,c,!0)},acceptData:function(a){if(a.nodeName){var b=d.noData[a.nodeName.toLowerCase()];if(b)return b!==!0&&a.getAttribute("classid")===b}return!0}}),d.fn.extend({data:function(a,c){var e=null;if(typeof a==="undefined"){if(this.length){e=d.data(this[0]);if(this[0].nodeType===1){var f=this[0].attributes,g;for(var i=0,j=f.length;i-1)return!0;return!1},val:function(a){if(!arguments.length){var c=this[0];if(c){if(d.nodeName(c,"option")){var e=c.attributes.value;return!e||e.specified?c.value:c.text}if(d.nodeName(c,"select")){var f=c.selectedIndex,g=[],h=c.options,i=c.type==="select-one";if(f<0)return null;for(var j=i?f:0,k=i?f+1:h.length;j=0;else if(d.nodeName(this,"select")){var f=d.makeArray(e);d("option",this).each(function(){this.selected=d.inArray(d(this).val(),f)>=0}),f.length||(this.selectedIndex=-1)}else this.value=e}})}}),d.extend({attrFn:{val:!0,css:!0,html:!0,text:!0,data:!0,width:!0,height:!0,offset:!0},attr:function(a,c,e,f){if(!a||a.nodeType===3||a.nodeType===8||a.nodeType===2)return b;if(f&&c in d.attrFn)return d(a)[c](e);var g=a.nodeType!==1||!d.isXMLDoc(a),h=e!==b;c=g&&d.props[c]||c;if(a.nodeType===1){var i=m.test(c);if(c==="selected"&&!d.support.optSelected){var j=a.parentNode;j&&(j.selectedIndex,j.parentNode&&j.parentNode.selectedIndex)}if((c in a||a[c]!==b)&&g&&!i){h&&(c==="type"&&n.test(a.nodeName)&&a.parentNode&&d.error("type property can't be changed"),e===null?a.nodeType===1&&a.removeAttribute(c):a[c]=e);if(d.nodeName(a,"form")&&a.getAttributeNode(c))return a.getAttributeNode(c).nodeValue;if(c==="tabIndex"){var k=a.getAttributeNode("tabIndex");return k&&k.specified?k.value:o.test(a.nodeName)||p.test(a.nodeName)&&a.href?0:b}return a[c]}if(!d.support.style&&g&&c==="style"){h&&(a.style.cssText=""+e);return a.style.cssText}h&&a.setAttribute(c,""+e);if(!a.attributes[c]&&(a.hasAttribute&&!a.hasAttribute(c)))return b;var l=!d.support.hrefNormalized&&g&&i?a.getAttribute(c,2):a.getAttribute(c);return l===null?b:l}h&&(a[c]=e);return a[c]}});var r=/\.(.*)$/,s=/^(?:textarea|input|select)$/i,t=/\./g,u=/ /g,v=/[^\w\s.|`]/g,w=function(a){return a.replace(v,"\\$&")};d.event={add:function(c,e,f,g){if(c.nodeType!==3&&c.nodeType!==8){try{d.isWindow(c)&&(c!==a&&!c.frameElement)&&(c=a)}catch(h){}if(f===!1)f=x;else if(!f)return;var i,j;f.handler&&(i=f,f=i.handler),f.guid||(f.guid=d.guid++);var k=d._data(c);if(!k)return;var l=k.events,m=k.handle;l||(k.events=l={}),m||(k.handle=m=function(a){return typeof d!=="undefined"&&d.event.triggered!==a.type?d.event.handle.apply(m.elem,arguments):b}),m.elem=c,e=e.split(" ");var n,o=0,p;while(n=e[o++]){j=i?d.extend({},i):{handler:f,data:g},n.indexOf(".")>-1?(p=n.split("."),n=p.shift(),j.namespace=p.slice(0).sort().join(".")):(p=[],j.namespace=""),j.type=n,j.guid||(j.guid=f.guid);var q=l[n],r=d.event.special[n]||{};if(!q){q=l[n]=[];if(!r.setup||r.setup.call(c,g,p,m)===!1)c.addEventListener?c.addEventListener(n,m,!1):c.attachEvent&&c.attachEvent("on"+n,m)}r.add&&(r.add.call(c,j),j.handler.guid||(j.handler.guid=f.guid)),q.push(j),d.event.global[n]=!0}c=null}},global:{},remove:function(a,c,e,f){if(a.nodeType!==3&&a.nodeType!==8){e===!1&&(e=x);var g,h,i,j,k=0,l,m,n,o,p,q,r,s=d.hasData(a)&&d._data(a),t=s&&s.events;if(!s||!t)return;c&&c.type&&(e=c.handler,c=c.type);if(!c||typeof c==="string"&&c.charAt(0)==="."){c=c||"";for(h in t)d.event.remove(a,h+c);return}c=c.split(" ");while(h=c[k++]){r=h,q=null,l=h.indexOf(".")<0,m=[],l||(m=h.split("."),h=m.shift(),n=new RegExp("(^|\\.)"+d.map(m.slice(0).sort(),w).join("\\.(?:.*\\.)?")+"(\\.|$)")),p=t[h];if(!p)continue;if(!e){for(j=0;j=0&&(a.type=f=f.slice(0,-1),a.exclusive=!0),e||(a.stopPropagation(),d.event.global[f]&&d.each(d.cache,function(){var b=d.expando,e=this[b];e&&e.events&&e.events[f]&&d.event.trigger(a,c,e.handle.elem)}));if(!e||e.nodeType===3||e.nodeType===8)return b;a.result=b,a.target=e,c=d.makeArray(c),c.unshift(a)}a.currentTarget=e;var h=d._data(e,"handle");h&&h.apply(e,c);var i=e.parentNode||e.ownerDocument;try{e&&e.nodeName&&d.noData[e.nodeName.toLowerCase()]||e["on"+f]&&e["on"+f].apply(e,c)===!1&&(a.result=!1,a.preventDefault())}catch(j){}if(!a.isPropagationStopped()&&i)d.event.trigger(a,c,i,!0);else if(!a.isDefaultPrevented()){var k,l=a.target,m=f.replace(r,""),n=d.nodeName(l,"a")&&m==="click",o=d.event.special[m]||{};if((!o._default||o._default.call(e,a)===!1)&&!n&&!(l&&l.nodeName&&d.noData[l.nodeName.toLowerCase()])){try{l[m]&&(k=l["on"+m],k&&(l["on"+m]=null),d.event.triggered=a.type,l[m]())}catch(p){}k&&(l["on"+m]=k),d.event.triggered=b}}},handle:function(c){var e,f,g,h,i,j=[],k=d.makeArray(arguments);c=k[0]=d.event.fix(c||a.event),c.currentTarget=this,e=c.type.indexOf(".")<0&&!c.exclusive,e||(g=c.type.split("."),c.type=g.shift(),j=g.slice(0).sort(),h=new RegExp("(^|\\.)"+j.join("\\.(?:.*\\.)?")+"(\\.|$)")),c.namespace=c.namespace||j.join("."),i=d._data(this,"events"),f=(i||{})[c.type];if(i&&f){f=f.slice(0);for(var l=0,m=f.length;l-1?d.map(a.options,function(a){return a.selected}).join("-"):"":a.nodeName.toLowerCase()==="select"&&(c=a.selectedIndex);return c},D=function D(a){var c=a.target,e,f;if(s.test(c.nodeName)&&!c.readOnly){e=d._data(c,"_change_data"),f=C(c),(a.type!=="focusout"||c.type!=="radio")&&d._data(c,"_change_data",f);if(e===b||f===e)return;if(e!=null||f)a.type="change",a.liveFired=b,d.event.trigger(a,arguments[1],c)}};d.event.special.change={filters:{focusout:D,beforedeactivate:D,click:function(a){var b=a.target,c=b.type;(c==="radio"||c==="checkbox"||b.nodeName.toLowerCase()==="select")&&D.call(this,a)},keydown:function(a){var b=a.target,c=b.type;(a.keyCode===13&&b.nodeName.toLowerCase()!=="textarea"||a.keyCode===32&&(c==="checkbox"||c==="radio")||c==="select-multiple")&&D.call(this,a)},beforeactivate:function(a){var b=a.target;d._data(b,"_change_data",C(b))}},setup:function(a,b){if(this.type==="file")return!1;for(var c in B)d.event.add(this,c+".specialChange",B[c]);return s.test(this.nodeName)},teardown:function(a){d.event.remove(this,".specialChange");return s.test(this.nodeName)}},B=d.event.special.change.filters,B.focus=B.beforeactivate}c.addEventListener&&d.each({focus:"focusin",blur:"focusout"},function(a,b){function f(a){var c=d.event.fix(a);c.type=b,c.originalEvent={},d.event.trigger(c,null,c.target),c.isDefaultPrevented()&&a.preventDefault()}var e=0;d.event.special[b]={setup:function(){e++===0&&c.addEventListener(a,f,!0)},teardown:function(){--e===0&&c.removeEventListener(a,f,!0)}}}),d.each(["bind","one"],function(a,c){d.fn[c]=function(a,e,f){if(typeof a==="object"){for(var g in a)this[c](g,e,a[g],f);return this}if(d.isFunction(e)||e===!1)f=e,e=b;var h=c==="one"?d.proxy(f,function(a){d(this).unbind(a,h);return f.apply(this,arguments)}):f;if(a==="unload"&&c!=="one")this.one(a,e,f);else for(var i=0,j=this.length;i0?this.bind(b,a,c):this.trigger(b)},d.attrFn&&(d.attrFn[b]=!0)}),function(){function u(a,b,c,d,e,f){for(var g=0,h=d.length;g0){j=i;break}}i=i[a]}d[g]=j}}}function t(a,b,c,d,e,f){for(var g=0,h=d.length;g+~,(\[\\]+)+|[>+~])(\s*,\s*)?((?:.|\r|\n)*)/g,e=0,f=Object.prototype.toString,g=!1,h=!0,i=/\\/g,j=/\W/;[0,0].sort(function(){h=!1;return 0});var k=function(b,d,e,g){e=e||[],d=d||c;var h=d;if(d.nodeType!==1&&d.nodeType!==9)return[];if(!b||typeof b!=="string")return e;var i,j,n,o,q,r,s,t,u=!0,w=k.isXML(d),x=[],y=b;do{a.exec(""),i=a.exec(y);if(i){y=i[3],x.push(i[1]);if(i[2]){o=i[3];break}}}while(i);if(x.length>1&&m.exec(b))if(x.length===2&&l.relative[x[0]])j=v(x[0]+x[1],d);else{j=l.relative[x[0]]?[d]:k(x.shift(),d);while(x.length)b=x.shift(),l.relative[b]&&(b+=x.shift()),j=v(b,j)}else{!g&&x.length>1&&d.nodeType===9&&!w&&l.match.ID.test(x[0])&&!l.match.ID.test(x[x.length-1])&&(q=k.find(x.shift(),d,w),d=q.expr?k.filter(q.expr,q.set)[0]:q.set[0]);if(d){q=g?{expr:x.pop(),set:p(g)}:k.find(x.pop(),x.length===1&&(x[0]==="~"||x[0]==="+")&&d.parentNode?d.parentNode:d,w),j=q.expr?k.filter(q.expr,q.set):q.set,x.length>0?n=p(j):u=!1;while(x.length)r=x.pop(),s=r,l.relative[r]?s=x.pop():r="",s==null&&(s=d),l.relative[r](n,s,w)}else n=x=[]}n||(n=j),n||k.error(r||b);if(f.call(n)==="[object Array]")if(u)if(d&&d.nodeType===1)for(t=0;n[t]!=null;t++)n[t]&&(n[t]===!0||n[t].nodeType===1&&k.contains(d,n[t]))&&e.push(j[t]);else for(t=0;n[t]!=null;t++)n[t]&&n[t].nodeType===1&&e.push(j[t]);else e.push.apply(e,n);else p(n,e);o&&(k(o,h,e,g),k.uniqueSort(e));return e};k.uniqueSort=function(a){if(r){g=h,a.sort(r);if(g)for(var b=1;b0},k.find=function(a,b,c){var d;if(!a)return[];for(var e=0,f=l.order.length;e":function(a,b){var c,d=typeof b==="string",e=0,f=a.length;if(d&&!j.test(b)){b=b.toLowerCase();for(;e=0)?c||d.push(h):c&&(b[g]=!1));return!1},ID:function(a){return a[1].replace(i,"")},TAG:function(a,b){return a[1].replace(i,"").toLowerCase()},CHILD:function(a){if(a[1]==="nth"){a[2]||k.error(a[0]),a[2]=a[2].replace(/^\+|\s*/g,"");var b=/(-?)(\d*)(?:n([+\-]?\d*))?/.exec(a[2]==="even"&&"2n"||a[2]==="odd"&&"2n+1"||!/\D/.test(a[2])&&"0n+"+a[2]||a[2]);a[2]=b[1]+(b[2]||1)-0,a[3]=b[3]-0}else a[2]&&k.error(a[0]);a[0]=e++;return a},ATTR:function(a,b,c,d,e,f){var g=a[1]=a[1].replace(i,"");!f&&l.attrMap[g]&&(a[1]=l.attrMap[g]),a[4]=(a[4]||a[5]||"").replace(i,""),a[2]==="~="&&(a[4]=" "+a[4]+" ");return a},PSEUDO:function(b,c,d,e,f){if(b[1]==="not")if((a.exec(b[3])||"").length>1||/^\w/.test(b[3]))b[3]=k(b[3],null,null,c);else{var g=k.filter(b[3],c,d,!0^f);d||e.push.apply(e,g);return!1}else if(l.match.POS.test(b[0])||l.match.CHILD.test(b[0]))return!0;return b},POS:function(a){a.unshift(!0);return a}},filters:{enabled:function(a){return a.disabled===!1&&a.type!=="hidden"},disabled:function(a){return a.disabled===!0},checked:function(a){return a.checked===!0},selected:function(a){a.parentNode&&a.parentNode.selectedIndex;return a.selected===!0},parent:function(a){return!!a.firstChild},empty:function(a){return!a.firstChild},has:function(a,b,c){return!!k(c[3],a).length},header:function(a){return/h\d/i.test(a.nodeName)},text:function(a){var b=a.getAttribute("type"),c=a.type;return"text"===c&&(b===c||b===null)},radio:function(a){return"radio"===a.type},checkbox:function(a){return"checkbox"===a.type},file:function(a){return"file"===a.type},password:function(a){return"password"===a.type},submit:function(a){return"submit"===a.type},image:function(a){return"image"===a.type},reset:function(a){return"reset"===a.type},button:function(a){return"button"===a.type||a.nodeName.toLowerCase()==="button"},input:function(a){return/input|select|textarea|button/i.test(a.nodeName)}},setFilters:{first:function(a,b){return b===0},last:function(a,b,c,d){return b===d.length-1},even:function(a,b){return b%2===0},odd:function(a,b){return b%2===1},lt:function(a,b,c){return bc[3]-0},nth:function(a,b,c){return c[3]-0===b},eq:function(a,b,c){return c[3]-0===b}},filter:{PSEUDO:function(a,b,c,d){var e=b[1],f=l.filters[e];if(f)return f(a,c,b,d);if(e==="contains")return(a.textContent||a.innerText||k.getText([a])||"").indexOf(b[3])>=0;if(e==="not"){var g=b[3];for(var h=0,i=g.length;h=0}},ID:function(a,b){return a.nodeType===1&&a.getAttribute("id")===b},TAG:function(a,b){return b==="*"&&a.nodeType===1||a.nodeName.toLowerCase()===b},CLASS:function(a,b){return(" "+(a.className||a.getAttribute("class"))+" ").indexOf(b)>-1},ATTR:function(a,b){var c=b[1],d=l.attrHandle[c]?l.attrHandle[c](a):a[c]!=null?a[c]:a.getAttribute(c),e=d+"",f=b[2],g=b[4];return d==null?f==="!=":f==="="?e===g:f==="*="?e.indexOf(g)>=0:f==="~="?(" "+e+" ").indexOf(g)>=0:g?f==="!="?e!==g:f==="^="?e.indexOf(g)===0:f==="$="?e.substr(e.length-g.length)===g:f==="|="?e===g||e.substr(0,g.length+1)===g+"-":!1:e&&d!==!1},POS:function(a,b,c,d){var e=b[2],f=l.setFilters[e];if(f)return f(a,c,b,d)}}},m=l.match.POS,n=function(a,b){return"\\"+(b-0+1)};for(var o in l.match)l.match[o]=new RegExp(l.match[o].source+/(?![^\[]*\])(?![^\(]*\))/.source),l.leftMatch[o]=new RegExp(/(^(?:.|\r|\n)*?)/.source+l.match[o].source.replace(/\\(\d+)/g,n));var p=function(a,b){a=Array.prototype.slice.call(a,0);if(b){b.push.apply(b,a);return b}return a};try{Array.prototype.slice.call(c.documentElement.childNodes,0)[0].nodeType}catch(q){p=function(a,b){var c=0,d=b||[];if(f.call(a)==="[object Array]")Array.prototype.push.apply(d,a);else if(typeof a.length==="number")for(var e=a.length;c",e.insertBefore(a,e.firstChild),c.getElementById(d)&&(l.find.ID=function(a,c,d){if(typeof c.getElementById!=="undefined"&&!d){var e=c.getElementById(a[1]);return e?e.id===a[1]||typeof e.getAttributeNode!=="undefined"&&e.getAttributeNode("id").nodeValue===a[1]?[e]:b:[]}},l.filter.ID=function(a,b){var c=typeof a.getAttributeNode!=="undefined"&&a.getAttributeNode("id");return a.nodeType===1&&c&&c.nodeValue===b}),e.removeChild(a),e=a=null}(),function(){var a=c.createElement("div");a.appendChild(c.createComment("")),a.getElementsByTagName("*").length>0&&(l.find.TAG=function(a,b){var c=b.getElementsByTagName(a[1]);if(a[1]==="*"){var d=[];for(var e=0;c[e];e++)c[e].nodeType===1&&d.push(c[e]);c=d}return c}),a.innerHTML="",a.firstChild&&typeof a.firstChild.getAttribute!=="undefined"&&a.firstChild.getAttribute("href")!=="#"&&(l.attrHandle.href=function(a){return a.getAttribute("href",2)}),a=null}(),c.querySelectorAll&&function(){var a=k,b=c.createElement("div"),d="__sizzle__";b.innerHTML="";if(!b.querySelectorAll||b.querySelectorAll(".TEST").length!==0){k=function(b,e,f,g){e=e||c;if(!g&&!k.isXML(e)){var h=/^(\w+$)|^\.([\w\-]+$)|^#([\w\-]+$)/.exec(b);if(h&&(e.nodeType===1||e.nodeType===9)){if(h[1])return p(e.getElementsByTagName(b),f);if(h[2]&&l.find.CLASS&&e.getElementsByClassName)return p(e.getElementsByClassName(h[2]),f)}if(e.nodeType===9){if(b==="body"&&e.body)return p([e.body],f);if(h&&h[3]){var i=e.getElementById(h[3]);if(!i||!i.parentNode)return p([],f);if(i.id===h[3])return p([i],f)}try{return p(e.querySelectorAll(b),f)}catch(j){}}else if(e.nodeType===1&&e.nodeName.toLowerCase()!=="object"){var m=e,n=e.getAttribute("id"),o=n||d,q=e.parentNode,r=/^\s*[+~]/.test(b);n?o=o.replace(/'/g,"\\$&"):e.setAttribute("id",o),r&&q&&(e=e.parentNode);try{if(!r||q)return p(e.querySelectorAll("[id='"+o+"'] "+b),f)}catch(s){}finally{n||m.removeAttribute("id")}}}return a(b,e,f,g)};for(var e in a)k[e]=a[e];b=null}}(),function(){var a=c.documentElement,b=a.matchesSelector||a.mozMatchesSelector||a.webkitMatchesSelector||a.msMatchesSelector;if(b){var d=!b.call(c.createElement("div"),"div"),e=!1;try{b.call(c.documentElement,"[test!='']:sizzle")}catch(f){e=!0}k.matchesSelector=function(a,c){c=c.replace(/\=\s*([^'"\]]*)\s*\]/g,"='$1']");if(!k.isXML(a))try{if(e||!l.match.PSEUDO.test(c)&&!/!=/.test(c)){var f=b.call(a,c);if(f||!d||a.document&&a.document.nodeType!==11)return f}}catch(g){}return k(c,null,null,[a]).length>0}}}(),function(){var a=c.createElement("div");a.innerHTML="";if(a.getElementsByClassName&&a.getElementsByClassName("e").length!==0){a.lastChild.className="e";if(a.getElementsByClassName("e").length===1)return;l.order.splice(1,0,"CLASS"),l.find.CLASS=function(a,b,c){if(typeof b.getElementsByClassName!=="undefined"&&!c)return b.getElementsByClassName(a[1])},a=null}}(),c.documentElement.contains?k.contains=function(a,b){return a!==b&&(a.contains?a.contains(b):!0)}:c.documentElement.compareDocumentPosition?k.contains=function(a,b){return!!(a.compareDocumentPosition(b)&16)}:k.contains=function(){return!1},k.isXML=function(a){var b=(a?a.ownerDocument||a:0).documentElement;return b?b.nodeName!=="HTML":!1};var v=function(a,b){var c,d=[],e="",f=b.nodeType?[b]:b;while(c=l.match.PSEUDO.exec(a))e+=c[0],a=a.replace(l.match.PSEUDO,"");a=l.relative[a]?a+"*":a;for(var g=0,h=f.length;g0)for(var g=c;g0},closest:function(a,b){var c=[],e,f,g=this[0];if(d.isArray(a)){var h,i,j={},k=1;if(g&&a.length){for(e=0,f=a.length;e-1:d(g).is(h))&&c.push({selector:i,elem:g,level:k});g=g.parentNode,k++}}return c}var l=N.test(a)?d(a,b||this.context):null;for(e=0,f=this.length;e-1:d.find.matchesSelector(g,a)){c.push(g);break}g=g.parentNode;if(!g||!g.ownerDocument||g===b)break}}c=c.length>1?d.unique(c):c;return this.pushStack(c,"closest",a)},index:function(a){if(!a||typeof a==="string")return d.inArray(this[0],a?d(a):this.parent().children());return d.inArray(a.jquery?a[0]:a,this)},add:function(a,b){var c=typeof a==="string"?d(a,b):d.makeArray(a),e=d.merge(this.get(),c);return this.pushStack(P(c[0])||P(e[0])?e:d.unique(e))},andSelf:function(){return this.add(this.prevObject)}}),d.each({parent:function(a){var b=a.parentNode;return b&&b.nodeType!==11?b:null},parents:function(a){return d.dir(a,"parentNode")},parentsUntil:function(a,b,c){return d.dir(a,"parentNode",c)},next:function(a){return d.nth(a,2,"nextSibling")},prev:function(a){return d.nth(a,2,"previousSibling")},nextAll:function(a){return d.dir(a,"nextSibling")},prevAll:function(a){return d.dir(a,"previousSibling")},nextUntil:function(a,b,c){return d.dir(a,"nextSibling",c)},prevUntil:function(a,b,c){return d.dir(a,"previousSibling",c)},siblings:function(a){return d.sibling(a.parentNode.firstChild,a)},children:function(a){return d.sibling(a.firstChild)},contents:function(a){return d.nodeName(a,"iframe")?a.contentDocument||a.contentWindow.document:d.makeArray(a.childNodes)}},function(a,b){d.fn[a]=function(c,e){var f=d.map(this,b,c),g=M.call(arguments);I.test(a)||(e=c),e&&typeof e==="string"&&(f=d.filter(e,f)),f=this.length>1&&!O[a]?d.unique(f):f,(this.length>1||K.test(e))&&J.test(a)&&(f=f.reverse());return this.pushStack(f,a,g.join(","))}}),d.extend({filter:function(a,b,c){c&&(a=":not("+a+")");return b.length===1?d.find.matchesSelector(b[0],a)?[b[0]]:[]:d.find.matches(a,b)},dir:function(a,c,e){var f=[],g=a[c];while(g&&g.nodeType!==9&&(e===b||g.nodeType!==1||!d(g).is(e)))g.nodeType===1&&f.push(g),g=g[c];return f},nth:function(a,b,c,d){b=b||1;var e=0;for(;a;a=a[c])if(a.nodeType===1&&++e===b)break;return a},sibling:function(a,b){var c=[];for(;a;a=a.nextSibling)a.nodeType===1&&a!==b&&c.push(a);return c}});var R=/ jQuery\d+="(?:\d+|null)"/g,S=/^\s+/,T=/<(?!area|br|col|embed|hr|img|input|link|meta|param)(([\w:]+)[^>]*)\/>/ig,U=/<([\w:]+)/,V=/",""],legend:[1,""],thead:[1,""],tr:[2,""],td:[3,""],col:[2,""],area:[1,""],_default:[0,"",""]};Z.optgroup=Z.option,Z.tbody=Z.tfoot=Z.colgroup=Z.caption=Z.thead,Z.th=Z.td,d.support.htmlSerialize||(Z._default=[1,"div","
"]),d.fn.extend({text:function(a){if(d.isFunction(a))return this.each(function(b){var c=d(this);c.text(a.call(this,b,c.text()))});if(typeof a!=="object"&&a!==b)return this.empty().append((this[0]&&this[0].ownerDocument||c).createTextNode(a));return d.text(this)},wrapAll:function(a){if(d.isFunction(a))return this.each(function(b){d(this).wrapAll(a.call(this,b))});if(this[0]){var b=d(a,this[0].ownerDocument).eq(0).clone(!0);this[0].parentNode&&b.insertBefore(this[0]),b.map(function(){var a=this;while(a.firstChild&&a.firstChild.nodeType===1)a=a.firstChild;return a}).append(this)}return this},wrapInner:function(a){if(d.isFunction(a))return this.each(function(b){d(this).wrapInner(a.call(this,b))});return this.each(function(){var b=d(this),c=b.contents();c.length?c.wrapAll(a):b.append(a)})},wrap:function(a){return this.each(function(){d(this).wrapAll(a)})},unwrap:function(){return this.parent().each(function(){d.nodeName(this,"body")||d(this).replaceWith(this.childNodes)}).end()},append:function(){return this.domManip(arguments,!0,function(a){this.nodeType===1&&this.appendChild(a)})},prepend:function(){return this.domManip(arguments,!0,function(a){this.nodeType===1&&this.insertBefore(a,this.firstChild)})},before:function(){if(this[0]&&this[0].parentNode)return this.domManip(arguments,!1,function(a){this.parentNode.insertBefore(a,this)});if(arguments.length){var a=d(arguments[0]);a.push.apply(a,this.toArray());return this.pushStack(a,"before",arguments)}},after:function(){if(this[0]&&this[0].parentNode)return this.domManip(arguments,!1,function(a){this.parentNode.insertBefore(a,this.nextSibling)});if(arguments.length){var a=this.pushStack(this,"after",arguments);a.push.apply(a,d(arguments[0]).toArray());return a}},remove:function(a,b){for(var c=0,e;(e=this[c])!=null;c++)if(!a||d.filter(a,[e]).length)!b&&e.nodeType===1&&(d.cleanData(e.getElementsByTagName("*")),d.cleanData([e])),e.parentNode&&e.parentNode.removeChild(e);return this},empty:function(){for(var a=0,b;(b=this[a])!=null;a++){b.nodeType===1&&d.cleanData(b.getElementsByTagName("*"));while(b.firstChild)b.removeChild(b.firstChild)}return this},clone:function(a,b){a=a==null?!1:a,b=b==null?a:b;return this.map(function(){return d.clone(this,a,b)})},html:function(a){if(a===b)return this[0]&&this[0].nodeType===1?this[0].innerHTML.replace(R,""):null;if(typeof a!=="string"||X.test(a)||!d.support.leadingWhitespace&&S.test(a)||Z[(U.exec(a)||["",""])[1].toLowerCase()])d.isFunction(a)?this.each(function(b){var c=d(this);c.html(a.call(this,b,c.html()))}):this.empty().append(a);else{a=a.replace(T,"<$1>$2>");try{for(var c=0,e=this.length;c1&&l0?this.clone(!0):this).get();d(f[h])[b](j),e=e.concat(j)}return this.pushStack(e,a,f.selector)}}),d.extend({clone:function(a,b,c){var e=a.cloneNode(!0),f,g,h;if((!d.support.noCloneEvent||!d.support.noCloneChecked)&&(a.nodeType===1||a.nodeType===11)&&!d.isXMLDoc(a)){ba(a,e),f=bb(a),g=bb(e);for(h=0;f[h];++h)ba(f[h],g[h])}if(b){_(a,e);if(c){f=bb(a),g=bb(e);for(h=0;f[h];++h)_(f[h],g[h])}}return e},clean:function(a,b,e,f){b=b||c,typeof b.createElement==="undefined"&&(b=b.ownerDocument||b[0]&&b[0].ownerDocument||c);var g=[];for(var h=0,i;(i=a[h])!=null;h++){typeof i==="number"&&(i+="");if(!i)continue;if(typeof i!=="string"||W.test(i)){if(typeof i==="string"){i=i.replace(T,"<$1>$2>");var j=(U.exec(i)||["",""])[1].toLowerCase(),k=Z[j]||Z._default,l=k[0],m=b.createElement("div");m.innerHTML=k[1]+i+k[2];while(l--)m=m.lastChild;if(!d.support.tbody){var n=V.test(i),o=j==="table"&&!n?m.firstChild&&m.firstChild.childNodes:k[1]===""&&!n?m.childNodes:[];for(var p=o.length-1;p>=0;--p)d.nodeName(o[p],"tbody")&&!o[p].childNodes.length&&o[p].parentNode.removeChild(o[p])}!d.support.leadingWhitespace&&S.test(i)&&m.insertBefore(b.createTextNode(S.exec(i)[0]),m.firstChild),i=m.childNodes}}else i=b.createTextNode(i);i.nodeType?g.push(i):g=d.merge(g,i)}if(e)for(h=0;g[h];h++)!f||!d.nodeName(g[h],"script")||g[h].type&&g[h].type.toLowerCase()!=="text/javascript"?(g[h].nodeType===1&&g.splice.apply(g,[h+1,0].concat(d.makeArray(g[h].getElementsByTagName("script")))),e.appendChild(g[h])):f.push(g[h].parentNode?g[h].parentNode.removeChild(g[h]):g[h]);return g},cleanData:function(a){var b,c,e=d.cache,f=d.expando,g=d.event.special,h=d.support.deleteExpando;for(var i=0,j;(j=a[i])!=null;i++){if(j.nodeName&&d.noData[j.nodeName.toLowerCase()])continue;c=j[d.expando];if(c){b=e[c]&&e[c][f];if(b&&b.events){for(var k in b.events)g[k]?d.event.remove(j,k):d.removeEvent(j,k,b.handle);b.handle&&(b.handle.elem=null)}h?delete j[d.expando]:j.removeAttribute&&j.removeAttribute(d.expando),delete e[c]}}}});var bd=/alpha\([^)]*\)/i,be=/opacity=([^)]*)/,bf=/-([a-z])/ig,bg=/([A-Z]|^ms)/g,bh=/^-?\d+(?:px)?$/i,bi=/^-?\d/,bj={position:"absolute",visibility:"hidden",display:"block"},bk=["Left","Right"],bl=["Top","Bottom"],bm,bn,bo,bp=function(a,b){return b.toUpperCase()};d.fn.css=function(a,c){if(arguments.length===2&&c===b)return this;return d.access(this,a,c,!0,function(a,c,e){return e!==b?d.style(a,c,e):d.css(a,c)})},d.extend({cssHooks:{opacity:{get:function(a,b){if(b){var c=bm(a,"opacity","opacity");return c===""?"1":c}return a.style.opacity}}},cssNumber:{zIndex:!0,fontWeight:!0,opacity:!0,zoom:!0,lineHeight:!0},cssProps:{"float":d.support.cssFloat?"cssFloat":"styleFloat"},style:function(a,c,e,f){if(a&&a.nodeType!==3&&a.nodeType!==8&&a.style){var g,h=d.camelCase(c),i=a.style,j=d.cssHooks[h];c=d.cssProps[h]||h;if(e===b){if(j&&"get"in j&&(g=j.get(a,!1,f))!==b)return g;return i[c]}if(typeof e==="number"&&isNaN(e)||e==null)return;typeof e==="number"&&!d.cssNumber[h]&&(e+="px");if(!j||!("set"in j)||(e=j.set(a,e))!==b)try{i[c]=e}catch(k){}}},css:function(a,c,e){var f,g=d.camelCase(c),h=d.cssHooks[g];c=d.cssProps[g]||g;if(h&&"get"in h&&(f=h.get(a,!0,e))!==b)return f;if(bm)return bm(a,c,g)},swap:function(a,b,c){var d={};for(var e in b)d[e]=a.style[e],a.style[e]=b[e];c.call(a);for(e in b)a.style[e]=d[e]},camelCase:function(a){return a.replace(bf,bp)}}),d.curCSS=d.css,d.each(["height","width"],function(a,b){d.cssHooks[b]={get:function(a,c,e){var f;if(c){a.offsetWidth!==0?f=bq(a,b,e):d.swap(a,bj,function(){f=bq(a,b,e)});if(f<=0){f=bm(a,b,b),f==="0px"&&bo&&(f=bo(a,b,b));if(f!=null)return f===""||f==="auto"?"0px":f}if(f<0||f==null){f=a.style[b];return f===""||f==="auto"?"0px":f}return typeof f==="string"?f:f+"px"}},set:function(a,b){if(!bh.test(b))return b;b=parseFloat(b);if(b>=0)return b+"px"}}}),d.support.opacity||(d.cssHooks.opacity={get:function(a,b){return be.test((b&&a.currentStyle?a.currentStyle.filter:a.style.filter)||"")?parseFloat(RegExp.$1)/100+"":b?"1":""},set:function(a,b){var c=a.style;c.zoom=1;var e=d.isNaN(b)?"":"alpha(opacity="+b*100+")",f=c.filter||"";c.filter=bd.test(f)?f.replace(bd,e):c.filter+" "+e}}),d(function(){d.support.reliableMarginRight||(d.cssHooks.marginRight={get:function(a,b){var c;d.swap(a,{display:"inline-block"},function(){b?c=bm(a,"margin-right","marginRight"):c=a.style.marginRight});return c}})}),c.defaultView&&c.defaultView.getComputedStyle&&(bn=function(a,c,e){var f,g,h;e=e.replace(bg,"-$1").toLowerCase();if(!(g=a.ownerDocument.defaultView))return b;if(h=g.getComputedStyle(a,null))f=h.getPropertyValue(e),f===""&&!d.contains(a.ownerDocument.documentElement,a)&&(f=d.style(a,e));return f}),c.documentElement.currentStyle&&(bo=function(a,b){var c,d=a.currentStyle&&a.currentStyle[b],e=a.runtimeStyle&&a.runtimeStyle[b],f=a.style;!bh.test(d)&&bi.test(d)&&(c=f.left,e&&(a.runtimeStyle.left=a.currentStyle.left),f.left=b==="fontSize"?"1em":d||0,d=f.pixelLeft+"px",f.left=c,e&&(a.runtimeStyle.left=e));return d===""?"auto":d}),bm=bn||bo,d.expr&&d.expr.filters&&(d.expr.filters.hidden=function(a){var b=a.offsetWidth,c=a.offsetHeight;return b===0&&c===0||!d.support.reliableHiddenOffsets&&(a.style.display||d.css(a,"display"))==="none"},d.expr.filters.visible=function(a){return!d.expr.filters.hidden(a)});var br=/%20/g,bs=/\[\]$/,bt=/\r?\n/g,bu=/#.*$/,bv=/^(.*?):[ \t]*([^\r\n]*)\r?$/mg,bw=/^(?:color|date|datetime|email|hidden|month|number|password|range|search|tel|text|time|url|week)$/i,bx=/^(?:about|app|app\-storage|.+\-extension|file|widget):$/,by=/^(?:GET|HEAD)$/,bz=/^\/\//,bA=/\?/,bB=/