#1 JavaScript::Eval (size: 233964, repeated: 2) (function() {
try {
var appNamespace = "$ice";
if (window[appNamespace]) {
if (window[appNamespace].logger && window[appNamespace].logger.error) {
window[appNamespace].logger.error("Global namespace already defined. Aborting.", this)
}
return
}
var what = function(obj) {
return typeof obj == "undefined" || obj === null ? "undefined" : ({}).toString.call(obj).match(/\s([a-z|A-Z]+)/)[1].toLowerCase()
};
var $extend = function(source) {
if (this.$root.what(source) != "object") {
this.$root.logger.warn("source is not an object", this);
return
}
var key;
for (key in source) {
this[key] = source[key]
}
return this
};
var $fn = function(key, fn) {
if (!this || this == window) {
return
}
if (this.$root.what(fn) != "function") {
this.$root.logger.warn(key + " is not a function", this);
return
}
this[key] = fn;
fn.$id = key;
fn.$parent = this;
fn.$root = this.$root
};
var $create = function(id, source, extension, bindable) {
var wsource = what(source),
parent = this || window,
node, key;
if (!/object|function/.test(wsource)) {
return null
}
if (parent[id]) {
node = parent[id]
} else {
var maker = function() {
var node = function() {};
node.prototype.$id = id;
node.prototype.$parent = parent;
node.prototype.$root = parent == window ? null : parent.$root;
node.prototype.$create = $create;
node.prototype.$extend = $extend;
node.prototype.$fn = $fn;
if (bindable && parent != window && parent.$root.event) {
node.prototype.bind = parent.$root.event.bind;
node.prototype.unbind = parent.$root.event.unbind;
node.prototype.fire = parent.$root.event.fire
}
return node
};
node = parent[id] = new(new maker())
}
if (what(extension) == "object") {
node.$extend(extension)
}
for (key in source) {
switch (what(source[key])) {
case "function":
node.$fn(key, source[key]);
break;
case "object":
node.$create(key, source[key]);
break;
default:
node[key] = source[key]
}
}
return node
};
var NodesArray = function() {
this.nodes = []
};
NodesArray.prototype = {
toString: function(separator) {
var result = [],
i, len;
for (i = 0, len = this.nodes.length; i < len; i++) {
result.unshift(this.nodes[i].$id)
}
return result.join(separator || ".")
}
};
var $root = $create(appNamespace, {}, null, false);
$root.what = what;
$root.$root = $root;
$root.$extend({
NodesArray: NodesArray,
$fn: $fn
});
$root.$create("plugins", {}, {}, true);
var versionFile = "ice";
var event = $root.$create("event", {
bind: function(o) {
var rt = this.$root,
ev = rt.event,
ls, key, clone, prop, err = null;
if (!o.event) {
err = ev.msgs.me
} else {
if (!o.listener) {
err = ev.msgs.ml
}
}
if (err) {
rt.logger.error(err, this);
return false
}
o.$root = rt;
if (!ev._listeners[o.event]) {
ev._listeners[o.event] = []
}
ls = ev._listeners[o.event];
var listenerType = rt.what(o.listener);
if (listenerType == "function") {
ls[ls.length] = o
} else {
if (listenerType == "object") {
for (key in o.listener) {
if (this != ev) {
this.$fn(key, o.listener[key])
}
clone = {};
for (prop in o) {
clone[prop] = o[prop]
}
clone.listener = o.listener[key];
ls[ls.length] = clone
}
}
}
return true
},
unbind: function(event, listener) {
var rt = this.$root,
ev = rt.event,
i, len, ls = ev._listeners[event];
if (rt.what(ls) != "array") {
return false
}
if (!listener) {
delete ev._listeners[event]
} else {
for (i = 0, len = ls.length; i < len; i++) {
if (ls[i].listener === listener) {
ls.splice(i--, 1)
}
}
}
return true
},
fire: function(event, data, delay) {
var rt = this.$root,
ls = rt.event._listeners[event],
func, context, o, hasData = rt.what(data) != "undefined",
time, msg;
if (!event || rt.event.disabled || (ls && ls.disabled) || rt.what(ls) != "array") {
return false
}
for (var i = 0, len = ls.length; i < len; i++) {
o = ls[i];
if (hasData) {
o.data = data
}
func = o.listener;
context = func.$parent || window;
if (context == window) {
rt.logger.error("Probable Error: Context is window object. event: " + event, this.fire)
}
if (rt.event.log) {
msg = ['Fire "', func.$id || "Anonymous", '" on "', event, '".', data && data.hookId ? " hookId:" + data.hookId : ""].join("")
}
time = delay && rt.what(delay) == "number" ? delay : o.delay;
if (time) {
return setTimeout((function() {
var clone = rt.utils.object.clone(o);
return function() {
if (msg) {
rt.logger.log(msg, func)
}
func.call(context, clone)
}
}()), time)
} else {
if (msg) {
rt.logger.log(msg, func)
}
func.call(context, o)
}
}
},
repeat: function(event, interval, data, delay) {
var rt = this.$root,
ls = rt.event._listeners[event],
func, context, o, hasData = rt.what(data) != "undefined",
msg, wrapper;
if (!event || rt.event.disabled || (ls && ls.disabled) || rt.what(ls) != "array" || !interval || rt.what(interval) != "number") {
return false
}
if (!delay || rt.what(delay) != "number") {
delay = null
}
for (var i = 0, len = ls.length; i < len; i++) {
o = ls[i];
if (o.repeat || o.delay) {
return
}
if (hasData) {
o.data = data
}
func = o.listener;
context = func.$parent || window;
if (rt.event.log) {
msg = ['Repeat "', func.$id || "Anonymous", '" on "', event, '".'].join("")
}
o.interval = interval;
o.counter = 0;
wrapper = function() {
if (msg && !o.counter) {
rt.logger.log(msg, func)
}
o.counter++;
func.call(context, o)
};
if (delay) {
o.delay = setTimeout(function() {
o.repeat = setInterval(wrapper, interval)
}, delay)
} else {
o.repeat = setInterval(wrapper, interval)
}
}
},
stop: function(event) {
var rt = this.$root,
ls = rt.event._listeners[event],
func, o;
if (!event || !ls) {
return false
}
for (var i = 0, len = ls.length; i < len; i++) {
o = ls[i];
clearInterval(o.repeat);
clearTimeout(o.delay);
delete o.repeat;
delete o.delay;
func = o.listener;
if (rt.event.log) {
rt.logger.log(['Stop "', func.$id || "Anonymous", '" on "', event, '" after ', o.counter, " repetitions."].join(""), func)
}
o.counter = 0
}
},
disable: function(event) {
this.$root.event.able(event, true)
},
enable: function(event) {
this.$root.event.able(event, false)
},
able: function(event, disabled) {
var rt = this.$root,
i;
if (event) {
if (rt.what(event) == "string") {
event = [event]
}
for (i = 0; i < event.length; i++) {
rt.event._listeners[event].disabled = disabled
}
} else {
rt.event.disabled = disabled
}
}
}, {
_listeners: {},
log: true,
msgs: {
me: "Error: Missing event.",
ml: "Error: Misssing listener."
}
}, false);
event.$create("dom", {
bind: function(element, o) {
var rt = this.$root,
nt = rt.settings.nodeTypes,
key, clone, prop, err = null,
func;
function isAChildOf(parent, child) {
if (parent === child) {
return false
}
while (child && child !== parent) {
child = child.parentNode
}
return child === parent
}
if (!element || !(element.nodeType == nt.ELEMENT || element.nodeType == nt.DOCUMENT || element == window)) {
err = this.msgs.mbe
} else {
if (!o.event) {
err = this.$parent.msgs.me
} else {
if (!o.listener) {
err = this.$parent.msgs.ml
}
}
}
if (err) {
rt.logger.error(err, this);
return false
}
if (!element.$iceId) {
element.$iceId = ++this.elementBinder
}
o.element = element;
o.$root = rt;
if (rt.what(o.listener) == "function") {
o.listener = {
a: o.listener
}
} else {
if (rt.what(o.listener) != "object") {
return
}
}
for (key in o.listener) {
clone = {};
for (prop in o) {
clone[prop] = o[prop]
}
clone.listener = o.listener[key];
if (element.addEventListener) {
if (/mouseenter|mouseleave/.test(clone.event)) {
clone.simEvent = clone.event;
clone.event = clone.event.replace(/enter/, "over").replace(/leave/, "out")
}
}
func = (function() {
var reclone = rt.utils.object.clone(clone);
return function(domEvt) {
if (!domEvt) {
domEvt = window.event
}
if (/mouseenter|mouseleave/.test(reclone.simEvent) && domEvt.relatedTarget && this == domEvt.relatedTarget || (isAChildOf(this, domEvt.relatedTarget))) {
return
}
reclone.domEvent = domEvt;
rt.event.dom.fire(reclone)
}
})();
if (element.addEventListener) {
element.addEventListener(clone.event, func, false)
} else {
if (element.attachEvent) {
element.attachEvent("on" + clone.event, func)
}
}
var eID = element.$iceId;
var eL = this._listeners;
if (!eL[eID]) {
eL[eID] = {}
}
if (!eL[eID][clone.event]) {
eL[eID][clone.event] = []
}
rt.utils.array.push(eL[eID][clone.event], {
listener: func,
original: clone.listener
})
}
return true
},
unbind: function(element, event, listener) {
var rt = this.$root,
nt = rt.settings.nodeTypes,
i;
if (!element || !element.$iceId || !(element.nodeType == nt.ELEMENT || element.nodeType == nt.DOCUMENT || element == window)) {
rt.logger.error(this.msgs.mbe, this);
return
}
var eID = element.$iceId;
var ls = rt.event.dom._listeners[eID];
if (!ls || !ls[event]) {
return
}
for (i = 0; i < ls[event].length; i++) {
if (ls[event][i].original == listener) {
if (element.removeEventListener) {
element.removeEventListener(event, ls[event][i].listener, false)
} else {
if (element.detachEvent) {
element.detachEvent("on" + event, ls[event][i].listener)
}
}
ls[event].splice(--i, 1)
}
}
if (ls[event].length == 0) {
delete ls[event]
}
return true
},
fire: function(o) {
var rt = this.$root,
func = o.listener,
context = func.$parent || window,
msg;
if (rt.event.log) {
msg = ['Fire "', func.$id || "Anonymous", '" on "', o.event, '".', o.data && o.data.hookId ? " hookId:" + o.data.hookId : ""].join("")
}
if (o.delay && rt.what(o.delay) == "number") {
setTimeout(function() {
if (msg) {
rt.logger.log(msg, func)
}
func.call(context, o)
}, o.delay)
} else {
if (msg) {
rt.logger.log(msg, func)
}
func.call(context, o)
}
}
}, {
_listeners: {},
elementBinder: 0,
msgs: {
mbe: "Error: Missing or bad element."
}
}, false);
$root.$create("logger", {
log: function(message, context, type) {
if (!type) {
type = "log"
}
this.history[this.history.length] = {
message: message,
type: type,
time: (new Date()).getTime(),
context: context
};
if (this.output == "console" && this.$root.what(window.console) != "undefined") {
console[type](message, this.descent(context))
}
},
info: function(message, context) {
this.log(message, context, "info")
},
warn: function(message, context) {
this.log(message, context, "warn")
},
error: function(message, context, kill) {
this.log(message, context, "error");
if (kill) {
this.$root.event.disable()
}
if (this.errorReporting >= Math.ceil(Math.random() * 100)) {
this.$root.event.fire("sendErrorReport", {
msg: message
})
}
},
descent: function(context) {
var result = new this.$root.NodesArray;
while (context && context.$root && context != window) {
result.nodes[result.nodes.length] = context;
context = context.$parent
}
return result
}
}, {
history: [],
output: "none",
errorReporting: -1
});
$root.$create("browser", new function() {
var ua = this.ua = navigator.userAgent;
var uac = function(str) {
return ua.indexOf(str) != -1
};
var _found = false;
var ver = function(browser) {
if (_found) {
return false
}
var match = ua.match(new RegExp(browser + ".?([0-9][0-9\\.]+)"));
if (match != null) {
_found = true;
return match[1]
}
return false
};
this.IE = ver("MSIE");
if (this.IE == "7.0" && $root.what(Array.isArray) == "function") {
this.IE = "9.0"
}
this.Firefox = ver("Firefox");
this.Chrome = ver("Chrome");
this.Safari = this.Chrome ? false : uac("Safari") && ver("Version");
this.MobileSafari = this.Safari && uac("Mobile") ? this.Safari : false;
this.Opera = uac("Opera") && uac("Presto") ? ver("Version") || ver("Opera") : false;
this.OperaMini = this.Opera && uac("Opera Mini");
this.ucweb = ver("UCWEB") || (uac("UCWEB") ? ver("Browser") : false);
_found = false;
this.AppleWebKit = ver("AppleWebKit");
this.Gecko = ver("Gecko");
this.Mozilla = !this.Gecko && !this.AppleWebKit && uac("Mozilla/");
_found = false;
this.WindowsMobile = uac("Windows Phone OS");
this.Windows = uac("Windows ");
this.Linux = !this.Windows && (uac("Linux ") || uac("Linux;"));
this.Mac = !this.Windows && !this.Linux && uac("Mac ");
this.iPhone = !this.Windows && !this.Linux && uac("iPhone");
this.iPad = !this.Windows && !this.Linux && uac("iPad");
this.Android = (!this.Windows && uac("Android")) ? ver("Android") : false;
this.Nokia = uac("Nokia");
this.getOS = function() {
var os = ["WindowsMobile", "Windows", "iPhone", "Mac", "iPad", "Android", "Nokia", "Linux"],
i, leni = os.length;
for (i = 0; i < leni; i++) {
if (this[os[i]]) {
return os[i]
}
}
return "unknown"
};
this.isMobile = function() {
return !!(this.iPhone || this.iPad || this.Android || this.WindowsMobile || this.OperaMini || this.ucweb)
};
this.getName = function() {
var names = ["IE", "Firefox", "Chrome", "MobileSafari", "Safari", "Opera", "ucweb", "Gecko", "AppleWebKit", "Mozilla"];
for (var i = 0, leni = names.length; i < leni; i++) {
if (this[names[i]]) {
return names[i]
}
}
return "unknown"
};
this.getVersion = function(asFloat) {
var ver = this.IE || this.Firefox || this.Chrome || this.MobileSafari || this.Safari || this.Opera || this.AppleWebKit || this.ucweb || "unknown";
return asFloat ? parseFloat(ver) || -1 : ver
};
this.toString = this.getValue = function() {
return [this.getName(), this.getVersion(), this.getOS()].join(" ")
}
});
var utils = $root.$create("utils", {
VeST: function(template, data, name) {
var fn, v = this.VeST,
c;
if (!(c = v.cache)) {
c = v.cache = {};
v.encQ = function(m) {
return m.split("'").join("\t")
};
v.decQ = function(m) {
return m.split("\t").join("'")
}
}
if (name && c[name]) {
fn = c[name]
} else {
template = template.replace(/<%\-\-[\s\S]*?\-\-%>/g, "");
var tjs = template.replace(/[\r\t\n]/g, " ").replace(/<%.*?%>/g, v.encQ).replace(/'/g, "\\'").replace(/<%.*?%>/g, v.decQ).replace(/<%=(.*?)%>/g, "',$1,'").split("<%").join("');").split("%>").join("p.push('");
tjs = ["var p=[];with(obj||{}){p.push('", tjs, "');}return p.join('');"].join("");
fn = new Function("obj", tjs);
if (name) {
c[name] = fn
}
}
return fn(data)
},
doRectsOverlap: function(r1, r2) {
var temp;
if (r2[0] < r1[0]) {
temp = r1;
r1 = r2;
r2 = temp
}
if (r1[2] < r2[0] || r1[0] > r2[2]) {
return false
}
if (r2[1] < r1[1]) {
temp = r1;
r1 = r2;
r2 = temp
}
if (r1[3] < r2[1] || r1[1] > r2[3]) {
return false
}
return true
}
});
utils.$create("number", {
get: function(counter) {
return this.counters[counter]
},
next: function(counter, start) {
if (this.$root.what(this.counters[counter]) == "undefined") {
this.counters[counter] = this.$root.what(start) == "number" ? start : 0
} else {
this.counters[counter]++
}
return this.counters[counter]
}
}, {
counters: {}
});
utils.$create("string", {
capitalize: function(str) {
var arr = str.split(/\s+/);
if (arr.length > 2) {
arr[0] = arr[0].charAt(0).toUpperCase() + arr[0].slice(1)
} else {
for (var i = 0, len = arr.length; i < len; ++i) {
arr[i] = arr[i].charAt(0).toUpperCase() + arr[i].slice(1)
}
}
return arr.join(" ")
},
qw: function(str) {
return this.trim(str).split(/\s+/)
},
toObject: function(str, key, decode) {
if (str.indexOf("=") == -1) {
return null
}
if (str.indexOf("?") == 0) {
str = str.substring(1)
}
var obj = {},
pairs = str.split("&"),
kv;
for (var i = 0, leni = pairs.length; i < leni; i++) {
kv = pairs[i].split("=");
if (kv.length != 2) {
continue
}
if (decode) {
kv[0] = decodeURIComponent(kv[0]);
kv[1] = decodeURIComponent(kv[1])
}
obj[kv[0]] = kv[1]
}
return this.$root.what(key) != "undefined" ? obj[key] : obj
},
trim: function(str) {
return str.replace(/^\s+|\s+$/g, "")
},
truncate: function(str, len, suffix) {
return str.length <= len ? str : str.substring(0, len) + (suffix || "")
},
truncateToChar: function(str, len, sep, suffix) {
var str2 = str.length <= len ? str : str.substring(0, len);
if (str2.length < str.length) {
str2 = str2.substr(0, str2.lastIndexOf(sep)) + (suffix || "")
}
return str2
}
});
utils.$create("array", {
clone: function(origin, deep) {
var clone = [],
i, leni, rt = this.$root;
for (i = 0, leni = origin.length; i < leni; i++) {
if (deep && /object|array/.test(rt.what(origin[i])) && (!this.cloneDepth || this.cloneDepth < 10)) {
if (!this.cloneDepth) {
this.cloneDepth = 0
}
this.cloneDepth++;
clone[i] = rt.what(origin[i]) == "object" ? this.$parent.object.clone(origin[i], deep) : this.clone(origin[i], deep)
} else {
clone[i] = origin[i]
}
}
delete this.cloneDepth;
return clone
},
concat: function() {
var arr = [];
for (var i = 0, leni = arguments.length; i < leni; i++) {
for (var j = 0, lenj = arguments[i].length; j < lenj; j++) {
arr[arr.length] = arguments[i][j]
}
}
return arr
},
discard: function(arr, item) {
for (var i = arr.length - 1; i >= 0; i--) {
if (arr[i] == item) {
arr.splice(i, 1)
}
}
return arr
},
find: function(arr, finder) {
for (var i = 0, leni = arr.length; i < leni; i++) {
if (finder(arr[i])) {
return arr[i]
}
}
return null
},
indexOf: function(arr, item) {
for (var i = 0, leni = arr.length; i < leni; i++) {
if (arr[i] == item) {
return i
}
}
return -1
},
insertionSort: function(arr, prop, asc) {
var i, j, value;
for (i = 1; i < arr.length; i++) {
value = arr[i];
j = i - 1;
while (j >= 0 && (asc ? arr[j][prop] > value[prop] : arr[j][prop] < value[prop])) {
arr[j + 1] = arr[j];
j--
}
arr[j + 1] = value
}
},
map: function(arr, mapper) {
for (var i = 0, leni = arr.length, res = []; i < leni; i++) {
res[i] = mapper(arr[i])
}
return res
},
push: function() {
if (arguments.length < 2) {
return
}
var arr = arguments[0];
for (var i = 1; i < arguments.length; i++) {
arr[arr.length] = arguments[i]
}
},
range: function(start, end) {
var arr = [],
i, what = this.$root.what;
if (what(start) == "number" && what(end) == "number" && start <= end) {
for (i = start; i <= end; i++) {
arr[arr.length] = i
}
}
return arr
},
sum: function(arr) {
var sum = 0,
i, len, what = this.$root.what;
for (i = 0, len = arr.length; i < len; i++) {
if (what(arr[i]) == "number") {
sum += arr[i]
}
}
return sum
},
times: function(str, x) {
var arr = this.range(1, x),
i;
for (i = 0; i < x; i++) {
arr[i] = str
}
return arr
},
toObject: function(arr, object, value) {
if (!arr) {
return object
}
var what = this.$root.what;
if (what(arr) != "array") {
arr = [arr]
}
if (!object) {
object = {}
}
var item, key, val;
for (var i = 0, leni = arr.length; i < leni; i++) {
item = arr[i];
key = what(item) == "string" ? item : item != null && what(item.toString) == "function" ? item.toString() : null;
if (key) {
val = (what(value) == "undefined") ? key : (what(value) == "function") ? value(key) : value;
object[key] = val
}
}
return object
},
uniq: function(arr) {
var i, j;
for (i = 0; i < arr.length - 1; i++) {
for (j = i + 1; j < arr.length; j++) {
if (arr[i] === arr[j]) {
arr.splice(j, 1);
j--
}
}
}
return arr
}
});
utils.$create("object", {
clean: function(obj) {
var res = {},
key, val, what = this.$root.what;
for (key in obj) {
val = obj[key];
if (what(val) == "undefined" || val === "" || val === null) {
continue
}
res[key] = obj[key]
}
return res
},
clone: function(origin, deep) {
var clone = {},
key, rt = this.$root;
for (key in origin) {
if (deep && /object|array/.test(rt.what(origin[key])) && (!this.cloneDepth || this.cloneDepth < 10)) {
if (!this.cloneDepth) {
this.cloneDepth = 0
}
this.cloneDepth++;
clone[key] = rt.what(origin[key]) == "object" ? this.clone(origin[key], deep) : this.$parent.array.clone(origin[key], deep)
} else {
clone[key] = origin[key]
}
}
delete this.cloneDepth;
return clone
},
extend: function() {
if (arguments.length < 2) {
return arguments.length ? arguments[0] : {}
}
var key, rt = this.$root,
i, leni, dest = arguments[0],
source;
if (rt.what(dest) != "object") {
return dest
}
for (i = 1, leni = arguments.length; i < leni; i++) {
source = arguments[i];
if (rt.what(source) == "object") {
for (key in source) {
dest[key] = source[key]
}
}
}
return dest
},
hasKey: function(obj, keys) {
if (!(keys instanceof Array)) {
keys = [keys]
}
for (var i = 0, leni = keys.length, what = this.$root.what; i < leni; i++) {
if (what(obj[keys[i]]) != "undefined") {
return true
}
}
return false
},
keys: function(obj) {
var arr = [];
for (var key in obj) {
arr[arr.length] = key
}
return arr
},
renamePorpery: function(o, oldName, newName) {
var rt = this.$root;
if (rt.what(o[oldName]) == "undefined") {
return
}
o[newName] = o[oldName];
delete o[oldName]
},
stringify: function(json, depth) {
var res, rt = this.$root,
type = rt.what(json),
push = rt.utils.array.push,
i, leni, key, sgf = this.stringify;
if (!depth) {
depth = 1
}
if (depth > 10) {
res = '"Exceeded max depth of 10 levels."'
} else {
if (type == "undefined") {
res = "undefined"
} else {
if (type == "number" || type == "boolean") {
res = json
} else {
if (type == "string") {
res = ['"', json.replace(/"/g, '\\"'), '"'].join("")
} else {
if (type == "function") {
res = '"[Function]"'
} else {
if (type == "array") {
res = ["["];
for (i = 0, leni = json.length; i < leni; i++) {
push(res, sgf.call(this, json[i], depth + 1), ",")
}
if (res.length > 1) {
res.pop()
}
push(res, "]");
res = res.join("")
} else {
if (json === null) {
res = "null"
} else {
if (type == "object") {
res = ["{"];
for (key in json) {
push(res, '"', key.replace(/"/g, '\\"'), '":', sgf.call(this, json[key], depth + 1), ",")
}
if (res.length > 1) {
res.pop()
}
push(res, "}");
res = res.join("")
}
}
}
}
}
}
}
}
return res
},
toQueryString: function(obj, useEncoding) {
var res = [],
key, value, push = this.$parent.array.push;
for (key in obj) {
if (useEncoding) {
key = encodeURIComponent(key);
value = encodeURIComponent(obj[key])
} else {
value = obj[key]
}
push(res, res.length ? "&" : "?", key, "=", value)
}
return res.join("")
},
values: function(obj) {
var arr = [];
for (var key in obj) {
arr[arr.length] = obj[key]
}
return arr
}
});
utils.$create("date", {
now: function() {
return new Date().getTime()
}
});
utils.$create("timer", {
start: function(id) {
var time = this.$root.utils.date.now();
this.times[id] = {
start: time
};
return time
},
stop: function(id) {
var rt = this.$root,
o = this.times[id];
if (!o || !o.start) {
rt.logger.warn(['Trying to stop timer "', id, '" which does not exist.'].join(""), this.stop);
return 0
}
o.stop = rt.utils.date.now();
o.delta = o.stop - o.start;
return o.delta
},
delta: function(id) {
var o = this.times[id];
return o && o.delta ? o.delta : 0
},
poll: function(id) {
var o = this.times[id];
if (!o || !o.start) {
return 0
}
return (o.stop || this.$root.utils.date.now()) - o.start
},
clear: function(id) {
delete this.times[id]
}
}, {
times: {}
});
utils.$create("cookie", {
set: function(name, value, expiration) {
expiration = expiration ? ("; expires=" + (this.$root.what(expiration) == "date" ? expiration.toUTCString() : new Date((new Date()).getTime() + expiration * 1000).toUTCString())) : "";
var parts = location.hostname.split(".");
var domain = "; domain=" + [parts[parts.length - 2], parts[parts.length - 1]].join(".");
document.cookie = [name, "=", encodeURIComponent(value), expiration, domain, "; path=/"].join("");
return true
},
has: function(name) {
return this.$parent.array.indexOf(this.$parent.array.map(document.cookie.split(/;\s*/), function(item) {
return item.split("=")[0]
}), name) > -1
},
remove: function(name) {
var parts = location.hostname.split(".");
var domain = "; domain=" + [parts[parts.length - 2], parts[parts.length - 1]].join(".");
document.cookie = [name, "=;expires=", new Date((new Date()).getTime() - 60000).toUTCString(), domain, "; path=/"].join("");
return true
},
get: function(name) {
var cookies = {};
this.$parent.array.map(document.cookie.split(/;\s*/), function(cookie) {
var p = cookie.split("=");
cookies[p[0]] = p[1];
return null
});
return decodeURIComponent(cookies[name]) || null
}
});
utils.$create("base64", {
init: function(str) {
if (!this.reverseBase64Chars) {
this.reverseBase64Chars = {};
for (var i = 0, leni = this.base64Chars.length; i < leni; i++) {
this.reverseBase64Chars[this.base64Chars[i]] = i
}
}
this.base64Str = str;
this.base64Count = 0
},
readBase64: function() {
if (!this.base64Str) {
return this.EOI
}
if (this.base64Count >= this.base64Str.length) {
return this.EOI
}
var c = this.base64Str.charCodeAt(this.base64Count) & 255;
this.base64Count++;
return c
},
encodeBase64: function(str) {
this.init(str);
var result = "";
var inBuffer = new Array(3);
var lineCount = 0;
var done = false;
while (!done && (inBuffer[0] = this.readBase64()) != this.EOI) {
inBuffer[1] = this.readBase64();
inBuffer[2] = this.readBase64();
result += (this.base64Chars[inBuffer[0] >> 2]);
if (inBuffer[1] != this.EOI) {
result += (this.base64Chars[((inBuffer[0] << 4) & 48) | (inBuffer[1] >> 4)]);
if (inBuffer[2] != this.EOI) {
result += (this.base64Chars[((inBuffer[1] << 2) & 60) | (inBuffer[2] >> 6)]);
result += (this.base64Chars[inBuffer[2] & 63])
} else {
result += (this.base64Chars[((inBuffer[1] << 2) & 60)]);
result += ("=");
done = true
}
} else {
result += (this.base64Chars[((inBuffer[0] << 4) & 48)]);
result += ("=");
result += ("=");
done = true
}
lineCount += 4;
if (lineCount >= 76) {
result += ("\n");
lineCount = 0
}
}
return result
},
readReverseBase64: function() {
if (!this.base64Str) {
return this.EOI
}
while (true) {
if (this.base64Count >= this.base64Str.length) {
return this.EOI
}
var nextCharacter = this.base64Str.charAt(this.base64Count);
this.base64Count++;
if (this.reverseBase64Chars[nextCharacter]) {
return this.reverseBase64Chars[nextCharacter]
}
if (nextCharacter == "A") {
return 0
}
}
},
ntos: function(n) {
n = n.toString(16);
if (n.length == 1) {
n = "0" + n
}
n = "%" + n;
return unescape(n)
},
decodeBase64: function(str) {
this.init(str);
var result = "";
var inBuffer = new Array(4);
var done = false;
while (!done && (inBuffer[0] = this.readReverseBase64()) != this.EOI && (inBuffer[1] = this.readReverseBase64()) != this.EOI) {
inBuffer[2] = this.readReverseBase64();
inBuffer[3] = this.readReverseBase64();
result += this.ntos((((inBuffer[0] << 2) & 255) | inBuffer[1] >> 4));
if (inBuffer[2] != this.EOI) {
result += this.ntos((((inBuffer[1] << 4) & 255) | inBuffer[2] >> 2));
if (inBuffer[3] != this.EOI) {
result += this.ntos((((inBuffer[2] << 6) & 255) | inBuffer[3]))
} else {
done = true
}
} else {
done = true
}
}
return result
}
}, {
EOI: -1,
base64Chars: "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_".split(""),
reverseBase64Chars: null,
base64Str: "",
base64Count: 0
});
utils.$create("dom", {
createDOMFragment: function(o) {
var el, rt = this.$root,
key, i, leni, child;
if (o.tag) {
var tag = o.tag.toLowerCase();
el = document.createElement(tag);
if (tag == "input") {
el.type = o.type || "text"
}
if (o.id) {
el.id = o.id
}
if (o.cls) {
el.className = o.cls
}
if (o.style) {
this.element.setStyle(el, o.style)
}
if (o.attributes) {
for (key in o.attributes) {
el.setAttribute(key, o.attributes[key])
}
}
if (rt.what(o.value) != "undefined") {
el.value = o.value
}
if (rt.what(o.innerHTML) != "undefined") {
el.innerHTML = o.innerHTML
}
if (o.events) {
for (key in o.events) {
rt.event.dom.bind(el, {
event: key,
listener: o.events[key]
})
}
}
} else {
if (o.isTextNode && rt.what(o.value) != "undefined") {
el = document.createTextNode(o.value)
} else {
return null
}
}
if (o.isChild) {
el = o.parent.appendChild(el)
}
if (o.tag && o.children) {
if (rt.what(o.children) != "array") {
o.children = [o.children]
}
for (i = 0, leni = o.children.length; i < leni; i++) {
child = o.children[i];
rt.utils.object.extend(child, {
isChild: true,
parent: el
});
this.createDOMFragment(child)
}
} else {
if (o.tag && o.childNodes) {
for (i = 0, leni = o.childNodes.length; i < leni; i++) {
el.appendChild(o.childNodes[i])
}
}
}
if (!o.isChild && o.parent) {
var parent = rt.what(o.parent) == "string" ? this.element.$(o.parent) : o.parent;
if (o.overwrite) {
parent.innerHTML = ""
}
o.before ? parent.insertBefore(el, o.before) : o.after ? this.element.insertAfter(el, o.after) : parent.appendChild(el)
}
return el
},
filterByClass: function(cls, tag, elm) {
if (!this._filterByClass) {
if (document.getElementsByClassName) {
this._filterByClass = function(cls, tag, elm) {
var elements = (elm ? (elm.getElementsByClassName ? elm : document) : document).getElementsByClassName(cls),
els = [];
tag = tag ? tag.toLowerCase() : null;
for (var i = 0, leni = elements.length; i < leni; i++) {
if (!tag || elements[i].tagName.toLowerCase() == tag) {
els[els.length] = elements[i]
}
}
return els
}
} else {
if (document.evaluate) {
this._filterByClass = function(cls, tag, elm) {
tag = tag || "*";
elm = elm || document;
var classes = cls.split(" "),
classesToCheck = "",
xhtmlNamespace = "http://www.w3.org/1999/xhtml",
namespaceResolver = (document.documentElement.namespaceURI === xhtmlNamespace) ? xhtmlNamespace : null,
els = [],
elements, node;
for (var j = 0, jl = classes.length; j < jl; j++) {
classesToCheck += "[contains(concat(' ', @class, ' '), ' " + classes[j] + " ')]"
}
try {
elements = document.evaluate(".//" + tag + classesToCheck, elm, namespaceResolver, 0, null)
} catch (e) {
elements = document.evaluate(".//" + tag + classesToCheck, elm, null, 0, null)
}
while ((node = elements.iterateNext())) {
els[els.length] = node
}
return els
}
} else {
this._filterByClass = function(cls, tag, elm) {
tag = tag || "*";
elm = elm || document;
var classes = cls.split(" "),
classesToCheck = [],
elements = (tag === "*" && elm.all) ? elm.all : elm.getElementsByTagName(tag),
current, els = [],
match;
for (var k = 0, kl = classes.length; k < kl; k++) {
classesToCheck[classesToCheck.length] = new RegExp("(^|\\s)" + classes[k] + "(\\s|$)")
}
for (var l = 0, ll = elements.length; l < ll; l++) {
current = elements[l];
match = false;
for (var m = 0, ml = classesToCheck.length; m < ml; m++) {
match = classesToCheck[m].test(current.className);
if (!match) {
break
}
}
if (match) {
els[els.length] = current
}
}
return els
}
}
}
}
return this._filterByClass(cls, tag, elm)
},
findWidestNode: function() {
var bd = document.body,
i, leni, rt = this.$root,
dm = rt.utils.dom,
dmel = dm.element,
node, widestNode, width, maxWidth = 0,
height, minHeight = 50,
widest = null;
for (i = 0, leni = bd.childNodes.length; i < leni; i++) {
node = bd.childNodes[i];
if (node.nodeType != rt.settings.nodeTypes.ELEMENT || !dmel.isVisible(node)) {
continue
}
width = dmel.getActualWidth(node);
height = dmel.getActualHeight(node);
if (width > maxWidth && height > minHeight) {
maxWidth = width;
widest = {
node: node,
width: width,
height: height
}
}
}
if (!widest) {
widestNode = bd;
widest = {
node: bd,
width: dm.document.getWidth(),
height: dm.document.getHeight()
}
}
return widest
}
});
utils.dom.$create("element", {
$: function(id) {
return document.getElementById(id)
},
getActualWidth: function(el) {
var cssWidth = this.getStyle(el, "width");
var width = parseInt(cssWidth, 10);
return !isNaN(width) && (width > 0) && (cssWidth.match(/px/)) ? width : el.clientWidth || el.offsetWidth
},
getActualHeight: function(el) {
var cssHeight = this.getStyle(el, "height");
var height = parseInt(cssHeight, 10);
return !isNaN(height) && (height > 0) && (cssHeight.match(/px/)) ? height : el.clientHeight || el.offsetHeight
},
getStyle: function(node, prop) {
var dfv = document.defaultView,
style = node.currentStyle || (dfv && dfv.getComputedStyle ? dfv.getComputedStyle(node, null) : null) || node.style;
return prop && style ? style[prop] : style
},
inHierarchy: function(low, high) {
do {
if (low == high) {
return true
}
low = low.parentNode
} while (low);
return false
},
insertAfter: function(newNode, refNode) {
var parent = refNode.parentNode;
return refNode.nextSibling ? parent.insertBefore(newNode, refNode.nextSibling) : parent.appendChild(newNode)
},
isOnViewport: function(node) {
if (!this.isVisible(node)) {
return false
}
return (this.offset(node).top < this.$parent.viewport.getHeight())
},
isVisible: function(node) {
if (!node) {
return false
}
while (node && node.tagName && node.tagName.toLowerCase() != "body") {
var cs = this.getStyle(node);
if (cs["display"] == "none" || cs["visibility"] == "hidden") {
return false
}
node = node.parentNode
}
return true
},
offset: function(node, ancestor) {
var x = 0,
y = 0,
rt = this.$root,
dm = rt.utils.dom,
dmel = dm.element,
b = rt.browser,
parent, body = document.body || document.documentElement;
var pos = "position",
abs = "absolute",
blw = "borderLeftWidth",
btw = "borderTopWidth";
if (!ancestor) {
ancestor = body
}
if (node == ancestor) {
return {
left: 0,
top: 0
}
}
if (node.getBoundingClientRect && !ancestor) {
var box = node.getBoundingClientRect();
var scrollTop = dm.document.getScrollTop();
var scrollLeft = dm.document.getScrollLeft();
return {
left: parseInt(box.left + scrollLeft, 10),
top: parseInt(box.top + scrollTop, 10)
}
}
var hasAbsolute = dmel.getStyle(node, pos) == abs;
parent = node;
while (parent && parent != ancestor) {
x += parent.offsetLeft;
y += parent.offsetTop;
if (!hasAbsolute && dmel.getStyle(parent, pos) == abs) {
hasAbsolute = true
}
if (b.Firefox) {
var bl = parseInt(dmel.getStyle(parent, blw), 10) || 0;
var bt = parseInt(dmel.getStyle(parent, btw), 10) || 0;
x += bl;
y += bt;
if (parent != node && dmel.getStyle(parent, "overflow") != "visible") {
x += bl;
y += bt
}
}
parent = parent.offsetParent
}
if (b.Safari && hasAbsolute) {
x -= body.offsetLeft;
y -= body.offsetTop
}
if (b.Firefox && !hasAbsolute) {
x += parseInt(dmel.getStyle(body, blw), 10) || 0;
y += parseInt(dmel.getStyle(body, btw), 10) || 0
}
parent = node.parentNode;
while (parent && parent != ancestor) {
if (!b.Opera || (parent.tagName.toLowerCase() != "tr" && dmel.getStyle(parent, "display") != "inline")) {
x -= parent.scrollLeft;
y -= parent.scrollTop
}
parent = parent.parentNode
}
var bs = dmel.getStyle(body);
if (ancestor == body && bs.position == abs && bs.left) {
x -= parseInt(bs.left, 10) || 0
}
return {
left: parseInt(x, 10),
top: parseInt(y, 10)
}
},
setStyle: function(node, styles) {
var b = this.$root.browser,
key;
if (!node) {
return null
}
if (!styles) {
styles = {}
}
for (key in styles) {
if (styles[key] != null) {
if ((key == "opacity" || key == "cssFloat") && b.IE) {
if (key == "opacity") {
node.style["filter"] = "alpha(opacity=" + Math.ceil(parseFloat(styles[key]) * 100) + ")"
}
if (key == "cssFloat") {
node.style["styleFloat"] = styles[key]
}
} else {
node.style[key] = styles[key]
}
}
}
return node
},
getData: function(node, dataId) {
return node.dataset ? node.dataset[dataId] : node.getAttribute("data-" + dataId)
},
setData: function(node, dataId, val) {
node.dataset ? (node.dataset[dataId] = val) : node.setAttribute("data-" + dataId, val)
}
});
utils.dom.$create("document", {
getHeight: function() {
var body = document.body,
html = document.documentElement;
return Math.max(body.scrollHeight, body.offsetHeight, html.clientHeight, html.scrollHeight, html.offsetHeight)
},
getWidth: function() {
var d = document,
m = "clientWidth";
return Math.max(d.documentElement[m], d.body[m]) || 0
},
getScrollTop: function() {
var d = document,
m = "scrollTop";
return window.pageYOffset || d.documentElement[m] || d.body[m] || 0
},
getScrollLeft: function() {
var d = document,
m = "scrollLeft";
return window.pageXOffset || d.documentElement[m] || d.body[m] || 0
}
});
utils.dom.$create("viewport", {
getHeight: function() {
var d = document,
de = d.documentElement,
m = "clientHeight";
return window.innerHeight || (de ? (de[m] || d.body[m] || 0) : 0)
},
getWidth: function() {
var d = document,
de = d.documentElement,
m = "clientWidth";
return window.innerWidth || (de ? (de[m] || d.body[m] || 0) : 0)
}
});
utils.dom.$create("style", {
getStylesheet: function() {
var st = this.$root.settings;
if (st.stylesheet) {
return st.stylesheet
}
var cont = document.getElementsByTagName("head");
cont = cont.length ? cont[0] : document.body;
var style = document.createElement("style");
style.type = "text/css";
return (st.stylesheet = cont.appendChild(style))
},
addRule: function(selector, css) {
var stylesheet = this.getStylesheet();
if (stylesheet.styleSheet && stylesheet.styleSheet.addRule) {
stylesheet.styleSheet.addRule(selector, css)
} else {
if (stylesheet.sheet && stylesheet.sheet.insertRule) {
stylesheet.sheet.insertRule([selector, "{", css, "}"].join(""), stylesheet.sheet.cssRules ? stylesheet.sheet.cssRules.length : 0)
}
}
},
addClass: function(el, cls) {
var uta = this.$root.utils.array,
classes = el.className.split(/\s+/);
if (uta.indexOf(classes, cls) == -1) {
uta.push(classes, cls)
}
el.className = classes.join(" ")
},
removeClass: function(el, cls) {
var classes = el.className.split(/\s+/);
this.$root.utils.array.discard(classes, cls);
el.className = classes.join(" ")
},
buildHookUnderlineCSS: function(type, color, imp) {
var bb = "border-bottom:",
td = "text-decoration:",
n = "none",
u = "underline",
i = imp ? " !important;" : ";";
switch (type) {
case "single":
return [bb, "0 ", n, i, td, u, i].join("");
case "dotted":
return [bb, "1px dotted ", color, i, td, n, i].join("");
case "dashed":
return [bb, "1px dashed ", color, i, td, n, i].join("");
case "none":
return [bb, "0 ", n, i, td, n, i].join("");
default:
return [bb, "1px solid ", color, i, td, u, i].join("")
}
},
buildBorderRadius: function(val) {
var what = this.$root.what,
dbs = document.body.style,
css = "border-radius:" + val + ";";
if (what(dbs.borderRadius) == "string") {
return css
} else {
if (what(dbs.MozBorderRadius) == "string") {
return "-moz-" + css
} else {
if (what(dbs.WebkitBorderRadius) == "string") {
return "-webkit-" + css
} else {
return ""
}
}
}
},
buildBoxShadow: function(val) {
var rt = this.$root,
what = rt.what,
b = rt.browser,
dbs = document.body.style,
css = "box-shadow:" + val + ";";
if (what(dbs.boxShadow) == "string") {
return css
} else {
if (what(dbs.MozBoxShadow) == "string") {
return "-moz-" + css
} else {
if (what(dbs.WebkitBoxShadow) == "string" && (!b.Safari || parseFloat(b.AppleWebKit >= 533))) {
return "-webkit-" + css
} else {
return ""
}
}
}
},
buildTextShadow: function(val) {
var what = this.$root.what,
dbs = document.body.style,
css = "text-shadow:" + val + ";";
if (what(dbs.textShadow) == "string") {
return css
} else {
if (what(dbs.MozTextShadow) == "string") {
return "-moz-" + css
} else {
if (what(dbs.WebkitTextShadow) == "string") {
return "-webkit-" + css
} else {
return ""
}
}
}
},
buildLinearGradient: function(start, end, startColor, endColor) {
var b = this.$root.browser,
css = "background-image:";
if (parseFloat(b.Firefox) >= 3.6) {
return [css, "-moz-linear-gradient(", start, ", ", startColor, ", ", endColor, " ", end, "px);"].join("")
} else {
if (parseFloat(b.AppleWebKit) >= 530) {
return [css, "-webkit-gradient(linear, left ", start, ", left ", end, ", from(", startColor, "), to(", endColor, "));"].join("")
} else {
return ""
}
}
},
supports: function(prop) {
var wh = this.$root.what,
dbs = document.body.style,
b = this.$root.browser,
s = "string",
M = "Moz",
W = "Webkit",
cprop = prop.charAt(0).toUpperCase() + prop.substr(1);
switch (prop) {
case "borderRadius":
case "textShadow":
return wh(dbs[prop]) == s ? prop : (wh(dbs[M + cprop]) == s ? M + cprop : (wh(dbs[W + cprop]) == s ? W + cprop : false));
case "boxShadow":
return wh(dbs[prop]) == s ? prop : (wh(dbs[M + cprop]) == s ? M + cprop : ((wh(dbs[W + cprop]) == s && (!b.Safari || parseFloat(b.AppleWebKit >= 533))) ? W + cprop : false));
case "linearGradient":
return (parseFloat(b.Firefox) >= 3.6 || parseFloat(b.AppleWebKit) >= 530) ? prop : false;
default:
return false
}
}
});
utils.dom.$create("event", {
disableEventBubbling: function(element, event) {
if (element.addEventListener) {
element.addEventListener(event, this.stop, false)
} else {
if (element.attachEvent) {
element.attachEvent("on" + event, this.stop)
}
}
},
stop: function(domEvt) {
domEvt.cancelBubble = true;
domEvt.returnValue = false;
if (domEvt.preventDefault) {
domEvt.preventDefault()
}
if (domEvt.stopPropagation) {
domEvt.stopPropagation()
}
}
});
$root.$create("helpers", {
getVar: function(v, context) {
var wl = this.$root.settings.white_label,
s1 = "infolink",
s2 = s1 + "s",
undef = "undefined",
what = this.$root.what;
s1 += "_";
s2 += "_";
var val = wl && what(window[wl + "_" + v]) != undef ? window[wl + "_" + v] : what(window[s2 + v]) != undef ? window[s2 + v] : what(window[s1 + v]) != undef ? window[s1 + v] : null;
if (context) {
context[v] = val
}
return val
},
chanceIntegration: function() {
var percentage = this.getVar("percentage");
if (percentage) {
percentage = percentage > 100 ? 100 : percentage < 0 ? 0 : percentage;
var rnd = Math.random() * 100;
if (rnd > percentage) {
var integrationNode;
try {
integrationNode = this.searchForIntegrationComment(document.body)
} catch (ex) {
integrationNode = null
}
if (integrationNode) {
var js = integrationNode.data;
if (document.readyState != "complete" && !this.getVar("ddw")) {
document.write(js.substring(14, js.length))
}
}
this.$root.logger.log("Stopping on unlucky chance integration.", this.chanceIntegration);
return true
}
}
return false
},
searchForIntegrationComment: function(node) {
switch (node.nodeType) {
case 1:
case 9:
for (var i = 0, leni = node.childNodes.length; i < leni; i++) {
var resultNode = this.searchForIntegrationComment(node.childNodes[i]);
if (resultNode) {
return resultNode
}
}
return null;
case 8:
return node.data.length > 15 && node.data.substr(0, 14) == "IL_INTEGRATION" ? node : null;
default:
return null
}
},
isSupportedClient: function() {
var rt = this.$root,
b = rt.browser,
sv = rt.settings.supportedClients[b.getName()];
return sv && b.getVersion(true) >= sv
},
setHosts: function() {
var rt = this.$root,
host, url, ver, path = "",
re, st = rt.settings,
hosts = st.hosts;
var scripts = document.getElementsByTagName("script"),
resources = rt.helpers.getVar("resources");
if (window.INFOLINKS && window.INFOLINKS._boot) {
st.boot = window.INFOLINKS._boot;
ver = rt.version = st.boot.version;
re = /\/infolinks_main\.js$/
} else {
if (window.$iceboot) {
st.boot = window.$iceboot;
ver = rt.version = st.boot.version;
re = /\/infolinks_main\.js$/
} else {
re = new RegExp(versionFile + ".js$")
}
}
if (resources) {
resources = resources.replace(/^\w+:\/\//, "");
host = resources.substring(0, resources.indexOf("/"));
path = resources.substring(resources.indexOf("/")) + "/"
} else {
for (var i = 0, leni = scripts.length; i < leni; i++) {
if (scripts[i].src.match(re) != null) {
url = scripts[i].src.replace(/^\w+:\/\//, "");
host = url.replace(/\/.*/, "");
path = url.substring(url.indexOf("/"), url.lastIndexOf("/") + 1);
if (!ver) {
var parts = path.split("/");
rt.version = parts[parts.length - 2]
}
break
}
}
}
if (host) {
hosts.resources = host
} else {
hosts.resources = hosts.resourcesDefault;
path = hosts.scriptDefaultPath
}
hosts.router = rt.utils.string.toObject(location.search, "il.mt") || rt.helpers.getVar("metro_server") || hosts.resources.replace(/\bresources\b/, "router");
hosts.thumbnails = hosts.resources.replace(/\bresources\b/, "thumbnails");
if (ver) {
path += ver
}
if (path && path.charAt(path.length - 1) != "/") {
path += "/"
}
hosts.scriptPath = path;
if (path.indexOf("/src/") != -1) {
hosts.src = true
}
},
getCustomerId: function() {
var rt = this.$root,
hp = rt.helpers;
rt.settings.$extend({
customerId: hp.getVar("cid") || hp.getVar("pid") || "null",
websiteId: hp.getVar("wsid") || 0,
customerUrl: document.location.href
})
},
setDefaultWebsiteDirectives: function(data) {
var rt = this.$root,
key, dwd = {
ht: true,
qmin: 1,
ha: null,
hd: null
};
if (!data.wd) {
data.wd = {}
}
for (key in dwd) {
if (rt.what(data.wd[key]) == "undefined") {
data.wd[key] = dwd[key]
}
}
},
getReferrer: function() {
var rt = this.$root,
docRef = document.referrer,
res = {
ref: "",
refq: ""
},
refqIndex, ut = rt.utils,
uts = ut.string,
hasRefc = ut.cookie.has("refc"),
simQuery = ut.string.toObject(location.search, "il.sq");
if (simQuery) {
res = {
refq: decodeURIComponent(simQuery),
ref: ut.base64.decodeBase64("d3d3Lmdvb2dsZS5jb20=")
};
ut.object.extend(rt.settings, res);
return res
}
if (docRef) {
refqIndex = docRef.indexOf("?");
if (refqIndex != -1) {
try {
var queryObj = uts.toObject(docRef.substring(refqIndex + 1));
res.refq = uts.truncate(uts.trim(decodeURIComponent((queryObj.q || queryObj.p || "").replace(/\+/g, " "))), 100, "");
res.ref = docRef.substring(0, refqIndex)
} catch (ex) {
rt.logger.error("Error reading referrer.", this.getReferrer)
}
if (docRef.indexOf(ut.base64.decodeBase64("Lmdvb2dsZS4=")) != -1 && /\/(url|imgres|search|cse)/.test(docRef.substring(docRef.indexOf("/"))) && (!queryObj || !queryObj["adurl"])) {
res.ose = 1
}
} else {
if (!hasRefc) {
res.ref = docRef
}
}
res.ref = uts.truncate(res.ref.replace(/^\w+:\/\//, ""), 100, "");
if (res.refq && !hasRefc) {
ut.cookie.set("refc", ut.object.toQueryString(res), 60)
}
}
if (!res.refq && hasRefc) {
ut.object.extend(res, uts.toObject(ut.cookie.get("refc") || ""))
}
ut.object.extend(rt.settings, res);
return res
},
normalizeText: function(text) {
var delimiter = "|";
text = text.replace(/\.|:|;|<|>|=|\?|\(|\)|\[|\]|\{|\}|,|"|\x201C|\x201D|\x96|\x97|\\|\//g, delimiter);
text = text.replace(/['`\-]\W/g, delimiter).replace(/\W['`\-]/g, delimiter);
var re1 = new RegExp("\\s*\\" + delimiter + "+\\s*", "g");
var re2 = new RegExp("\\" + delimiter + "{2,}", "g");
text = text.replace(re1, delimiter).replace(re2, delimiter);
text = text.toLowerCase().replace(/\|/g, "P").replace(/\s/g, "S").replace(/\./g, "D").replace(/'/g, "Q").replace(/\$/g, "M").replace(/\+/g, "A");
return text
},
countWords: function(text) {
var re = new RegExp("P|S", "g");
var matched = text.match(re);
return (matched != null) ? matched.length + 1 : 0
},
getMetaContent: function(name, limit) {
var metas = document.getElementsByTagName("meta");
for (var i = 0, leni = metas.length; i < leni; i++) {
if (metas[i].name && metas[i].name.toLowerCase() == name && metas[i].content) {
return this.normalizeText(this.$root.utils.string.truncateToChar(metas[i].content, limit * 1024, " "))
}
}
return ""
},
getSilverlightVersion: function() {
var plugin = navigator.plugins["Silverlight Plug-In"],
version = -1;
if (plugin) {
version = plugin.description
} else {
try {
var control = new ActiveXObject("AgControl.AgControl");
var checkVersion = 2;
while (control.IsVersionSupported(checkVersion + ".0")) {
checkVersion++
}
checkVersion--;
version = (checkVersion == 1) ? -1 : checkVersion
} catch (ex) {}
}
return version
},
getTagTexts: function(tags, prop, param) {
var rt = this.$root,
ut = rt.utils,
uts = ut.string,
uta = ut.array,
nodes, res = [],
i, leni, j, lenj, val, end = false,
charCount = 0,
tlm = rt.settings.textLimits.merged,
nodesCount = 0,
maxNodes = 20;
if (rt.what(tags) != "array") {
tags = [tags]
}
for (i = 0, leni = tags.length; i < leni; i++) {
nodes = document.getElementsByTagName(tags[i]);
for (j = 0, lenj = nodes.length; j < lenj; j++) {
val = prop == "text" ? (nodes[j].textContent || nodes[j].innerText || "") : prop == "alt" ? nodes[j].alt : "";
if (!val) {
continue
}
val = uts.truncateToChar(val, tlm[param].i, " ");
nodesCount++;
if (charCount + val.length > tlm[param].t * 1024 || nodesCount >= maxNodes) {
end = true;
break
}
uta.push(res, val);
charCount += val.length
}
if (end) {
break
}
}
return this.normalizeText(res.join("|"))
},
processImpressionResponse: function(response) {
var rt = this.$root,
hp = rt.helpers,
component;
if (rt.what(response) != "object") {
return null
}
if (response.components) {
response.prs = {};
for (component in response.components) {
response.prs[component.charAt(0)] = response.components[component]
}
delete response.components
}
hp.normalizeSentenceLists(response);
if (response.messages) {
hp.findMaxBidCount(response)
}
return response
},
findMaxBidCount: function(response) {
var prod, msg, i, maxBDC = 0;
for (prod in response.prs) {
msg = response.prs[prod].messages;
if (!msg) {
continue
}
for (i in msg) {
if (msg[i].bdc > maxBDC) {
maxBDC = msg[i].bdc
}
}
}
this.$root.settings.bdc = maxBDC
},
normalizeSentenceLists: function(response) {
var prs = response.prs,
prod, ut = this.$root.utils,
numOfSentences = ut.object.keys(response.sentences).length;
for (prod in prs) {
if (numOfSentences && prs[prod].sentences.length == 1 && prs[prod].sentences[0] == "ALL") {
prs[prod].sentences = ut.array.range(0, numOfSentences - 1)
}
}
},
getCustomerBehavior: function(str) {
var rt = this.$root,
v, key, i, leni, res = {};
function uc() {
return arguments[1].toUpperCase()
}
var arr = rt.utils.string.qw(str);
for (i = 0, leni = arr.length; i < leni; i++) {
v = rt.helpers.getVar(arr[i]);
if (v != null) {
key = arr[i].replace(/_(\w)/g, uc);
res[key] = v
}
}
return res
},
getImpressionBehavior: function() {
var rt = this.$root,
st = rt.settings,
uto = rt.utils.object,
bi = rt.comm.settings.responses.impression.behavior_imp || {};
uto.renamePorpery(bi, "lc", "linkColor");
uto.renamePorpery(bi, "st", "bubbleShowDelay");
uto.renamePorpery(bi, "rw", "adsReuseWindow");
uto.renamePorpery(bi, "bd", "bubbleDirection");
st.behavior.impression = bi
},
renameBehaviorProperties: function(o) {
var rt = this.$root,
uto = rt.utils.object;
uto.renamePorpery(o, "hc", "highlightCount");
uto.renamePorpery(o, "lc", "linkColor");
uto.renamePorpery(o, "du", "doubleUnderline");
uto.renamePorpery(o, "st", "bubbleShowDelay");
uto.renamePorpery(o, "rw", "adsReuseWindow");
uto.renamePorpery(o, "si", "simanitIcon");
uto.renamePorpery(o, "bd", "bubbleDirection");
uto.renamePorpery(o, "t", "theme");
uto.renamePorpery(o, "ln", "lines");
return o
},
sanitize: function(data, sanitizer, strict) {
var rt = this.$root;
for (var key in data) {
if (strict && rt.what(sanitizer[key]) == "undefined") {
delete data[key];
continue
}
switch (sanitizer[key]) {
case "int":
data[key] = parseInt(data[key], 10) || 0;
break;
case "bool":
data[key] = data[key] == "false" ? false : !! data[key];
break;
case "color":
data[key] = this.validateColorValue(data[key] || "");
break;
case "str":
data[key] = data[key] && data[key].toString ? data[key].toString() : data[key];
break;
case "node":
data[key] = data[key] && data[key].tagName ? data[key] : null;
break;
default:
if (rt.what(sanitizer[key]) == "array") {
if (rt.utils.array.indexOf(sanitizer[key], data[key]) == -1) {
data[key] = sanitizer[key][0]
}
}
}
}
return data
},
validateColorValue: function(color) {
return (color && color.match(/^#?[0-9a-fA-F]{6}$/) != null) ? color.charAt(0) == "#" ? color : "#" + color : "#000000"
},
createBaseClasses: function() {
var rt = this.$root,
dmst = rt.utils.dom.style,
baseClass = rt.settings.baseClass;
var baseCSS = "margin:0;padding:0;border:0;outline:0;font:normal normal normal 13px trebuchet MS,Arial,sans-serif;vertical-align:baseline;background:transparent;list-style:none;text-decoration:none;text-align:left;float:none;";
dmst.addRule("." + baseClass, baseCSS);
dmst.addRule("." + baseClass + " *", baseCSS);
dmst.addRule("a." + baseClass + ":hover", "background-color:transparent !important;")
},
getHookData: function(hookId) {
var data = this.$root.comm.settings.responses.getads;
return data ? data[hookId] || null : null
},
setHookData: function(hookId, data) {
var res = this.$root.comm.settings.responses;
if (!res.getads) {
res.getads = {}
}
res.getads[hookId] = data
},
clearHookData: function(hookId) {
var data = this.$root.comm.settings.responses.getads;
if (data && data[hookId]) {
data[hookId] = null
}
},
createHook: function(hookId, sentence, node, fontSize, context, prodCode, prodName, hasBubble, instance) {
var rt = this.$root,
st = rt.settings,
sn = context.settings.sentences;
var hook = {
id: hookId,
fontSize: fontSize,
node: node,
parentNode: node.parentNode,
rendered: true,
sentence: sentence,
prod: prodCode,
type: prodName,
hovered: false,
currentAdIndex: 0,
instance: instance
};
st.hooksMap[hook.id] = hook;
if (!sn[sentence]) {
sn[sentence] = {
hooks: [],
rendered: 0
}
}
rt.utils.array.push(sn[sentence].hooks, hook);
sn[sentence].rendered++;
if (hasBubble) {
hook.bubble = rt.utils.object.clone(rt.bubble.settings.base);
rt.helpers.bindHookEvents(hook)
}
return hook
},
getHookBehavior: function(hookId) {
return this.$root.products[this.$root.settings.hooksMap[hookId].type].settings.behavior.merged
},
bindHookEvents: function(hook) {
var rt = this.$root,
ed = rt.event.dom,
rtb = rt.bubble,
node = hook.node,
data = {
hookId: hook.id
};
ed.bind(node, {
event: "dblclick",
listener: rtb.hookDblClick
});
ed.bind(node, {
event: "mouseenter",
data: data,
listener: rtb.hookMouseover
});
ed.bind(node, {
event: "mouseleave",
data: data,
listener: rtb.hookMouseout
});
ed.bind(node, {
event: "click",
data: data,
listener: rtb.hookClick
})
},
getHookSD: function(hookId) {
var rt = this.$root,
st = rt.settings,
hook = st.hooksMap[hookId],
imp;
if (!hook) {
return {}
}
imp = hook.updater ? hook.updater.impression : rt.comm.settings.responses.impression;
return rt.utils.object.extend({
sdata: hook.sentence,
scs: imp.sentences[hook.sentence]
}, imp.rauth)
},
getAdByMidx: function(ads, midx) {
return this.$root.utils.array.find(ads, function(ad) {
return ad.midx == midx
})
},
setAdThumbnail: function(ad) {
if (ad.template == "text" && !ad.thumbURL) {
ad.thumbURL = ["http://", this.$root.settings.hosts.thumbnails, "/thumbnail.jpg?domain=", ad.displayedURL].join("")
}
},
hitTrackerURL: function(trackerURL) {
var rt = this.$root;
if (rt.what(trackerURL) != "array") {
trackerURL = [trackerURL]
}
for (var i = 0; i < trackerURL.length; i++) {
rt.utils.dom.createDOMFragment({
tag: "img",
parent: document.body,
attributes: {
src: trackerURL[i]
},
style: {
display: "none"
}
})
}
},
mapUnhoverableAreas: function() {
var rt = this.$root,
st = rt.settings,
ut = rt.utils,
dmel = ut.dom.element,
b = rt.browser;
var embeds = document.getElementsByTagName("embed");
var objects = document.getElementsByTagName("object");
var arr = ut.array.concat(embeds, objects);
st.unhoverableAreas = [];
for (var i = 0; i < arr.length; i++) {
if (!dmel.isVisible(arr[i])) {
continue
}
if (arr[i].tagName.toLowerCase() == "embed") {
if ((arr[i].getAttribute("wmode") || "").toLowerCase() == "transparent") {
continue
}
} else {
var params = arr[i].getElementsByTagName("param"),
hasWmode = false;
for (var j = 0, lenj = params.length; j < lenj; j++) {
if (params[j].name == "wmode" && params[j].value.toLowerCase() == "transparent") {
hasWmode = true;
break
}
}
if (hasWmode) {
continue
}
}
if (arr[i].tagName.toLowerCase() == "embed" && arr[i].parentNode.tagName.toLowerCase() == "object") {
if (b.IE) {
continue
} else {
ut.array.discard(arr, arr[i].parentNode)
}
}
var width = parseInt(arr[i].width, 10) || arr[i].offsetWidth || 0;
var height = parseInt(arr[i].height, 10) || arr[i].offsetHeight || 0;
if (!width || !height) {
continue
}
var pos = dmel.offset(arr[i]);
ut.array.push(st.unhoverableAreas, [pos.left, pos.top, pos.left + width, pos.top + height])
}
},
hasSpecialTags: function(content, tags) {
content = content.toLowerCase();
if ((tags == "all" || tags == "script") && (content.indexOf("<scr") != -1 || content.indexOf("document.write") != -1)) {
return true
}
return (tags == "all" || tags == "iframe") && content.indexOf("<ifr") != -1
},
parseTokens: function(hook, content) {
var rt = this.$root,
data = this.getHookData(hook.id),
ad = rt.helpers.getAdByMidx(data.ads, hook.currentAdIndex);
if (!content) {
content = ad.content
}
if (ad.template == "html" || ad.template == "external") {
var re = /@start@.*?@end@/,
match, matchUrl, url, redirectUrl, encoded;
while ((match = content.match(re)) != null) {
matchUrl = match[0];
url = matchUrl.substring(7, matchUrl.length - 5);
redirectUrl = rt.comm.getRedirectUrl(hook, url, "onWin");
content = content.replace(re, redirectUrl)
}
re = /@encode@.*?@encode@/;
while ((match = content.match(re)) != null) {
encoded = encodeURIComponent(match[0].substring(8, match[0].length - 8));
content = content.replace(re, encoded)
}
}
if (ad.contentType == "javascript") {
content = ['<script type="text/javascript">', content, "<\/script>"].join("")
}
return content
},
setActualTemplate: function(ad) {
ad.actualTemplate = (ad.echo || (ad.template == "html" || ad.template == "external") && ad.content && this.hasSpecialTags(ad.content, "script")) ? "iframe" : ad.template
},
getPlatform: function() {
var rt = this.$root,
gen = document.getElementsByName("generator"),
i, leni, val, undef = "undefined";
for (i = 0, leni = gen.length; i < leni; i++) {
val = gen[i].getAttribute("content");
if (!val) {
continue
}
if (val.indexOf("WordPress") > -1) {
return "wdp"
}
if (val.indexOf("Joomla") > -1) {
return "jml"
}
if (val.indexOf("blogger") > -1) {
return "bsp"
}
if (val.indexOf("vBulletin") > -1) {
return "vbt"
}
if (val.indexOf("phpBB") > -1) {
return "pbb"
}
if (val.indexOf("weebly") > -1) {
return "wbl"
}
if (val.indexOf("tumblr") > -1) {
return "tbr"
}
}
if (rt.what(window["Drupal"]) != undef) {
return "drl"
}
if (rt.what(window["Joomla"]) != undef) {
return "jml"
}
if (rt.what(window["blogger"]) != undef) {
return "jml"
}
if (rt.what(window["blogger_blog_id"]) != undef) {
return "jml"
}
if (rt.utils.dom.filterByClass("contentpaneopen").length) {
return "jml"
}
if (rt.what(window["vBulletin"]) != undef) {
return "vbt"
}
if (rt.what(window["phpbb"]) != undef) {
return "pbb"
}
if (rt.what(window["positionWeeblyFooter"]) != undef) {
return "wbl"
}
if (rt.what(window["Tumblr"]) != undef) {
return "tbr"
}
if (rt.what(window["ipb"]) != undef) {
return "ipb"
}
var links = document.getElementsByTagName("link"),
href;
for (i = 0, leni = links.length; i < leni; i++) {
href = links[i].getAttribute("href");
if (!href) {
continue
}
if (href.indexOf("wp-content") > -1) {
return "wdp"
}
if (href.indexOf("support-files") > -1) {
return "sbi"
}
}
return ""
},
getSiteLanguage: function() {
if (this.getSiteLanguage.lang) {
return this.getSiteLanguage.lang
}
var lang = "en";
return this.getSiteLanguage.lang = lang
},
translate: function(key) {
var tr = this.$root.settings.translations;
return tr[key] ? tr[key][this.getSiteLanguage()] : key
},
getEchoForm: function(content, iframeName, formId, formCls) {
var rt = this.$root,
st = rt.settings,
echo = "http://" + st.hosts.router + "/echo.htm";
var html = '<form <% if (formId){ %>id="<%= formId %>"<% } %> <% if (formCls){ %>class="<%= formCls %>"<% } %> method="post" action="<%= echo %>" target="<%= iframeName %>" accept-charset="utf-8" style="display:none;"> <input type="hidden" name="echo" value="<%= content %>" /> <input type="hidden" name="pid" value="<%= cid %>" /> <input type="hidden" name="wsid" value="<%= wsid %>" /> <input type="hidden" name="jsv" value="<%= jsv %>" /> </form>';
return rt.utils.VeST(html, {
echo: echo,
content: encodeURIComponent(content.split("").reverse().join("")),
iframeName: iframeName,
formId: formId,
formCls: formCls,
cid: st.customerId,
wsid: st.websiteId,
jsv: rt.version,
nocache: rt.utils.number.next("echo")
})
}
});
var comm = $root.$create("comm", {
loadScript: function(url, params, event, data) {
var $comm = this,
rt = this.$root,
qstr = "",
qarr = [],
cbfunc;
if (rt.what(params) == "object") {
for (var key in params) {
rt.utils.array.push(qarr, (qarr.length || url.indexOf("?") != -1) ? "&" : "?", encodeURIComponent(key), "=", encodeURIComponent(params[key]))
}
qstr = qarr.join("")
} else {
if (rt.what(params) == "string") {
qstr = params
}
}
url += qstr;
if (url.match(/^\w+:\/\//) == null) {
url = "http://" + url
}
if (event) {
cbfunc = function(url) {
var rt = $comm.$root,
ls = $comm.loadedScripts;
if (ls[url]) {
return true
}
ls[url] = true;
if (rt.what(data) == "undefined") {
rt.event.fire(event)
} else {
rt.event.fire(event, data)
}
}
} else {
cbfunc = function() {
$comm.loadedScripts[url] = true
}
}
if (this.loadedScripts[url]) {
cbfunc()
} else {
this.loadedScripts[url] = false;
var script = document.createElement("script");
script.type = "text/javascript";
script.charset = "UTF-8";
script.onreadystatechange = function() {
if (/complete|loaded/.test(this.readyState) && !$comm.loadedScripts[url]) {
cbfunc(url)
}
};
script.onload = function() {
cbfunc(url)
};
script.src = url;
var container = document.getElementsByTagName("head");
container = container[0] || document.body;
script = container.appendChild(script);
return true
}
},
supportsCORS: function() {
var xhr = window.XMLHttpRequest ? new XMLHttpRequest() : null;
return this.settings.cors = (xhr && "withCredentials" in xhr)
},
sendRequest: function(options, beforeSend) {
var rt = this.$root,
b = rt.browser,
st = rt.settings,
cst = this.settings,
uta = rt.utils.array,
hasBeforeSend = rt.what(beforeSend) == "function",
ptxt, removeParams, totalLength, ptxtMaxLength, i, leni;
var urlCharLimit = {
IE: 2048,
Other: 8192
};
if (b.iPhone || b.iPad) {
var inputs = [],
formContainer;
if (hasBeforeSend) {
beforeSend.call(rt, "i")
}
for (var key in options.params) {
uta.push(inputs, {
tag: "input",
type: "hidden",
attributes: {
name: key
},
value: options.params[key]
})
}
formContainer = document.getElementById("IL_FORM_CONT");
if (formContainer) {
var parent = formContainer.parentNode;
parent.removeChild(formContainer)
}
formContainer = rt.utils.dom.createDOMFragment({
tag: "div",
parent: document.body,
id: "IL_FORM_CONT",
style: {
display: "none"
},
children: [{
tag: "form",
id: "IL_FORM",
children: inputs,
attributes: {
method: options.method,
action: options.url,
target: "IL_FRAME"
}
}, {
tag: "div",
id: "IL_FRAME_CONT",
innerHTML: '<iframe id="IL_FRAME" name="IL_FRAME" src="' + st.blankURL + '" width="1" height="1" frameborder="0" scrolling="no"></iframe>'
}]
});
if (formContainer) {
document.getElementById("IL_FORM").submit()
}
} else {
if (cst.mode == "cors") {
if (hasBeforeSend) {
beforeSend.call(rt, "a")
}
this.sendAjaxRequest(options)
} else {
if (cst.mode == "messaging") {
if (cst.messagingReady) {
if (hasBeforeSend) {
beforeSend.call(rt, "a")
}
var message = rt.utils.object.stringify({
action: "ajax",
data: options
});
this.sendMessage(message)
} else {
rt.utils.array.push(this.pendingRequests, [options, beforeSend])
}
} else {
if (cst.mode == "flash") {
if (b.IE) {
if (hasBeforeSend) {
beforeSend.call(rt, "f")
}
this.flash.embedIE(options)
} else {
if (this.flash.flashLoadAmount == 10 && this.flash.flashElement) {
if (hasBeforeSend) {
beforeSend.call(rt, "f")
}
this.flash.sendURLRequest(options.url, options.method, options.params, options.onSuccess, options.onSuccess, 1)
} else {
rt.utils.array.push(this.pendingRequests, [options, beforeSend])
}
}
} else {
if (hasBeforeSend) {
beforeSend.call(rt, "s")
}
ptxt = options.params.ptxt;
removeParams = rt.utils.string.qw("ptxt plinks pimgs phdrs pdesc page_keyw ptitle"), i, leni = removeParams.length;
for (i = 0, leni = removeParams.length; i < leni; i++) {
options.params[removeParams[i]] = ""
}
rt.utils.object.clean(options.params);
totalLength = rt.utils.object.toQueryString(options.params).length + options.url.length + document.location.href.length + navigator.userAgent.length + document.cookie.length + 400;
ptxtMaxLength = urlCharLimit[b.IE ? "IE" : "Other"] - totalLength;
if (ptxtMaxLength < 0) {
rt.logger.error("Request too long for GET.", this.sendRequest);
return
}
options.params.ptxt = (ptxtMaxLength > 0) ? ptxt.substring(0, ptxtMaxLength) : "";
options.params.twnum = rt.helpers.countWords(options.params.ptxt);
this.loadScript(options.url, options.params)
}
}
}
}
},
sendMessage: function(message) {
var rt = this.$root,
commFrame = rt.utils.dom.element.$("iceCommFrame");
if (commFrame && commFrame.contentWindow) {
commFrame.contentWindow.postMessage(message, "*")
} else {
rt.logger.error("Could not get comm frame.", this.sendMessage)
}
},
receiveMessage: function(event) {
var de = event.domEvent,
message = de.data,
data, rt = this.$root,
lg = rt.logger;
var origin = (de.origin || de.domain).replace("http://", "");
if (origin.indexOf(this.settings.responses.gsd.rs) != 0) {
return
}
if (message.charAt(0) == "(" && message.charAt(message.length - 1) == ")") {
message = message.substring(1, message.length - 1)
}
try {
data = rt.what(window.JSON) != "undefined" && window.JSON.parse ? window.JSON.parse(message) : eval("(" + message + ")")
} catch (ex) {
lg.error("Data parsing failed: " + ex.message + ". message:" + message + " ", this.receiveMessage);
return
}
if (data.action == "error") {
lg.error(data.data, this.receiveMessage)
} else {
if (data.action == "event") {
rt.event.fire(data.type, data.data)
} else {
if (!data.action) {
rt.event.fire("afterImpression", data)
}
}
}
},
sendAjaxRequest: function(o) {
var rt = this.$root,
xhr, xdr, xhrc = window.XMLHttpRequest ? new XMLHttpRequest() : null;
if (rt.what(o) != "object") {
return null
}
if (xhrc && "withCredentials" in xhrc) {
xhr = xhrc
} else {
if (window.XDomainRequest) {
xdr = new XDomainRequest()
}
}
if (!xhr && !xdr) {
return null
}
if (xhr) {
xhr.onreadystatechange = function() {
if (!req || !req.xhr) {
return
}
if (req.xhr.readyState == 4) {
reqComplete(req)
}
}
} else {
xdr.onload = function() {
reqComplete(req)
}
}
function reqComplete(req) {
if (req.done || req.aborted) {
return
}
var o = req.xhr || req.xdr;
req.done = true;
if (req.xdr || req.xhr.status == 200) {
if (req.onSuccess) {
rt.comm.handleAjaxResponse({
action: "event",
type: req.onSuccess,
data: o.responseText
})
}
} else {
if (req.xdr || req.xhr.status != 0) {
rt.comm.handleAjaxResponse({
action: "error",
data: "Ajax request failed."
})
}
}
}
function reqTimeout() {
if (!req || req.done) {
return
}
var o = req.xhr || req.xdr;
req.aborted = true;
o.abort();
rt.comm.handleAjaxResponse({
action: "error",
data: "Ajax request timed out."
});
if (req.xhr) {
delete req.xhr["onreadystatechange"]
}
}
function process() {
var o = req.xhr || req.xdr,
params = req.params || {},
method = req.method || "GET",
url = req.url || window.location.href;
req.queryString = (req.queryString ? req.queryString + "&" : "") + rt.utils.object.toQueryString(params, true).substr(1);
if (req.method == "GET" && req.queryString) {
req.url += ((req.url.indexOf("?") > -1) ? "&" : "?") + req.queryString
}
if (req.timeout > 0) {
setTimeout(reqTimeout, req.timeout)
}
if (req.xhr) {
req.xhr.open(method, url, true)
} else {
req.xdr.open(method, url)
}
if (method == "POST") {
if (req.xhr && rt.what(req.xhr.setRequestHeader) == "function") {
req.xhr.setRequestHeader("Content-type", "application/x-www-form-urlencoded")
}
o.send(req.queryString)
} else {
o.send()
}
}
var req = rt.utils.object.extend({
xhr: xhr,
xdr: xdr,
process: process
}, o);
req.process();
return req
},
handleAjaxResponse: function(response) {
var rt = this.$root,
data;
if (response.action == "error") {
rt.logger.error(response.data, this.handleAjaxResponse)
} else {
if (response.action == "event") {
try {
data = rt.what(window.JSON) != "undefined" && window.JSON.parse ? window.JSON.parse(response.data) : eval("(" + response.data + ")")
} catch (ex) {
rt.logger.error("Data parsing failed: " + ex.message, this.handleAjaxResponse);
return
}
rt.event.fire(response.type, data)
}
}
},
getRedirectUrl: function(hook, url, clickedOn) {
var rt = this.$root,
st = rt.settings,
ut = rt.utils,
uto = ut.object,
data = rt.helpers.getHookData(hook.id),
ad = rt.helpers.getAdByMidx(data.ads, hook.currentAdIndex);
if (ad.noClickPrefix) {
return url || ad.redirectURL
}
var now = ut.date.now();
var params = uto.clean(uto.extend({
rid: this.settings.responses.gsd.rid,
bdc: hook.bdc,
midx: hook.midx || hook.currentAdIndex,
rts: now,
vt: ut.timer.poll("adView" + hook.id),
clk_t: clickedOn,
jsv: rt.version,
prod_t: hook.prod || "",
tcln: hook.tcln || "",
pst: hook.pst || "",
cv: hook.viewed ? 1 : 0,
refq: st.impression.params.refq || "",
ifip: st.ifip || ""
}, rt.helpers.getHookSD(hook.id)));
params.rurl = url || ad.redirectURL || "";
var serverClickUrl = ["http://", this.settings.responses.gsd.rs, "/action/clk.htm"].join("");
return serverClickUrl + uto.toQueryString(params, true)
}
}, {
settings: {
responses: {},
errorReportingUrl: "http://cel.infolinks.com/"
},
loadedScripts: {},
pendingRequests: []
}, true);
comm.$create("flash", {
getSwfUrl: function() {
return ["http://", this.$root.settings.hosts.resources, "/flash/ic5.swf"].join("")
},
embed: function() {
var rt = this.$root,
swf = this.getSwfUrl();
rt.utils.timer.start("tmr_fsh");
rt.utils.dom.createDOMFragment({
tag: "div",
parent: document.body,
style: {
display: "block",
position: "absolute",
top: "1px",
left: "1px",
width: "1px",
height: "1px"
},
innerHTML: ['<embed pluginspage="http://www.macromedia.com/go/getflashplayer" src="', swf, '" width="1" height="1" wmode="transparent" name="ilfc" allowScriptAccess="always" type="application/x-shockwave-flash"></embed>'].join("")
})
},
embedIE: function(options) {
var rt = this.$root,
st = rt.settings,
ut = rt.utils,
swf = this.getSwfUrl(),
id = "ilfc" + rt.utils.number.next("flashEmbedConter");
this.requests[options.url] = {
request: ut.object.extend(options, {
open: false,
complete: false
})
};
var flashVars = ut.object.toQueryString({
url: options.url,
method: options.method,
success: options.onSuccess,
error: options.onSuccess
}, true).substr(1);
if (options.params) {
flashVars += ["&", ut.object.toQueryString(options.params, true).substr(1)].join("")
}
window[id + "_DoFSCommand"] = function(command, args) {
var response, func;
try {
func = eval(command);
response = eval(decodeURIComponent(args))
} catch (ex) {
rt.logger.error("Error evaluating response.", this);
return
}
func.call(func.$parent, response)
};
rt.utils.timer.start("tmr_fsh");
ut.dom.createDOMFragment({
tag: "div",
parent: document.body,
style: {
display: "block",
position: "absolute",
top: "1px",
left: "1px",
width: "1px",
height: "1px"
},
innerHTML: ['<object id="', id, '" classid="clsid:D27CDB6E-AE6D-11cf-96B8-444553540000" codebase="http://download.macromedia.com/pub/shockwave/cabs/flash/swflash.cab" width="1" height="1" align="middle">', '<param name="movie" value="', swf, '" />', '<param name="quality" value="high" />', '<param name="allowScriptAccess" value="always" />', '<param name="wmode" value="transparent" />', '<param name="flashvars" value="environment=IE&pcode=', st.impression.pcode, "&", flashVars, '" />', "</object>", "<sc", "ript event=FSCommand(command,args) for=", id, ">\n ", id, "_DoFSCommand(command, args)</sc", "ript>"].join("")
});
this.flashLoadComplete()
},
flashLoadUpdate: function(loaded) {
this.flashLoadAmount = loaded
},
flashLoadComplete: function() {
var rt = this.$root;
this.flashLoadAmount = 10;
this.flashElement = window["ilfc" + rt.utils.number.get("flashEmbedConter")] || document["ilfc"];
rt.utils.timer.stop("tmr_fsh");
while (this.$parent.pendingRequests.length) {
this.$parent.sendRequest.apply(this.$parent, rt.comm.pendingRequests.shift())
}
},
sendURLRequest: function(url, method, params, success, error, contextReferenceKey) {
this.requests[url] = {
request: {
url: url,
method: method,
params: params,
success: success,
error: error,
contextReferenceKey: contextReferenceKey,
open: false,
complete: false
}
};
this.flashElement.sendURLRequest(url, method, params, success, error, contextReferenceKey)
},
requestOpenHandler: function(responseObj) {
this.requests[responseObj.url].request.open = true
},
requestCompleteHandler: function(response) {
var rt = this.$root,
data, request = this.requests[response.url];
if (!request) {
rt.logger.error("Missing Request Object");
return
}
request.request.complete = true;
request.response = response;
if (response.success) {
var event = response.success;
try {
data = eval(response.data.replace(/^data=/, ""))
} catch (e) {
rt.logger.error("Error Evaluating Response.");
return
}
rt.event.fire(event, data)
}
},
requestError: function(response) {
this.requests[response.url].response = response;
if (response.error) {
var event = response.error;
this.$root.event.fire(event, response)
}
},
getFlashVersion: function() {
var flashVer = -1,
swStr = "Shockwave Flash",
np = navigator.plugins,
swp, b = this.$root.browser;
if (np && np.length) {
swp = np[swStr + " 2.0"] || np[swStr];
if (swp) {
flashVer = parseFloat(swp.description.replace(/[a-z ]+([0-9\.]+)[a-z ]+/i, "$1."))
}
}
if (flashVer == -1 && b.IE && b.Windows) {
var axo, vnum = [".9", ".7", ".6", ".3", ".3", ""],
vstr = [null, null, "WIN 6,0,21,0", null, "WIN 3,0,18,0", "WIN 2,0,0,11"];
for (var i = 0, leni = vnum.length; i < leni; i++) {
try {
axo = new ActiveXObject("ShockwaveFlash.ShockwaveFlash" + vnum[i]);
flashVer = vstr[i] ? vstr[i] : axo.GetVariable("$version")
} catch (e) {}
if (flashVer != -1) {
break
}
}
if (flashVer != -1) {
flashVer = parseFloat(flashVer.replace(/^[a-z ]+/i, "").replace(/,/g, "."))
}
}
return flashVer
}
}, {
requests: {}
}, false);
comm.bind({
event: "initComm",
listener: {
init: function() {
var rt = this.$root,
cst = this.settings,
b = rt.browser;
cst.flashVersion = this.flash.getFlashVersion();
if ((b.iPhone || b.iPad) && window.postMessage) {
cst.mode = "formsubmit";
rt.event.dom.bind(window, {
event: "message",
listener: this.receiveMessage
})
} else {
if (this.supportsCORS()) {
cst.mode = "cors"
} else {
if (window.postMessage) {
cst.mode = "messaging";
cst.messagingReady = false;
rt.event.dom.bind(window, {
event: "message",
listener: this.receiveMessage
});
rt.utils.dom.createDOMFragment({
tag: "div",
style: {
display: "none"
},
parent: document.body,
innerHTML: ['<iframe id="iceCommFrame" src="http://', cst.responses.gsd.rs, '/comm2.htm" width="1" height="1" frameborder="0" scrolling="no"></iframe>'].join("")
})
} else {
if (cst.flashVersion >= 9) {
cst.mode = "flash";
if (!rt.browser.IE) {
this.flash.embed()
}
} else {
cst.mode = "unsupported";
rt.logger.error("Unsupported comm mode", this.init)
}
}
}
}
}
}
});
comm.bind({
event: "getAds",
listener: {
getAds: function(event) {
var rt = this.$root,
uto = rt.utils.object,
et = rt.externalTags,
hook = rt.settings.hooksMap[event.data.hookId];
if (uto.keys(et.settings.tags).length) {
hook.externalBidsTimeout = rt.event.fire("sendGetAds", uto.extend({
timeout: true
}, event.data), event.data.bidRequestTimeout || et.settings.bidRequestTimeout);
rt.event.fire("sendBids", event.data)
} else {
rt.event.fire("sendGetAds", event.data)
}
}
}
});
comm.bind({
event: "sendGetAds",
listener: {
sendGetAds: function(event) {
var rt = this.$root,
hookId = event.data.hookId,
st = rt.settings,
ut = rt.utils,
hook = st.hooksMap[hookId],
gsd = rt.comm.settings.responses.gsd;
if (event.data.timeout) {
hook.killBids = true
} else {
clearTimeout(hook.externalBidsTimeout)
}
if (!rt.helpers.getHookData(hookId)) {
rt.helpers.setHookData(hookId, "pending")
}
hook.bdc = ++st.bdc;
var params = ut.object.clean(ut.object.extend({
lid: hookId,
rid: gsd.rid,
jsv: rt.version,
rts: ut.date.now(),
bdc: hook.bdc,
prod_t: hook.prod,
cfv: rt.comm.settings.flashVersion,
ifip: st.ifip,
cb: event.data.callback || "getadsResponse",
tcln: hook.tcln,
pst: hook.pst,
purl: st.customerUrl,
ref: st.impression.params.ref,
refq: st.impression.params.refq,
ose: st.ose || ""
}, event.data.params || {}, rt.helpers.getHookSD(hookId), rt.externalTags.getBidData(hook.externalTag), rt.externalTags.getViewedTagsParam()));
if ("irt".indexOf(hook.prod) == -1) {
if (hook.prod == "s" || hook.prod == "o") {
params.as = "728*90"
}
}
if (rt.what(window["x1"]) != "undefined" && rt.what(window["x2"]) != "undefined") {
params[window["x1"]] = window["x2"]
}
rt.comm.loadScript(gsd.rs + "/action/getads.htm", params)
}
}
});
comm.bind({
event: "sendAdView",
listener: {
sendAdView: function(event) {
var rt = this.$root,
gsd = this.settings.responses.gsd,
ut = rt.utils,
uta = ut.array,
p = event.data.params,
hook = rt.settings.hooksMap[event.data.hookId],
data = rt.helpers.getHookData(hook.id),
undef = "undefined";
var params = ut.object.extend({
rid: gsd.rid,
bdc: rt.what(p.bdc) != undef ? p.bdc : uta.times(hook.bdc, data.ads.length).join("~"),
midx: rt.what(p.midx) != undef ? p.midx : uta.range(0, data.ads.length - 1).join("~"),
emd: rt.what(p.emd) != undef ? p.emd : (data.ads[hook.currentAdIndex].emd || ""),
rts: ut.date.now(),
prod_t: "unknown",
jsv: rt.version
}, rt.helpers.getHookSD(hook.id), p);
this.loadScript([gsd.rs, "/action/adview.htm"].join(""), params, "adViewed", event.data)
}
}
});
comm.bind({
event: "adViewed",
listener: {
adViewed: function(event) {
var rt = this.$root,
hook = rt.settings.hooksMap[event.data.hookId];
hook.viewed = true
}
}
});
comm.bind({
event: "doRedirect",
listener: {
doRedirect: function(event) {
var result = event.data;
var rt = this.$root,
st = rt.settings,
b = rt.browser,
ut = rt.utils,
hook = result.hook,
reuseWindow = rt.helpers.getHookBehavior(hook.id).adsReuseWindow,
winName;
if (st.clickStatus == "complete") {
return
}
if (!result.maxLength) {
result.maxLength = b.IE ? 2048 : 8192
}
var data = rt.helpers.getHookData(hook.id);
var url = result.url || rt.helpers.getAdByMidx(data.ads, hook.currentAdIndex).redirectURL;
rt.event.fire(hook.type + "HookMouseout", {
hookId: hook.id
});
var hookNodeId = hook.node.id;
st.clickStatus = "complete";
if (hook.bubble) {
rt.event.fire("hideBubble", {
hookId: hook.id
})
}
hook = null;
if (url.length < result.maxLength) {
winName = hookNodeId;
try {
winName = st.adWin.name
} catch (ex) {}
if (b.IE && b.getVersion(true) < 9) {
var anchor = rt.utils.dom.createDOMFragment({
tag: "a",
parent: document.body,
attributes: {
href: url
},
style: {
display: "none"
}
});
if (!reuseWindow && st.adWin && winName == hookNodeId) {
anchor.target = winName
}
anchor.click()
} else {
if (!reuseWindow && st.adWin && winName == hookNodeId) {
try {
st.adWin.location = url
} catch (ex) {
window.location = url;
st.adWin.close();
st.adWin = null
}
} else {
window.location = url
}
}
} else {
var action = url,
inputs = null,
urlParamsIndex = url.indexOf("?");
if (urlParamsIndex != -1) {
action = url.substring(0, urlParamsIndex);
var params = ut.string.toObject(url.substring(urlParamsIndex + 1), null, true);
inputs = [];
for (var key in params) {
ut.array.push(inputs, {
tag: "input",
type: "hidden",
value: params[key],
attributes: {
name: key
}
})
}
}
var redirectForm = ut.dom.createDOMFragment({
tag: "form",
parent: document.body,
style: {
display: "none"
},
children: inputs,
attributes: ut.object.extend({
action: action,
method: "post"
}, reuseWindow ? {} : {
target: hookNodeId
})
});
redirectForm.submit()
}
}
}
});
comm.bind({
event: "productClick",
listener: {
productClick: function(event) {
var rt = this.$root,
st = rt.settings,
hookId = event.data.hookId,
hook = st.hooksMap[hookId],
data = rt.helpers.getHookData(hookId),
clickType = event.data.clickType || hook.clickType;
if (st.clickStatus == "complete") {
return
}
if ((clickType == "onLink" || clickType == "onLinkAfterWinOpen") && data && data.ads[hook.currentAdIndex].redirectURL == "") {
st.clickStatus = "none";
if (st.adWin) {
rt.event.fire("hideBubble", {
hookId: hookId
});
st.adWin.close();
st.adWin = null
}
return
}
var url = this.getRedirectUrl(hook, event.data.url || null, clickType);
rt.event.fire("startClick", {
url: url,
hook: hook
})
}
}
});
comm.bind({
event: "startClick",
listener: {
updateClickCookie: function(event) {
var rt = this.$root,
st = rt.settings,
ut = rt.utils,
uto = ut.object,
now = rt.utils.date.now(),
hook = event.data.hook,
midx = hook.midx || hook.currentAdIndex,
data = rt.helpers.getHookData(hook.id),
ad = rt.helpers.getAdByMidx(data.ads, midx);
var params = uto.clean(uto.extend({
rid: this.settings.responses.gsd.rid,
bdc: hook.bdc,
midx: midx,
emd: ad.emd || "",
rts: now,
vt: ut.timer.poll("adView" + hook.id),
clk_t: hook.clickType,
jsv: rt.version,
prod_t: hook.prod || "",
tcln: hook.tcln || "",
pst: hook.pst || "",
ifip: st.ifip || ""
}, rt.helpers.getHookSD(hook.id)));
var url = ["http://", this.settings.responses.gsd.rs, "/", now, "/ck.js"].join("");
this.loadScript(url, params, "doRedirect", event.data)
}
}
});
comm.bind({
event: "commRemoteReady",
listener: {
commRemoteReady: function() {
var rt = this.$root,
uto = rt.utils.object,
st = this.settings,
key, data = [];
st.messagingReady = true;
var gsd = st.responses.gsd;
if (gsd.cks) {
for (key in gsd.cks) {
rt.utils.array.push(data, {
name: key,
value: gsd.cks[key],
expiration: "2y"
})
}
var message = uto.stringify({
action: "setcookie",
data: data
});
this.sendMessage(message)
}
while (this.pendingRequests.length) {
this.sendRequest.apply(this, this.pendingRequests.shift())
}
}
}
});
comm.bind({
event: "sendErrorReport",
listener: {
sendErrorReport: function(event) {
var rt = this.$root,
st = rt.settings,
gsd = rt.comm.settings.responses.gsd,
evt = null,
cbdata = null;
if (event.data.cbdata) {
evt = event.data.cbdata.evt;
cbdata = event.data.cbdata.data;
delete event.data.cbdata
}
this.loadScript(this.settings.errorReportingUrl, rt.utils.object.extend({
pid: st.customerId,
wsid: st.websiteId,
jsv: rt.version,
rid: gsd ? gsd.rid : ""
}, event.data || {}), evt, cbdata)
}
}
});
$root.$create("settings", {}, {
svntest: "yes",
supportedClients: {
IE: 6,
Firefox: 1.5,
Safari: 3,
MobileSafari: 4,
Opera: 10,
Chrome: 1,
AppleWebKit: 533,
ucweb: 7
},
hosts: {
resourcesDefault: "resources.infolinks.com",
scriptDefaultPath: "/js/"
},
productCodes: {
i: "intext",
t: "intag",
s: "insearch",
o: "insearch",
f: "inframe"
},
nodeTypes: {
ELEMENT: 1,
DOCUMENT: 9,
TEXT: 3,
COMMENT: 8
},
baseZIndex: 9999999,
bdc: 0,
behavior: {
def: {
linkColor: "009900",
bubbleShowDelay: 200,
bubbleHideDelay: 1000,
adsReuseWindow: true,
hoverRequestDelay: 20
},
sanitizer: {
linkColor: "color",
linkHoverColor: "color",
linkHoverBgColor: "color",
bubbleShowDelay: "int",
bubbleHideDelay: "int",
adsReuseWindow: "bool",
hoverRequestDelay: "int"
}
},
hooksMap: {},
hooksCount: 0,
baseClass: "IL_BASE",
clickStatus: "none",
defaultLabel: "infolinks",
defaultHomeUrl: "http://www.infolinks.com/?kid=bb&trackerid=101",
defaultHelpUrl: "http://www.infolinks.com/opt-out.html?pid=<%= cid %>&wsid=<%= wsid %>",
yourAdHereUrl: "http://www.infolinks.com/ads",
white_labelLoaded: false,
textLimits: {
def: {
plinks: {
t: 2,
i: 100
},
pimgs: {
t: 2,
i: 100
},
phdrs: {
t: 2,
i: 100
},
pdesc: 1,
page_keyw: 2
}
},
translations: {
advertisement: {
en: "Advertisement",
es: "Aviso Publicitario"
},
yourAdHere: {
en: "Your Ad Here",
es: "Publique Aqu??"
},
clickHere: {
en: "Click here",
es: "Presione Aqu??"
},
searchingFor: {
en: "Searching for",
es: "Buscando"
},
nextSearchResultFor: {
en: "Next search result for",
es: "Nueva b??squeda para"
},
learnMore: {
en: "Learn More",
es: "Saber m??s"
},
adsBy: {
en: "Ads by",
es: "Anuncios"
}
}
});
$root.$create("harvest", {
createInstance: function() {
var o = {};
o.texts = [];
o.nodes = [];
o.stopped = false;
o.harvesting = false;
o.firstNode = null;
o.charCount = 0;
o.insideAllowedNode = null;
o.useAllowSettings = false;
return o
},
setConditionalTags: function() {
var rt = this.$root,
st = rt.settings,
hs = this.settings,
label = (st.white_label || st.defaultLabel).toUpperCase();
hs.tagGenericOff = "INTEXT_OFF";
hs.tagGenericOn = "INTEXT_ON";
hs.tagGenericStop = "INTEXT_STOP";
hs.tagGenericToggle = "INTEXT_TOGGLE";
hs.tagOff = label + "_OFF";
hs.tagOn = label + "_ON";
hs.tagStop = label + "_STOP";
hs.tagToggle = label + "_TOGGLE"
},
setHarvestEnabled: function() {
var hs = this.settings;
var bodyHtml = document.body.innerHTML;
var indexOfCommentTag = function(tag) {
return bodyHtml.indexOf(["<!--", tag, "-->"].join(""))
};
var onIndexGeneric = indexOfCommentTag(hs.tagGenericOn);
var onIndexWL = indexOfCommentTag(hs.tagOn);
var onIndex = (onIndexGeneric == -1 || onIndexWL == -1) ? Math.max(onIndexGeneric, onIndexWL) : Math.min(onIndexGeneric, onIndexWL);
var offIndexGeneric = indexOfCommentTag(hs.tagGenericOff);
var offIndexWL = indexOfCommentTag(hs.tagOff);
var offIndex = (offIndexGeneric == -1 || offIndexWL == -1) ? Math.max(offIndexGeneric, offIndexWL) : Math.min(offIndexGeneric, offIndexWL);
hs.enabled = (onIndex == -1 || (offIndex != -1 && onIndex > offIndex))
},
getHarvestedText: function(container) {
var rt = this.$root,
st = rt.settings,
hs = this.settings,
hp = rt.helpers,
ut = rt.utils,
uta = ut.array,
hd = st.highlightDeny,
ha = st.highlightAllow,
instance = this.createInstance();
hs.instances[hs.instances.length] = instance;
if (hs.instances.length == 1) {
ut.timer.start("tmr_har")
}
if (ha) {
hs.allowedTags = uta.toObject(ha.tags, {}, 1);
hs.allowedIds = uta.toObject(ha.ids, {}, 1);
hs.allowedCls = uta.toObject(ha.cls, {}, 1);
for (var key in hs.allowedTags) {
if (hs.deniedTags[key]) {
delete hs.deniedTags[key]
}
}
if (!ha.min) {
ha.min = 1
}
instance.useAllowSettings = true
}
if (hd) {
hs.deniedTags = uta.toObject(hd.tags, hs.deniedTags, 1);
hs.deniedIds = uta.toObject(hd.ids, hs.deniedIds, 1);
hs.deniedCls = uta.toObject(hd.cls, hs.deniedCls, 1)
}
this.setConditionalTags();
this.setHarvestEnabled();
hs.allowOnclick = hp.getVar("allow_onclick");
this.harvestText(container || document.body);
var text = instance.texts.join("|");
text = hp.normalizeText(text);
var twnum = hp.countWords(text);
if (instance.useAllowSettings && twnum < ha.min) {
instance.useAllowSettings = false;
this.harvestText(container || document.body);
text = instance.texts.join("|");
text = hp.normalizeText(text);
twnum = hp.countWords(text)
}
if (hs.instances.length == 1) {
ut.timer.stop("tmr_har")
}
instance.text = text;
return instance
},
isHarvestableNode: function(node) {
var hs = this.settings,
ut = this.$root.utils;
return !((node.getAttribute("onclick") != null && node != document.body && !hs.allowOnclick) || hs.deniedTags[node.tagName.toLowerCase()] || (node.id && hs.deniedIds[node.id]) || (node.className && ut.object.hasKey(hs.deniedCls, node.className.split(/\s+/))) || (!this.$root.comm.settings.responses.gsd.wd.ht && !ut.dom.element.isVisible(node)))
},
harvestText: function(node) {
var rt = this.$root,
hs = this.settings,
nodeType = null,
ut = rt.utils,
uto = ut.object,
tm = ut.timer,
nt = rt.settings.nodeTypes,
i, leni, text, instanceNum = hs.instances.length - 1,
instance = hs.instances[instanceNum];
if (!instance.harvesting) {
instance.harvesting = true;
instance.stopped = false;
tm.start("harvest" + instanceNum);
instance.nodes = [];
instance.texts = [];
instance.charCount = 0;
instance.firstNode = node;
if (!instance.useAllowSettings) {
instance.insideAllowedNode = node
}
}
if (instance.stopped || hs.timeLimit != -1 && tm.poll("harvest" + instanceNum) >= hs.timeLimit) {
instance.stopped = true
} else {
nodeType = node.nodeType
}
var hasAllowedIds = uto.keys(hs.allowedIds).length > 0,
hasAllowedCls = uto.keys(hs.allowedCls).length > 0;
switch (nodeType) {
case nt.DOCUMENT:
case nt.ELEMENT:
if (this.isHarvestableNode(node)) {
if (instance.useAllowSettings && !instance.insideAllowedNode && !hs.deniedTags[node.tagName.toLowerCase()] && ((!hasAllowedIds && !hasAllowedCls) || (hasAllowedIds && node.id && hs.allowedIds[node.id]) || (hasAllowedCls && node.className && uto.hasKey(hs.allowedCls, node.className.split(/\s+/))))) {
instance.insideAllowedNode = node
}
for (i = 0, leni = node.childNodes.length; i < leni; i++) {
if (instance.stopped) {
break
}
this.harvestText(node.childNodes[i])
}
if (instance.insideAllowedNode == node) {
instance.insideAllowedNode = null
}
}
break;
case nt.TEXT:
if (hs.enabled && instance.insideAllowedNode) {
text = ut.string.trim(node.data).replace(/\s+/g, " ");
if (text.length > 3) {
if (hs.charLimit != -1 && instance.charCount + text.length > hs.charLimit) {
instance.stopped = true;
text = text.substring(0, hs.charLimit - instance.charCount).replace(/\S+$/, "")
}
ut.array.push(instance.nodes, node);
ut.array.push(instance.texts, text);
instance.charCount += text.length
}
}
break;
case nt.COMMENT:
this.checkConditionalTags(ut.string.trim(node.data), hs)
}
if (instance.firstNode == node) {
instance.harvesting = false;
tm.stop("harvest" + instanceNum)
}
},
checkConditionalTags: function(value, st) {
var c = this.settings;
switch (value) {
case c.tagOff:
case c.tagGenericOff:
st.enabled = false;
break;
case c.tagOn:
case c.tagGenericOn:
st.enabled = true;
break;
case c.tagToggle:
case c.tagGenericToggle:
st.enabled = !st.enabled;
break;
case c.tagStop:
case c.tagGenericStop:
st.stopped = true
}
}
}, {
settings: {
allowedCls: null,
allowedIds: null,
charLimit: 8000,
deniedCls: {
footer: 1,
wibiyaToolbar_window: 1
},
deniedIds: {
footer: 1,
wibiyaToolbar: 1,
wibiyaToolbar_window_template: 1
},
deniedTags: {
a: 1,
acronym: 1,
address: 1,
br: 1,
dd: 1,
dl: 1,
dt: 1,
embed: 1,
fieldset: 1,
h1: 1,
h2: 1,
h3: 1,
h4: 1,
h5: 1,
h6: 1,
iframe: 1,
input: 1,
label: 1,
legend: 1,
noscript: 1,
object: 1,
param: 1,
script: 1,
select: 1,
style: 1,
textarea: 1,
th: 1,
title: 1,
m: 1
},
enabled: true,
timeLimit: 1000,
instances: []
}
});
var shared = $root.$create("shared", {}, null, true);
shared.bind({
event: "main",
listener: {
main: function() {
var rt = this.$root,
ut = rt.utils,
st = rt.settings;
st.cconf = ut.string.toObject(ut.cookie.get("$ice-conf")) || {};
if (st.cconf.logto) {
rt.logger.output = st.cconf.logto
}
if (st.cconf.er) {
rt.logger.errorReporting = parseInt(st.cconf.er, 10)
}
rt.utils.timer.start("tmr_wait");
rt.settings.boot = (window["INFOLINKS"] && window["INFOLINKS"]._boot) ? window["INFOLINKS"]._boot : window.$iceboot ? window.$iceboot : null;
var $this = this;
rt.helpers.getVar("white_label", rt.settings);
if (rt.helpers.chanceIntegration()) {
return
}
if (document.readyState && /complete|interactive/i.test(document.readyState)) {
$this.$root.event.fire("domready");
return
}
if (this.$root.what(document.addEventListener) == "function") {
document.addEventListener("DOMContentLoaded", function() {
$this.$root.event.fire("domready")
}, false)
} else {
document.onreadystatechange = function() {
if (/complete|interactive/i.test(document.readyState)) {
document.onreadystatechange = null;
$this.$root.event.fire("domready")
}
}
}
}
}
});
shared.bind({
event: "domready",
listener: {
domready: function() {
var rt = this.$root,
hp = rt.helpers,
msg, i, leni, pluginUrl, src;
rt.utils.timer.stop("tmr_wait");
rt.utils.timer.start("tmr_all");
if (rt.settings._initialized) {
msg = "Trying to re-run an application that has already been initialized."
} else {
if (!hp.isSupportedClient()) {
msg = "Client is not supported: " + rt.browser.toString()
}
}
if (msg) {
rt.logger.error(msg, this.domready);
return
}
rt.settings._initialized = true;
hp.setHosts();
if (rt.demo.isDemo()) {
rt.event.fire("demo");
return
}
rt.event.fire("loadPlugins")
}
}
});
shared.bind({
event: "loadPlugins",
listener: {
loadPlugins: function() {
var rt = this.$root,
st = rt.settings,
hs = st.hosts,
src, i, leni, pluginUrl;
if (rt.settings.white_label && !rt.settings.white_labelLoaded) {
rt.settings.white_labelLoaded = true;
rt.comm.loadScript([hs.resources, hs.scriptDefaultPath, "0/wl/", st.white_label, ".js"].join(""), null, "loadPlugins");
return
}
var plugins = rt.helpers.getVar("plugins");
if (plugins) {
src = rt.settings.hosts.src ? "/src" : "";
if (rt.what(plugins) == "string") {
plugins = [plugins]
}
rt.settings.plugins = {};
for (i = 0, leni = plugins.length; i < leni; i++) {
pluginUrl = (plugins[i].match(/https?:\/\//)) ? plugins[i] : [rt.settings.hosts.resources, "/js", src, "/0/plugins/", plugins[i], ".js"].join("");
rt.settings.plugins[pluginUrl] = false;
rt.comm.loadScript(pluginUrl, null, "pluginLoaded", {
plugin: pluginUrl
})
}
} else {
rt.event.fire("beforeGSD")
}
}
}
});
shared.bind({
event: "pluginLoaded",
listener: {
pluginLoaded: function(event) {
var rt = this.$root,
st = rt.settings,
key;
st.plugins[event.data.plugin] = true;
if (rt.utils.array.indexOf(rt.utils.object.values(st.plugins), false) == -1) {
for (key in rt.plugins) {
if (rt.plugins[key] && rt.what(rt.plugins[key].init) == "function") {
rt.plugins[key].init()
}
}
rt.event.fire("beforeGSD")
}
}
}
});
shared.bind({
event: "beforeGSD",
listener: {
prepareGSD: function() {
var rt = this.$root,
st = rt.settings,
hp = rt.helpers;
hp.getCustomerId();
var docRef = hp.getReferrer();
var params = {
evt: "afterGSD",
pid: st.customerId,
wsid: st.websiteId,
pdom: location.hostname,
purl: st.customerUrl,
jsv: rt.version
};
if (docRef.ref.length) {
params.ref = docRef.ref
}
if (docRef.refq.length) {
params.refq = docRef.refq
}
rt.utils.timer.start("tmr_gsd");
rt.comm.loadScript([st.hosts.router, "/gsd/", rt.utils.date.now(), rt.utils.number.next("nocache")].join(""), params)
}
}
});
shared.bind({
event: "afterGSD",
listener: {
gsdCallback: function(evt) {
var rt = this.$root,
data = evt.data,
tl = rt.settings.textLimits;
rt.utils.timer.stop("tmr_gsd");
data.rs = rt.utils.string.toObject(location.search, "il.rt") || rt.helpers.getVar("runtime_server") || data.rs || null;
var msg = "";
if (!data.rs) {
msg = "GSD Response is missing `rs`."
}
if (!data.prs) {
msg = "GSD Response is missing `prs`."
}
if (msg) {
rt.logger.error(msg, this.gsdCallback, true);
return
}
data.rs = data.rs.toLowerCase();
if (!data.makey) {
data.makey = ""
}
rt.helpers.setDefaultWebsiteDirectives(data);
tl.merged = rt.utils.object.extend(tl.def, data.wd || {});
if (data.prs.indexOf("r") != -1) {
if (data.prs.indexOf("t") == -1) {
data.prs += ",t"
} else {
data.wd.rtm = "b"
}
}
rt.comm.settings.responses.gsd = data;
rt.event.fire("initComm");
if (/i|t/.test(data.prs)) {
rt.event.fire("beforeHarvest")
} else {
rt.event.fire("beforeImpression")
}
}
}
});
shared.bind({
event: "beforeHarvest",
listener: {
prepareHarvest: function() {
var rt = this.$root,
hp = rt.helpers,
st = rt.settings,
hd = null,
gsd = rt.comm.settings.responses.gsd;
hd = hp.getVar("highlight_deny") || gsd.wd.hd || {};
if (rt.what(window["vBulletin"]) != "undefined") {
if (!hd.cls) {
hd.cls = []
}
rt.utils.array.push(hd.cls, "thead", "tcat", "navbar", "tfoot", "alt2")
}
st.$extend({
highlightDeny: hd,
highlightAllow: hp.getVar("highlight_allow") || gsd.wd.ha
});
rt.updater.settings.className = rt.what(window["blogger"]) != "undefined" ? "hentry" : (hp.getVar("updater_class") || hp.getVar("refreshed_container"));
var harvested = rt.harvest.getHarvestedText();
rt.event.fire("beforeImpression", {
ptxt: harvested.text
})
}
}
});
shared.bind({
event: "beforeImpression",
listener: {
prepareImpression: function(event) {
var rt = this.$root,
ut = rt.utils,
hp = rt.helpers,
st = rt.settings,
prs, prods = rt.products,
cm = rt.comm,
gsd = cm.settings.responses.gsd,
tgst = prods.intag.settings,
crt = document.getElementsByName(tgst.relatedTags).length || "",
ctc = document.getElementsByName(tgst.prodId).length || "";
if (!st.impression) {
st.impression = {
params: {}
}
}
var imp = st.impression;
var impp = imp.params;
prs = ut.array.toObject(gsd.prs.split(","), {}, true);
if (event.data && event.data.updater) {
prs = {
i: true
}
}
impp.ptxt = event.data && gsd.prs != "s" ? event.data.ptxt : "";
impp.twnum = hp.countWords(impp.ptxt);
if (prs["i"] && impp.twnum < gsd.wd.qmin) {
delete prs["i"]
}
if (prs["t"] && gsd.wd.rtm == "m" && !crt && !ctc) {
delete prs["t"]
}
if (rt.helpers.getVar("inframe_disable") === true) {
delete prs["f"]
}
if (prs["f"]) {
var gpmp = prods.inframe.buildImpPageMarginsParam();
if (gpmp) {
impp.ifs = gpmp
} else {
delete prs["f"]
}
}
impp.prs = ut.object.keys(prs).join(",");
if (impp.prs == "") {
impp.prs = ".";
impp.ptxt = ""
}
if (!event.data || !event.data.updater) {
impp.pid = st.customerId;
impp.wsid = st.websiteId;
impp.makey = gsd.makey;
impp.anow = hp.getVar("anow") || "";
impp.rid = gsd.rid || "";
impp.purl = st.customerUrl;
impp.jsv = rt.version;
impp.ms = gsd.ms || "";
impp.gid = gsd.wd.gid || "";
impp.rh = hp.getVar("require_highlight") || "";
impp.by = "u";
impp.crt = crt;
impp.ctc = ctc;
impp.cfv = cm.settings.flashVersion;
st.ifip = hp.getVar("ifip") || "";
st.blankURL = ["http://", st.hosts.resources, "/static/blank.html"].join("");
impp.ifip = st.ifip;
impp.pf = hp.getPlatform();
impp.ptitle = hp.normalizeText(document.title);
impp.ref = st.ref;
impp.refq = st.refq;
if (st.ose) {
impp.ose = st.ose
}
impp.csilv = hp.getSilverlightVersion();
if (impp.prs.match(/[^so,\.]/) != null) {
impp.plinks = hp.getTagTexts("a", "text", "plinks");
impp.pimgs = hp.getTagTexts("img", "alt", "pimgs");
impp.phdrs = hp.getTagTexts(ut.string.qw("h1 h2 h3 h4 h5 h6"), "text", "phdrs");
impp.pdesc = hp.getMetaContent("description", st.textLimits.merged.pdesc);
impp.page_keyw = hp.getMetaContent("keywords", st.textLimits.merged.page_keyw)
}
imp.pcode = (hp.getVar("encoding") || document.characterSet || document.charset || "").toLowerCase();
imp.url = ["http://", gsd.rs, "/action/doq.htm", "?pcode=", imp.pcode, "&r=", ut.date.now(), ut.number.next("nocache")].join("");
if (rt.browser.IE && cm.settings.mode == "cors") {
imp.url += "&oct=1"
}
imp.method = "POST";
imp.onSuccess = "afterImpression"
}
ut.object.extend(impp, gsd.cks || {});
impp.rts = ut.date.now();
imp.params = ut.object.clean(impp);
cm.sendRequest(imp, function(sendBy) {
imp.params.by = sendBy;
if (!ut.timer.poll("tmr_imp")) {
ut.timer.start("tmr_imp")
}
})
}
}
});
shared.bind({
event: "afterImpression",
listener: {
handleImpressionResponse: function(event) {
var rt = this.$root,
utt = rt.utils.timer,
response, prs;
if (!utt.delta("tmr_imp")) {
utt.stop("tmr_imp")
}
response = rt.helpers.processImpressionResponse(event.data);
if (rt.what(response) != "object") {
rt.logger.error("Bad Impression response.", true);
return
}
prs = response.prs;
if (prs.r) {
if (prs.t) {
prs.t.sentences = rt.utils.array.uniq(rt.utils.array.concat(prs.t.sentences, prs.r.sentences));
rt.utils.object.extend(prs.t.behavior, prs.r.behavior)
} else {
prs.t = prs.r;
delete prs.r
}
}
rt.comm.settings.responses.impression = response;
rt.externalTags.init();
rt.event.fire("preRenderProducts")
}
}
});
shared.bind({
event: "preRenderProducts",
listener: {
preRenderProducts: function() {
var rt = this.$root,
hp = rt.helpers,
st = rt.settings,
bh = st.behavior,
ut = rt.utils;
bh.customer = hp.getCustomerBehavior("link_color link_hover_color link_hover_bg_color ads_reuse_window bubble_direction bubble_logo_url bubble_logo_url_downgrade bubble_logo_width bubble_logo_height bubble_logo_link bubble_help_link");
bh.impression = hp.renameBehaviorProperties(rt.comm.settings.responses.impression.behavior_imp || {});
hp.createBaseClasses();
st.homeUrl = bh.customer.bubbleLogoLink || st.defaultHomeUrl;
st.helpUrl = rt.utils.VeST(bh.customer.bubbleHelpLink || bh.customer.bubbleLogoLink || st.defaultHelpUrl, {
cid: st.customerId,
wsid: st.websiteId
});
st.productRenderStatus = ut.array.toObject(ut.object.keys(st.productCodes), {}, "before");
this.$root.event.fire("renderProduct")
}
}
});
shared.bind({
event: "productRenderStatus",
listener: {
productRenderStatus: function(event) {
var rt = this.$root,
st = rt.settings,
ut = rt.utils,
ps = st.productRenderStatus,
data = event.data;
ps[data.prod] = data.status;
if (data.status == "failed") {
rt.logger.error([st.productCodes[data.prod], " failed. reason: ", data.reason].join(""), this.productRenderStatus)
}
if (!/before|during/.test(ut.object.values(ps).join(","))) {
this.$root.event.fire("afterRenderProducts")
}
}
}
});
shared.bind({
event: "afterRenderProducts",
listener: {
productsRendedred: function() {
var rt = this.$root,
st = rt.settings,
gsd = rt.comm.settings.responses.gsd,
i, len, cb, src = st.hosts.src ? "/src" : "";
if (/i|r|t/.test(gsd.prs)) {
rt.helpers.mapUnhoverableAreas()
}
if (rt.what(gsd.incs) != "undefined") {
for (i = 0, len = gsd.incs.length; i < len; ++i) {
var func = function(name, params) {
return function() {
if (rt.plugins[name] && rt.what(rt.plugins[name].init) == "function") {
rt.plugins[name].init(params)
}
}
};
cb = func(gsd.incs[i].s, gsd.incs[i].p);
rt.comm.loadScript([st.hosts.resources, "/js", src, "/0/plugins/", gsd.incs[i].s, ".js"].join(""), null, cb)
}
}
if (rt.updater.settings.className) {
rt.event.fire("initUpdater")
}
rt.utils.timer.stop("tmr_all");
rt.event.fire("sendImpressionLog")
}
}
});
shared.bind({
event: "sendImpressionLog",
listener: {
sendImpressionLog: function() {
var rt = this.$root,
st = rt.settings,
ut = rt.utils,
uta = ut.array,
tmr = ut.timer,
res = rt.comm.settings.responses,
gsd = res.gsd;
st.sendClientLog = rt.helpers.getVar("send_client_log") || gsd.scl || false;
if (!st.sendClientLog) {
return
}
var prods = rt.products,
ist = prods.intext.settings,
tst = prods.intag.settings,
sentence, i, leni, hook, intxt_sen = [];
var params = {
rid: gsd.rid,
makey: gsd.makey,
tmr_scr: st.boot && st.boot.tmr_scr ? ut.date.now() - st.boot.tmr_scr : -1,
tmr_wait: tmr.delta("tmr_wait") || -1,
tmr_gsd: tmr.delta("tmr_gsd") || -1,
tmr_har: tmr.delta("tmr_har") || -1,
tmr_imp: tmr.delta("tmr_imp") || -1,
tmr_dwq: tmr.delta("tmr_imp") || -1,
tmr_hi: tmr.delta("tmr_hi") || -1,
tmr_fsh: tmr.delta("tmr_fsh") || -1,
tmr_all: tmr.delta("tmr_all") || -1
};
if (gsd.prs.indexOf(ist.prodCode) != -1) {
params.intxt_num = [ist.rendered, ut.object.keys(ist.sentences).length].join("*");
for (sentence in ist.sentences) {
for (i = 0, leni = ist.sentences[sentence].hooks.length; i < leni; i++) {
hook = ist.sentences[sentence].hooks[i];
uta.push(intxt_sen, [sentence, hook.visible ? 1 : 0, hook.pos.left, hook.pos.top].join("_"))
}
}
params.intxt_sen = intxt_sen.join("*")
}
if (gsd.prs.indexOf(tst.prodCode) != -1) {
var tCldSent = (res.impression.prs[tst.prodCode] || {
sentences: []
}).sentences.length;
params.tCld_num = [uta.sum(uta.map(tst.instances, function(instance) {
return instance.hooksCount
})), tCldSent].join("*");
if (tst.instances.length) {
params.tCld_pos = [tst.instances[0].pos.left, tst.instances[0].pos.top].join("*")
}
}
rt.comm.loadScript(gsd.rs + "/action/dcil.htm", params)
}
}
});
$root.event.dom.bind(document, {
event: "keyup",
listener: {
keyboardShortcuts: function(event) {
var evt = event.domEvent,
rt = event.$root,
logger = rt.logger;
if (evt.keyCode == 76 && evt.ctrlKey && evt.altKey) {
logger.output = logger.output == "console" ? "none" : "console";
if (rt.what(window.console) != "undefined") {
console.info("Logging to console turned " + (logger.output == "console" ? "on." : "off."))
}
} else {
if (evt.keyCode == 67 && evt.ctrlKey && evt.altKey) {
if (rt.what(window.console) != "undefined") {
console.clear()
}
}
}
}
}
});
var products = $root.$create("products", {}, null, true);
var intext = products.$create("intext", {
createCandidate: function(node, parentNode, sentence) {
var rt = this.$root,
ut = rt.utils,
dm = ut.dom,
o = {};
o.sentence = sentence;
o.node = node;
o.parentNode = parentNode;
o.rendered = false;
o.type = "intext";
o.prod = "i";
o.bubble = ut.object.clone(rt.bubble.settings.base);
o.fontSize = (node.nodeType == 1 ? parseInt(dm.element.getStyle(node, "lineHeight"), 10) : parseInt(dm.element.getStyle(parentNode, "fontSize"), 10)) || 0;
o.visible = dm.element.isVisible(parentNode);
o.onViewPort = dm.element.isOnViewport(parentNode);
o.wordCount = (parentNode.innerText || parentNode.textContent).replace(/\s+/g, " ").length;
o.importance = parentNode.offsetWidth / dm.viewport.getWidth();
return o
},
estimateCandidatesFontSizeIE: function(candidates) {
var rt = this.$root,
b = rt.browser,
c;
if (!b.IE || b.getVersion(true) >= 9) {
return
}
for (var i = 0, leni = candidates.length; i < leni; i++) {
c = candidates[i];
c.fontSize = c.node.firstChild.offsetHeight || 0
}
},
scoreFactorsCalc: {
fontSize: function(v) {
return !v || v > 16 || v < 10 ? 0 : 1
},
wordCount: function(v) {
return v < 10 ? 0 : v < 20 ? 0.3 : v < 30 ? 0.6 : 1
},
importance: function(v) {
return v > 0.4 ? 1 : v > 0.2 ? 0.5 : v
}
},
scoreCandidates: function(candidates) {
var sf = this.settings.scoreFactors,
calc = this.scoreFactorsCalc,
c, i, leni;
for (i = 0, leni = candidates.length; i < leni; i++) {
c = candidates[i];
c.score = calc.fontSize(c.fontSize) * sf.fontSize + (c.visible ? 1 : 0) * sf.visible + (c.onViewPort ? 1 : 0) * sf.onViewPort + calc.wordCount(c.wordCount) * sf.wordCount + calc.importance(c.importance) * sf.importance
}
},
createStyleSheet: function() {
var rt = this.$root,
ist = this.settings,
bh = ist.behavior.merged,
b = rt.browser,
dm = rt.utils.dom,
dmst = dm.style;
var cs = dm.element.getStyle(document.body);
if (cs && cs.position == "relative" && cs.width && parseInt(cs.width, 10) < dm.document.getWidth()) {
document.body.style.position = "static"
}
var underline = dmst.buildHookUnderlineCSS(bh.underline, bh.linkColor, true);
dmst.addRule("." + ist.hookClass, [underline, "color:", bh.linkColor, " !important; background:transparent none repeat scroll 0% !important;cursor:pointer !important;position:static;display:inline !important;padding:0 0 1px 0 !important;float:none !important;"].join(""));
if (bh.linkHoverColor) {
dmst.addRule("." + ist.hookClass + "_HOVER", ["color:", bh.linkHoverColor, " !important;border-bottom-color:", bh.linkHoverColor, " !important;"].join(""))
}
if (bh.simanitIcon) {
if (b.IE && b.getVersion(true) <= 7) {
dmst.addRule("." + ist.hookClass + "_ICON", ["display:inline-block !important; position:static !important;cursor:pointer !important;margin:0 !important;padding:0 !important;background:transparent url(", bh.simanitIcon, ") no-repeat scroll ", bh.simanitPosition, " center; width:", bh.simanitWidth, "px !important;float:none !important;"].join(""))
} else {
dmst.addRule("." + ist.hookClass + "_ICON", ["display:inline !important;position:static !important;cursor:pointer !important;margin:0 !important;padding:0 !important;background:transparent url(", bh.simanitIcon, ") no-repeat scroll ", bh.simanitPosition, " center;padding-", bh.simanitPosition, ":", bh.simanitWidth, "px !important; float:none !important;", b.IE ? "height:1%;" : ""].join(""))
}
if (bh.simanitOver) {
dmst.addRule("." + ist.hookClass + "_ICON_OVER", ["background-image:url(", bh.simanitOver, ");"].join(""))
}
}
},
createHook: function(hook, textNode, updater) {
var rt = this.$root,
ist = this.settings,
st = rt.settings,
bh = ist.behavior.merged,
b = rt.browser,
node;
node = hook.node = document.createElement("span");
hook.id = ++st.hooksCount;
ist.hooksCount++;
node.id = ist.hookClass + hook.id;
if (updater) {
hook.updater = updater
}
st.hooksMap[hook.id] = hook;
node.className = ist.hookClass;
var text = textNode.data || textNode.innerHTML.replace(/<\/?span>/ig, "");
if (bh.simanitIcon) {
var simanitTag = ['<span class="', ist.hookClass, '_ICON"></span>'].join("");
node.innerHTML = bh.simanitPosition == "left" ? simanitTag + text : text + simanitTag
} else {
node.innerHTML = text
}
var ps = rt.utils.dom.element.getStyle(hook.parentNode),
css = [],
push = rt.utils.array.push;
if (ps["fontFamily"]) {
push(css, "font-family:", ps["fontFamily"], " !important;")
}
if (ps["fontWeight"]) {
push(css, "font-weight:", ps["fontWeight"], " !important;")
}
if (ps["fontStyle"]) {
push(css, "font-style:", ps["fontStyle"], " !important;")
}
if ((!b.IE || (b.getVersion(true) > 8)) && !b.Opera && ps["fontSize"] && ps["fontSize"].match(/px$/) != null) {
push(css, "font-size:", ps["fontSize"], " !important;")
}
if (textNode.nodeType == 1 || b.IE) {
push(css, this.fixIEAdNodeStyle(textNode))
}
rt.utils.dom.style.addRule("#" + node.id, css.join(""));
hook.currentAdIndex = 0;
rt.helpers.bindHookEvents(hook);
return node
},
fixIEAdNodeStyle: function(node) {
var rt = this.$root,
bh = this.settings.behavior.merged,
b = rt.browser,
ut = rt.utils,
dmel = ut.dom.element,
push = ut.array.push,
css = [];
if (node.nodeType != 1) {
node = node.parentNode
}
if (b.getVersion() >= 7 && bh.underline == "double") {
push(css, "border:1px solid transparent; border-bottom:1px solid ", bh.linkColor, ";")
}
if (bh.underline != "single" && bh.underline != "none") {
push(css, "padding-bottom:2px;")
}
var parent = node.offsetParent,
nodePos = dmel.offset(node);
if (parent && parent.tagName.toLowerCase().match(/^(?:li|td)$/) != null) {
if (nodePos.top + node.offsetHeight >= dmel.offset(parent).top + parent.offsetHeight) {
dmel.setStyle(parent, {
paddingBottom: "3px"
})
}
}
if (nodePos.top + node.offsetHeight > document.body.clientHeight) {
dmel.setStyle(document.body, {
paddingBottom: "3px"
})
}
parent = node.parentNode;
if (bh.underline == "double" && dmel.getStyle(parent, "styleFloat") && parseInt(dmel.getStyle(parent, "paddingBottom")) < 2 && parent.offsetHeight < 18) {
dmel.setStyle(parent, {
paddingBottom: "2px"
})
}
return css.join("")
},
revertCandidateNodesIE: function(updater) {
var rt = this.$root,
candidates, sentence, i, leni, textNode, node, parentNode;
var sentenceObjects;
if (!rt.browser.IE) {
return
}
if (updater) {
sentenceObjects = updater.impression.sentences
} else {
sentenceObjects = rt.comm.settings.responses.impression.sentences
}
for (sentence in sentenceObjects) {
candidates = sentenceObjects[sentence].candidates;
if (!candidates) {
continue
}
for (i = 0, leni = candidates.length; i < leni; i++) {
node = candidates[i].node;
textNode = document.createTextNode(node.innerText);
parentNode = node.parentNode;
parentNode.insertBefore(textNode, node);
parentNode.removeChild(node);
candidates[i].node = textNode
}
}
}
}, {
settings: {
prodCode: "i",
prodName: "intext",
behavior: {
def: {
skin: "brand",
theme: "def",
highlightCount: 1,
underline: "double",
favicon: false,
simanitIcon: null,
simanitOver: null,
simanitWidth: 16,
simanitPosition: "right"
},
sanitizer: {
highlightCount: "int",
underline: ["double", "single", "dotted", "dashed", "none"],
favicon: "bool",
simanitIcon: "str",
simanitOver: "str",
simanitWidth: "int",
simanitPosition: ["right", "left"]
}
},
themes: {
color: {
def: "#003366",
lightBlue: "#1b8ede",
green: "#67b045",
orange: "#f3933b",
red: "#dd3c42",
pink: "#d84189",
purple: "#5939aa"
}
},
hookClass: "IL_AD",
hooksCount: 0,
maxCandidates: 50,
scoreFactors: {
fontSize: 10,
visible: 10,
onViewPort: 50,
wordCount: 30,
importance: 0
},
rendered: 0
}
}, true);
intext.bind({
event: "renderProduct",
listener: {
renderIntext: function() {
var rt = this.$root,
prod = "i";
if (!rt.comm.settings.responses.impression.prs[prod]) {
rt.event.fire("productRenderStatus", {
prod: prod,
status: "none"
});
return
}
rt.event.fire("productRenderStatus", {
prod: prod,
status: "during"
});
rt.utils.timer.start("tmr_hi");
rt.event.fire("initIntext")
}
}
});
intext.bind({
event: "initIntext",
listener: {
init: function(event) {
var rt = this.$root,
st = rt.settings,
bh = st.behavior,
bhi = this.settings.behavior,
prod = "i",
imp = rt.comm.settings.responses.impression,
prodImp = imp.prs[prod],
uto = rt.utils.object;
function convertDoubleUnderline() {
for (var i = 0; i < arguments.length; i++) {
if (rt.what(arguments[i].underline) == "undefined" && rt.what(arguments[i].doubleUnderline) != "undefined") {
arguments[i].underline = arguments[i].doubleUnderline.toString() == "false" ? "dotted" : "double"
}
}
}
bhi.customer = rt.helpers.getCustomerBehavior("link_color highlight_count underline simanit_icon simanit_over simanit_width simanit_position");
bhi.impression = rt.helpers.renameBehaviorProperties(prodImp.behavior || {});
convertDoubleUnderline(bh.impression, bhi.impression, bhi.customer);
bhi.merged = rt.utils.object.extend({}, bh.def, bhi.def, bh.impression, bhi.impression, bh.customer, bhi.customer);
rt.helpers.sanitize(bhi.merged, uto.extend({}, bh.sanitizer, bhi.sanitizer));
if (!rt.bubble.initialized) {
rt.event.fire("initBubble", this.settings.prodName)
}
rt.event.fire("setIntextMarkers", event.data)
}
}
});
intext.bind({
event: "setIntextMarkers",
listener: {
setCandidates: function(event) {
var rt = this.$root,
hs = rt.harvest.settings,
ist = this.settings,
updater = event.data && event.data.updater ? event.data.updater : null,
nodes, context, sentencesKeys, sentenceIndexes, sentences, sentenceObjects, sentence, normalizedSentence, re, k, lenk, i, leni, node, text, sentenceObj, match, newNode, parentNode, harvested = hs.instances[hs.instances.length - 1],
matchText, textNode, candidateNode, hadMatches, textFollowingMatch, allCandidates = [];
if (updater) {
context = updater;
sentenceObjects = context.sentences = {}
} else {
context = rt.comm.settings.responses;
sentenceObjects = ist.sentences = {}
}
nodes = harvested.nodes;
sentences = context.impression.sentences;
sentenceIndexes = context.impression.prs.i.sentences || [];
sentencesKeys = rt.utils.object.keys(sentences);
for (k = 0, lenk = sentenceIndexes.length; k < lenk; k++) {
sentence = sentencesKeys[sentenceIndexes[k]];
normalizedSentence = sentence.replace(/([\+\.\?\(\)\[\]\*])/g, "\\$1").replace(/(\w+)/g, "\\b$1\\b").replace(/\s+/g, "\\s+");
re = new RegExp(normalizedSentence, "i");
sentenceObj = sentenceObjects[sentence] = {
candidates: [],
hooks: [],
rendered: 0
};
for (i = 0, leni = nodes.length; i < leni; i++) {
if (sentenceObj.candidates.length >= ist.maxCandidates) {
break
}
node = nodes[i];
if (!node.parentNode || rt.what(node.data) == "undefined" || rt.utils.array.indexOf(allCandidates, node) != -1) {
continue
}
text = node.data;
match = re.exec(text);
if (!match || node.parentNode.className == ist.hookClass) {
continue
}
textFollowingMatch = text.substr(match.index + match[0].length);
if (textFollowingMatch.match(/^[\u2019']s/) != null) {
continue
}
hadMatches = false;
newNode = document.createDocumentFragment();
parentNode = node.parentNode;
nodes.splice(i, 1);
while (match && sentenceObj.candidates.length < ist.maxCandidates) {
matchText = match[0];
if ((match.index == 0 || text.charAt(match.index - 1).match(/\w/) == null) && (text.length <= match.index + matchText.length || text.charAt(match.index + matchText.length).match(/\w/) == null)) {
hadMatches = true;
if (match.index > 0) {
textNode = document.createTextNode(text.substr(0, match.index));
newNode.appendChild(textNode);
nodes.splice(i++, 0, textNode)
}
if (rt.browser.IE && rt.browser.getVersion(true) < 9) {
candidateNode = document.createElement("span");
candidateNode.innerHTML = ["<span>", matchText.charAt(0), "</span>", matchText.substring(1)].join("")
} else {
candidateNode = document.createTextNode(matchText)
}
rt.utils.array.push(allCandidates, candidateNode);
candidateNode = newNode.appendChild(candidateNode);
rt.utils.array.push(sentenceObj.candidates, this.createCandidate(candidateNode, parentNode, sentence))
}
text = text.substr(match.index + matchText.length);
match = re.exec(text)
}
if (!hadMatches) {
continue
}
if (text != "") {
textNode = document.createTextNode(text);
newNode.appendChild(textNode);
nodes.splice(i, 0, textNode)
}
parentNode.insertBefore(newNode, node);
parentNode.removeChild(node);
node.data = "";
leni = nodes.length
}
this.estimateCandidatesFontSizeIE(sentenceObj.candidates);
this.scoreCandidates(sentenceObj.candidates);
rt.utils.array.insertionSort(sentenceObj.candidates, "score", false);
for (i = ist.behavior.merged.highlightCount, leni = sentenceObj.candidates.length; i < leni; i++) {
rt.utils.array.push(nodes, sentenceObj.candidates[i].node)
}
}
rt.event.fire("createIntextHooks", {
updater: updater
})
}
}
});
intext.bind({
event: "createIntextHooks",
listener: {
createIntextHooks: function(event) {
var rt = this.$root,
ist = this.settings,
bh = ist.behavior.merged,
updater = event.data && event.data.updater ? event.data.updater : null,
context, sentences, sentenceIndexes, sentencesKeys, sentenceObjects, sentence, sentenceObj, candidate, textNode, parentNode, hook, k, lenk;
if (updater) {
context = updater;
sentenceObjects = context.sentences
} else {
context = rt.comm.settings.responses;
sentenceObjects = ist.sentences;
this.createStyleSheet()
}
sentences = context.impression.sentences;
sentenceIndexes = context.impression.prs.i.sentences;
sentencesKeys = rt.utils.object.keys(sentences);
for (k = 0, lenk = sentenceIndexes.length; k < lenk; k++) {
sentence = sentencesKeys[sentenceIndexes[k]];
sentenceObj = sentenceObjects[sentence];
while (sentenceObj.candidates.length && sentenceObj.rendered < bh.highlightCount) {
candidate = sentenceObj.candidates[0];
textNode = candidate.node;
parentNode = textNode.parentNode || candidate.parentNode;
if (!parentNode) {
continue
}
hook = this.createHook(candidate, textNode, updater);
parentNode.insertBefore(hook, textNode);
parentNode.removeChild(textNode);
candidate.rendered = true;
sentenceObj.rendered++;
if (sentenceObj.hooks.length == 0 && !updater) {
ist.rendered++
}
rt.utils.array.push(sentenceObj.hooks, sentenceObj.candidates.shift());
candidate.pos = rt.utils.dom.element.offset(hook)
}
}
this.revertCandidateNodesIE(updater);
rt.utils.timer.stop("tmr_hi");
if (!updater) {
rt.event.fire("productRenderStatus", {
prod: "i",
status: "after"
})
}
}
}
});
intext.bind({
event: "intextHookMouseover",
listener: {
intextHookMouseover: function(event) {
var rt = this.$root,
st = rt.settings,
bh = this.settings.behavior.merged,
hook = st.hooksMap[event.data.hookId];
if (st.clickStatus != "none") {
return
}
var cls = this.settings.hookClass;
if (bh.linkHoverColor) {
hook.node.className = [cls, " ", cls, "_HOVER"].join("")
}
if (bh.simanitIcon && bh.simanitOver) {
var iconSpan = hook.node.getElementsByTagName("span");
if (iconSpan.length) {
iconSpan[0].className = [cls, "_ICON ", cls, "_ICON_OVER"].join("")
}
}
}
}
});
intext.bind({
event: "intextHookMouseout",
listener: {
hookMouseout: function(event) {
var rt = this.$root,
st = rt.settings,
ist = this.settings,
bh = ist.behavior.merged,
hook = st.hooksMap[event.data.hookId],
cls = this.settings.hookClass;
if (bh.linkHoverColor) {
hook.node.className = cls
}
if (bh.simanitIcon && bh.simanitOver) {
var iconSpan = hook.node.getElementsByTagName("span");
if (iconSpan.length) {
iconSpan[0].className = cls + "_ICON "
}
}
}
}
});
var autoPlacement = $root.$create("autoPlacement", {
createMarker: function(prodId, val) {
var rt = this.$root,
apst = this.settings,
dmel = rt.utils.dom.element,
resNodeHeight, node, result;
if (rt.what(prodId) == "array") {
prodId = prodId[0]
}
node = rt.utils.dom.createDOMFragment({
tag: "input",
type: "hidden",
attributes: {
name: prodId,
value: val
}
});
if (apst.result) {
result = apst.result
} else {
apst.result = result = this.findPlacement()
}
if (result.placement != "before" && (resNodeHeight = dmel.getStyle(result.node, "height"))) {
if (resNodeHeight.indexOf("px") != -1) {
dmel.setStyle(result.node, {
minHeight: parseInt(resNodeHeight, 10) + 45 + "px"
})
}
}
if (result.placement == "append") {
result.node.appendChild(node)
} else {
if (result.placement == "prepend") {
result.node.insertBefore(node, result.node.firstChild)
} else {
result.node.parentNode.insertBefore(node, result.node)
}
}
return [node]
},
findPlacement: function() {
var rt = this.$root,
ut = rt.utils,
dmel = ut.dom.element,
el, i, leni;
var ids = ut.string.qw("pageContent content_body contentBody contentWrapper main_content_section main-content bodyarea content-wrap Blog1 content");
var commentsId = ut.string.qw("commentlist comments respond commentpost commentform disqus_thread idc-container-parent");
for (i = 0, leni = commentsId.length; i < leni; i++) {
if (el = dmel.$(commentsId[i])) {
if (dmel.isVisible(el)) {
return {
node: el,
placement: (/respond|commentform|disqus_thread/.test(commentsId[i])) ? "before" : "prepend"
}
}
}
}
for (i = 0, leni = ids.length; i < leni; i++) {
if (el = dmel.$(ids[i])) {
if (dmel.isVisible(el)) {
return {
node: el,
placement: "append"
}
}
}
}
return {
node: this.findBestContainer(),
placement: "append"
}
},
findBestContainer: function() {
var rt = this.$root,
hs = this.settings,
ut = rt.utils,
i, leni, candidate, winner = null,
maxScore = -1000,
score, node, dm = ut.dom,
dmel = dm.element,
docHeight, docWidth, iceapw;
var forbiddenTags = ut.array.toObject(ut.string.qw("body tbody table tr ul dl ol p span embed marquee"), {}, 1);
var wrapper = dm.findWidestNode();
if (wrapper.node == document.body) {
docWidth = dm.document.getWidth();
docHeight = dm.document.getHeight()
} else {
docWidth = wrapper.width;
docHeight = wrapper.height
}
this.harvest(document.body);
for (i = 0, leni = hs.candidates.length; i < leni; i++) {
candidate = hs.candidates[i];
node = candidate.node;
if (forbiddenTags[node.tagName.toLowerCase()]) {
continue
}
candidate.wordsCount = parseInt(dmel.getData(node, "iceapw"), 10) || 0;
candidate.childrenCount = parseInt(dmel.getData(node, "iceapc"), 10) || 0;
if (!candidate.wordsCount || !candidate.childrenCount) {
continue
}
score = candidate.score = (candidate.width / (docWidth || 1) + candidate.height / (docHeight || 1)) / 4 + candidate.wordsCount / (hs.totalWordsCount || 1) - candidate.childrenCount / (hs.totalValidNodes || 1);
if (rt.what(score) == "number" && score > maxScore) {
maxScore = score;
winner = candidate
}
}
if (winner) {
for (i = 0, leni = hs.candidates.length; i < leni; i++) {
candidate = hs.candidates[i];
if (candidate.wordsCount == winner.wordsCount && candidate.node != winner.node && dmel.inHierarchy(candidate.node, winner.node)) {
winner = candidate
}
}
}
hs.winner = winner;
return winner ? winner.node : document.body
},
harvest: function(node) {
var rt = this.$root,
hs = this.settings,
nodeType, ut = rt.utils,
dmel = ut.dom.element,
tm = ut.timer,
nt = rt.settings.nodeTypes,
i, leni, wordsCount, text, parent, iceapw, iceapc;
if (!hs.harvesting) {
hs.harvesting = true;
hs.stopped = false;
tm.start("apHarvest");
hs.candidates = [];
hs.firstNode = node;
hs.enabled = true;
hs.timeLimit = 1000;
hs.totalWordsCount = 0;
hs.totalValidNodes = 0
}
if (hs.stopped || hs.timeLimit != -1 && tm.poll("apHarvest") >= hs.timeLimit) {
hs.stopped = true
} else {
nodeType = node.nodeType
}
switch (nodeType) {
case nt.DOCUMENT:
case nt.ELEMENT:
if (node.className.indexOf(rt.settings.baseClass) == -1 && node.className.indexOf(rt.products.intext.settings.hookClass) == -1 && dmel.isVisible(node) && rt.harvest.isHarvestableNode(node)) {
for (i = 0, leni = node.childNodes.length; i < leni; i++) {
if (hs.stopped) {
break
}
this.harvest(node.childNodes[i])
}
hs.totalValidNodes++;
parent = node.parentNode;
while (parent && parent != document && parent.tagName.toLowerCase() != "html") {
iceapc = (parseInt(dmel.getData(parent, "iceapc"), 10) || 0) + 1;
dmel.setData(parent, "iceapc", iceapc);
parent = parent.parentNode
}
ut.array.push(hs.candidates, {
node: node,
parent: node.parentNode,
width: dmel.getActualWidth(node),
height: dmel.getActualHeight(node)
})
}
break;
case nt.TEXT:
if (hs.enabled) {
text = ut.string.trim(node.data).replace(/\s+/g, " ");
if (text.match(/\S/)) {
wordsCount = text.split(/\s+/).length;
hs.totalWordsCount += wordsCount;
parent = node.parentNode;
while (parent && parent != document && parent.tagName.toLowerCase() != "html") {
iceapw = (parseInt(dmel.getData(parent, "iceapw"), 10) || 0) + wordsCount;
dmel.setData(parent, "iceapw", iceapw);
parent = parent.parentNode
}
}
}
break;
case nt.COMMENT:
rt.harvest.checkConditionalTags(ut.string.trim(node.data), hs)
}
if (hs.firstNode == node) {
hs.harvesting = false;
tm.stop("apHarvest")
}
}
}, {
settings: {}
}, false);
var intag = products.$create("intag", {
locateMarkers: function(prodId, lines) {
var rt = this.$root,
b = rt.browser,
i, leni, markers, autoMarker = [];
if (rt.what(prodId) != "array") {
prodId = [prodId]
}
for (i = 0, leni = prodId.length; i < leni; i++) {
markers = document.getElementsByName(prodId[i]);
if (markers.length) {
break
}
}
if ((rt.comm.settings.responses.gsd.wd.rtm == "b" || !markers.length) && (!b.IE || b.getVersion(true) > 6)) {
autoMarker = rt.autoPlacement.createMarker(prodId, lines);
if (autoMarker.length) {
this.settings.autoPlacement = true
}
}
return rt.utils.array.concat([], markers, autoMarker)
},
renderUnit: function(instanceIndex) {
var rt = this.$root,
st = rt.settings,
stit = this.settings,
instance = stit.instances[instanceIndex],
i, leni, html = "";
for (i = 0, leni = instance.lines; i < leni; i++) {
html += this.renderUnitLine(instanceIndex, i, i == leni - 1)
}
return rt.utils.dom.createDOMFragment({
tag: "div",
parent: instance.container,
after: instance.marker,
cls: st.baseClass,
style: {
margin: "0 auto",
padding: "10px 0",
width: instance.width + "px"
},
innerHTML: html
})
},
renderUnitLine: function(instanceIndex, line, withLogo) {
var rt = this.$root,
st = rt.settings,
stit = this.settings,
b = rt.browser,
instance = stit.instances[instanceIndex],
bh = stit.behavior.merged,
skinPath = this.getSkinPath();
var tpl = '<% if (withLogo){ %><div id="<%= prodId %>_LOGO_<%= instanceIndex %>" class="<%= baseCls %>" style="float:right; margin-right:15px; margin-top:8px; width:53px; height:12px; cursor:pointer; font-size:1px; <% if (oldIE || oldFF){ %>background:url(<%= skinPath %>logo<%= bh.darkBg ? \'-gray\' : \'\' %>.png) no-repeat scroll 0 0 transparent;<% } %>"> <% if (!(oldIE || oldFF)){ %> <svg version="1.1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" x="0px" y="0px" width="53px" height="12px" viewBox="0 0 636 144" enable-background="new 0 0 636 144" xml:space="preserve"> <g> <%-- dot (first) --%> <path id="<%= prodId %>_LOGO_<%= instanceIndex %>_DOT1" fill="<%= bh.theme == \'def\' ? \'#208CE5\' : themeColor %>" d="M16.918,24.865c5.848,0,10.57-4.735,10.57-10.583s-4.722-10.57-10.57-10.57 S6.334,8.434,6.334,14.282S11.07,24.865,16.918,24.865"/> <%-- in --%> <path fill="<%= logoColor %>" d="M88.085,43.784H77.024c-17.149,0-31.181,14.031-31.181,31.182v34.796 c0,0.218,0.016,0.415,0.027,0.618v5.185c0,5.71-4.672,10.382-10.382,10.382h-0.467c-5.71,0-10.382-4.672-10.382-10.382V92.608 h0.015V45.889v-0.025c0-1.124-0.885-2.033-2.01-2.08h-11.49c-1.09,0.047-1.949,0.907-1.986,1.996v46.828h0.04 c-0.015,0.355-0.04,0.707-0.04,1.066v22.246c0,14.031,11.479,25.512,25.511,25.512h1.151c14.031,0,25.511-11.48,25.511-25.512 v-5.466v-4.62v-28.89c0.082-9.872,8.159-17.948,18.031-17.948h6.366c9.871,0,17.948,8.076,18.042,17.948v28.89v4.62v28.873 c0.013,0.023,0.013,0.034,0.013,0.048c0,1.111,0.883,2.008,1.983,2.057h11.505c1.077-0.036,1.936-0.887,1.985-1.973v-27.966v-5.659 V74.966C119.267,57.815,105.234,43.784,88.085,43.784"/> <%-- f (part) --%> <path fill="<%= logoColor %>" d="M155.069,56.972v82.643c-0.072,0.992-0.886,1.78-1.903,1.818h-11.014 c-1.062-0.038-1.912-0.897-1.912-1.962c0-0.024,0-0.048-0.023-0.073V34.456c0.716-17.064,14.923-30.744,32.179-30.744h8.536 c0.025,0,0.038,0.011,0.06,0.011c1.053,0,1.915,0.849,1.974,1.901v11.037c-0.035,1.016-0.85,1.844-1.878,1.889h-8.692 c-9.509,0-17.327,7.75-17.327,17.268v6.301V56.972z"/> <%-- f (part) --%> <path fill="<%= logoColor %>" d="M151.99,59.104h28.873c0.023-0.012,0.034-0.012,0.047-0.012 c1.111,0,2.008-0.884,2.057-1.984V45.604c-0.036-1.078-0.887-1.938-1.973-1.986h-27.965"/> <%-- o --%> <path fill="<%= logoColor %>" d="M276.24,107.925h0.158V76.608c-0.37-18.164-15.248-32.825-33.494-32.825 h-16.756v0.022c-17.875,0.431-32.322,14.924-32.679,32.803h-0.026v31.316c0,18.213,14.601,33.064,32.705,33.496v0.012h16.589h0.021 h0.146C261.304,141.349,276.24,126.354,276.24,107.925 M208.93,107.925L208.93,107.925V77.289c0-9.914,8.096-18.02,18.021-18.02 h15.953c9.946,0,18.02,8.106,18.02,18.02v30.636h-0.167c0,9.949-8.074,18.021-17.999,18.021h-15.807 C217.026,125.946,208.93,117.874,208.93,107.925"/> <%-- l --%> <path fill="<%= logoColor %>" d="M312.844,139.376L312.844,139.376c0,1.064-0.798,1.938-1.829,2.045h-11.816 c-1.027-0.107-1.837-0.98-1.837-2.045h-0.013V5.769h0.013c0-1.135,0.908-2.033,2.031-2.057h11.432 c1.124,0.024,2.019,0.922,2.019,2.057V139.376z"/> <%-- dot (second) --%> <path id="<%= prodId %>_LOGO_<%= instanceIndex %>_DOT2" fill="<%= bh.theme == \'def\' ? \'#208CE5\' : themeColor %>" d="M341.662,24.865c5.848,0,10.57-4.735,10.57-10.583s-4.723-10.57-10.57-10.57 s-10.584,4.722-10.584,10.57S335.814,24.865,341.662,24.865"/> <%-- in (second) --%> <path fill="<%= logoColor %>" d="M412.829,43.784h-11.061c-17.149,0-31.181,14.031-31.181,31.182v34.796 c0,0.218,0.016,0.415,0.026,0.618v5.185c0,5.71-4.672,10.382-10.382,10.382h-0.468c-5.71,0-10.382-4.672-10.382-10.382V92.608 h0.016V45.723v-0.025c0-1.123-0.885-2.033-2.01-2.08h-11.49c-1.091,0.047-1.949,0.908-1.986,1.996v46.994h0.04 c-0.015,0.355-0.04,0.707-0.04,1.066v22.246c0,14.031,11.479,25.512,25.512,25.512h1.15c14.031,0,25.512-11.48,25.512-25.512 v-5.466v-4.62v-28.89c0.082-9.872,8.158-17.948,18.029-17.948h6.367c9.871,0,17.947,8.076,18.041,17.948v28.89v4.62v28.873 c0.014,0.023,0.014,0.034,0.014,0.048c0,1.111,0.883,2.008,1.982,2.057h11.506c1.076-0.036,1.936-0.887,1.984-1.973v-27.966v-5.659 V74.966C444.01,57.815,429.979,43.784,412.829,43.784"/> <%-- k --%> <path fill="<%= logoColor %>" d="M480.277,139.376L480.277,139.376V91.735h0.146h9.255l40.656,48.766 c0.599,0.549,1.15,0.906,1.841,0.932h16.073c0.882-0.025,2.869-0.322,1.794-2.056l-0.013-0.024l-47.58-56.777l44.599-36.815 c0.015-0.049,0.015-0.049,0.036-0.073c1.066-1.734-0.886-2.032-1.78-2.069H527.08c-0.621,0.024-1.15,0.324-1.666,0.791 l-36.812,31.075h-8.325V5.769c0-1.135-0.896-2.033-2.02-2.057h-11.422c-1.124,0.024-2.033,0.922-2.033,2.057v133.607 c0,1.064,0.803,1.938,1.844,2.045h11.802C479.476,141.313,480.277,140.44,480.277,139.376"/> <%-- s --%> <path fill="<%= logoColor %>" d="M603.208,84.782H577.99c-6.91-0.114-12.508-5.785-12.508-12.783 c0-6.996,5.598-12.895,12.508-12.895h39.271c1.146,0,2.08-0.959,2.08-2.111v0.191V45.752v-0.037c0-1.164-0.935-2.097-2.08-2.097 H577.99c-15.451,0-28.008,12.73-28.008,28.381c0,15.651,12.557,28.381,28.008,28.27h24.252c6.911,0.111,12.508,5.812,12.508,12.795 c0,6.996-5.597,12.896-12.508,12.896H591.56l0.001-0.014h-28.874c-0.022,0.014-0.034,0.014-0.047,0.014 c-1.11,0-2.007,0.896-2.056,2.01v11.449c0.035,1.092,0.886,1.963,1.973,2.014h0.225h27.74h12.224 c15.209-0.279,27.491-12.9,27.491-28.369C630.236,97.737,618.191,85.202,603.208,84.782"/> </g> </svg> <% } %> </div><% } %> <ul id="<%= prodId %>_LIST_<%= instanceIndex %>_<%= line %>" class="<%= baseCls %>" style="display:block; width:<%= instance.width - bh.logoWidth -30 %>px; height:<%= bh.tagHeight %>px; text-align:center; padding:0; margin:6px 0 0 0; font-size:0; overflow:hidden;"></ul>';
return rt.utils.VeST(tpl, {
prodId: stit.prodId,
baseCls: st.baseClass,
st: st,
bh: bh,
themeColor: stit.themes.color[bh.theme],
instance: instance,
instanceIndex: instanceIndex,
oldIE: stit.oldIE,
oldFF: b.Firefox && b.getVersion(true) < 4,
skinPath: skinPath,
line: line,
withLogo: withLogo,
logoColor: bh.darkBg ? "#888888" : "#003366"
})
},
getSkinPath: function() {
var stit = this.settings;
return ["http:/", this.$root.settings.hosts.resources, "static", "skins", stit.behavior.merged.skin, stit.prodName, stit.rv, ""].join("/")
},
hookMouseStateChange: function(event) {
var el = event.element,
key;
for (key in event.data) {
el.style[key] = event.data[key]
}
}
}, {
settings: {
prodId: "IL_IN_TAG",
tagCloud: "IL_TAG_CLOUD",
relatedTags: "IL_RELATED_TAGS",
prodCode: "t",
prodName: "intag",
rv: 1,
instances: [],
containerMinWidth: 200,
sentences: {},
oldIE: (function() {
var b = $root.browser;
return (b.IE && (document.compatMode == "BackCompat" || b.getVersion(true) < 9))
}()),
behavior: {
def: {
skin: "brand",
theme: "def",
fontFamily: "Arial,sans-serif",
fontWeight: "normal",
fontSize: 13,
underline: "single",
logoHeight: 11,
logoWidth: 48,
height: 60,
hookMargin: 15,
lines: 1,
darkBg: false
},
sanitizer: {
fontFamily: "str",
fontWeight: ["normal", "bold"],
fontSize: "int",
underline: ["double", "single", "dotted", "dashed", "none"],
logoHeight: "int",
logoWidth: "int",
height: "int",
hookMargin: "int",
lines: "int",
darkBg: "bool"
}
},
themes: {
color: {
def: "#003366",
lightBlue: "#1b8ede",
green: "#67b045",
orange: "#f3933b",
red: "#dd3c42",
pink: "#d84189",
purple: "#5939aa"
}
}
}
}, true);
intag.bind({
event: "renderProduct",
listener: {
renderIntag: function() {
var rt = this.$root,
prod = this.settings.prodCode;
if (!rt.comm.settings.responses.impression.prs[prod]) {
rt.event.fire("productRenderStatus", {
prod: prod,
status: "none"
});
return
}
rt.event.fire("productRenderStatus", {
prod: prod,
status: "during"
});
rt.event.fire("initIntag")
}
}
});
intag.bind({
event: "initIntag",
listener: {
init: function() {
var rt = this.$root,
st = rt.settings,
bh = st.behavior,
stit = this.settings,
prod = stit.prodCode,
uto = rt.utils.object,
prodImp = rt.comm.settings.responses.impression.prs[prod],
bhr = stit.behavior,
i, leni;
var cbh = rt.helpers.getVar("related_tags") || {};
bhr.impression = rt.helpers.renameBehaviorProperties(prodImp.behavior || {});
bhr.merged = uto.extend({}, bh.def, bhr.def, bh.impression, bhr.impression, bh.customer, cbh);
bhr.merged.tagHeight = Math.max(Math.ceil(bhr.merged.fontSize * 1.3) + 2, 17);
rt.helpers.sanitize(bhr.merged, uto.extend({}, bh.sanitizer, bhr.sanitizer));
if (!stit.themes.color[bhr.merged.theme]) {
bhr.merged.theme = "def"
}
if (!rt.bubble.initialized) {
rt.event.fire("initBubble", stit.prodName)
}
var markers = this.locateMarkers([stit.prodId, stit.relatedTags], bhr.merged.lines);
if (markers.length) {
for (i = 0, leni = markers.length; i < leni; i++) {
var o = {
marker: markers[i],
container: markers[i].parentNode,
lines: parseInt(markers[i].value, 10) || 1,
hooksCount: 0
};
o.width = rt.utils.dom.element.getActualWidth(o.container);
if (o.width < stit.containerMinWidth) {
rt.logger.warn("Warning: In-Tag instance does not have minimum required width.", this.init);
continue
}
rt.utils.array.push(stit.instances, o)
}
}
rt.event.fire("createIntagUnits")
}
}
});
intag.bind({
event: "createIntagUnits",
listener: {
createIntagUnits: function() {
var rt = this.$root,
st = rt.settings,
stit = this.settings,
bh = stit.behavior.merged,
ut = rt.utils,
dm = ut.dom,
dmel = dm.element,
i, leni, k, lenk, instance, sentence, liNode, hook, baseCls = st.baseClass,
hookId, j, lenj, lines, currentLine, logo, adNode, ps, b = rt.browser;
var underline = dm.style.buildHookUnderlineCSS(bh.underline, bh.linkColor, true);
dm.style.addRule("." + stit.prodId + "_AD", [underline, "display:inline; color:", bh.linkColor, " !important; cursor:pointer !important; font-family:", bh.fontFamily, "; font-weight:", bh.fontWeight, "; font-size:", bh.fontSize, "px !important; white-space:nowrap !important; float:none !important;"].join(""));
var liStyle = {
display: "inline",
margin: 0,
padding: 0,
background: "none"
};
var currentSentenceIndex = 0,
imp = rt.comm.settings.responses.impression,
sentenceIndexes = imp.prs[stit.prodCode].sentences,
el, ul, computedWidth, availWidth, sentenceLoopCount, sentencesKeys = ut.object.keys(imp.sentences);
for (i = 0, leni = stit.instances.length; i < leni; i++) {
instance = stit.instances[i];
currentLine = 0;
el = instance.node = this.renderUnit(i);
ps = el.previousSibling;
while (ps) {
if (ps.nodeType == st.nodeTypes.ELEMENT && ps.tagName.toLowerCase() != "input") {
if (/left|right/.test(dmel.getStyle(ps, b.IE ? "styleFloat" : "cssFloat"))) {
dmel.setStyle(el, {
clear: "left"
})
}
break
}
ps = ps.previousSibling
}
instance.pos = dmel.offset(el);
lines = [];
for (j = 0, lenj = instance.lines; j < lenj; j++) {
ul = dmel.$([stit.prodId, "LIST", i, j].join("_"));
if (ul) {
ut.array.push(lines, ul)
}
}
if (!lines.length) {
rt.logger.warn("Error: In-Tag UL element not found.", this.createIntagUnits);
rt.event.fire("productRenderStatus", {
prod: stit.prodCode,
status: "none"
});
return
}
logo = dmel.$([stit.prodId, "LOGO", i].join("_"));
if (logo) {
rt.event.dom.bind(logo, {
event: "click",
listener: function(event) {
rt.utils.dom.event.stop(event.domEvent);
if (st.homeUrl) {
window.open(st.homeUrl, "_blank")
}
}
})
}
computedWidth = 0;
availWidth = instance.width - bh.logoWidth - 30;
sentenceLoopCount = 0;
for (k = currentSentenceIndex, lenk = sentenceIndexes.length; k < lenk; k++) {
sentence = sentencesKeys[sentenceIndexes[k]];
hookId = ++st.hooksCount;
liNode = dm.createDOMFragment({
tag: "li",
parent: lines[currentLine],
cls: baseCls,
style: liStyle,
children: {
tag: "span",
cls: [baseCls, " ", stit.prodId, "_AD"].join(""),
style: {
padding: ["0 ", bh.hookMargin, "px"].join(""),
fontWeight: "normal"
},
id: [stit.prodId, "_AD", hookId].join(""),
innerHTML: ut.string.capitalize(sentence)
}
});
adNode = liNode.getElementsByTagName("span")[0];
rt.event.dom.bind(adNode, {
event: "mouseover",
data: {
fontWeight: "bold",
padding: ["0 ", bh.hookMargin - 2, "px"].join("")
},
listener: this.hookMouseStateChange
});
rt.event.dom.bind(adNode, {
event: "mouseout",
data: {
fontWeight: "normal",
padding: ["0 ", bh.hookMargin, "px"].join("")
},
listener: this.hookMouseStateChange
});
computedWidth += liNode.offsetWidth;
if ((computedWidth > availWidth) || (sentenceLoopCount >= 3 && currentLine >= lines.length - 1)) {
if (currentLine < lines.length - 1) {
lines[++currentLine].appendChild(liNode);
computedWidth = bh.hookMargin * 2 + liNode.offsetWidth
} else {
lines[currentLine].removeChild(liNode);
currentSentenceIndex = k;
st.hooksCount--;
break
}
}
instance.hooksCount++;
hook = rt.helpers.createHook(hookId, sentence, liNode.firstChild, bh.fontSize, this, stit.prodCode, stit.prodName, true, instance);
if (stit.autoPlacement) {
hook.pst = "auto"
}
dm.createDOMFragment({
isTextNode: true,
value: "\n",
parent: lines[currentLine]
});
if (k == lenk - 1) {
k = -1;
++sentenceLoopCount
}
}
}
this.$root.event.fire("productRenderStatus", {
prod: stit.prodCode,
status: "after"
})
}
}
});
var insearch = products.$create("insearch", {
getSkinPath: function() {
var stsr = this.settings,
bh = stsr.behavior.merged;
return ["http:/", this.$root.settings.hosts.resources, "static", "skins", bh.skin, stsr.prodName, stsr.rv, ""].join("/")
},
setEventHandlers: function(hook) {
var rt = this.$root,
b = rt.browser,
st = rt.settings,
ut = rt.utils,
node = hook.node,
stsr = this.settings,
dm = ut.dom,
dmel = dm.element,
evdm = rt.event.dom,
sr = this,
ns = "IL_SR_",
xBtn = dmel.$(ns + "X"),
helpBtn = dmel.$(ns + "HELP"),
clickBtn = dmel.$(ns + "BTN"),
srLogo = dmel.$(ns + "LOGO");
if (b.IE) {
stsr.initialBannerShowTime = 20
}
this.closeBanner(stsr.initialBannerShowTime);
evdm.bind(window, {
event: "resize",
listener: function() {
var left = Math.ceil((dm.viewport.getWidth() / 2) - (parseInt(node.style.width) / 2));
stsr.instance.left = left;
node.style.left = left + "px"
}
});
if (stsr.oldIE) {
evdm.bind(window, {
event: "scroll",
listener: this.updateTopPosition
});
evdm.bind(window, {
event: "resize",
listener: this.updateTopPosition
})
}
evdm.bind(window, {
event: "scroll",
listener: this.scrollHandler
});
if (xBtn) {
evdm.bind(xBtn, {
event: "click",
listener: function(event) {
rt.utils.dom.event.stop(event.domEvent);
rt.event.stop("SRAnimateUp");
rt.event.disable("SRAnimateUp");
rt.event.stop("SRAnimateDown");
rt.event.disable("SRAnimateDown");
rt.event.dom.unbind(window, "scroll", sr.scrollHandler);
node.parentNode.removeChild(node)
}
});
evdm.bind(xBtn, {
event: "mouseover",
data: {
el: xBtn,
pos: "-15px -15px"
},
listener: this.setBackgroundPosition
});
evdm.bind(xBtn, {
event: "mouseout",
data: {
el: xBtn,
pos: "-15px 0"
},
listener: this.setBackgroundPosition
})
}
if (srLogo) {
evdm.bind(srLogo, {
event: "click",
listener: function(event) {
rt.utils.dom.event.stop(event.domEvent);
if (st.homeUrl) {
window.open(st.homeUrl, "_blank")
}
}
})
}
if (clickBtn) {
evdm.bind(clickBtn, {
event: "mouseover",
data: {
el: clickBtn
},
listener: function(event) {
event.data.el.style.backgroundPosition = "0 -24px"
}
});
evdm.bind(clickBtn, {
event: "mouseout",
data: {
el: clickBtn
},
listener: function(event) {
event.data.el.style.backgroundPosition = "0 0"
}
})
}
if (helpBtn) {
evdm.bind(helpBtn, {
event: "click",
listener: function(event) {
rt.utils.dom.event.stop(event.domEvent);
if (st.helpUrl) {
window.open(st.helpUrl, "_blank")
}
}
});
evdm.bind(helpBtn, {
event: "mouseover",
data: {
el: helpBtn,
pos: "0 -15px"
},
listener: this.setBackgroundPosition
});
evdm.bind(helpBtn, {
event: "mouseout",
data: {
el: helpBtn,
pos: "0 0"
},
listener: this.setBackgroundPosition
})
}
var bh = stsr.behavior;
evdm.bind(node, {
event: "click",
listener: this[bh.skins.click[bh.merged.skin] || "insearchClick"]
});
evdm.bind(node, {
event: "mouseenter",
listener: function() {
stsr.animating.mouseover = true;
stsr.animating.mouseout = false;
if (!stsr.animating.up) {
rt.event.repeat("SRAnimateUp", stsr.animationInterval)
}
}
});
evdm.bind(node, {
event: "mouseleave",
listener: function() {
stsr.animating.mouseover = false;
stsr.animating.mouseout = true;
sr.closeBanner(stsr.oldIE ? 5 : 2)
}
})
},
setBackgroundPosition: function(event) {
event.data.el.style.backgroundPosition = event.data.pos
},
updateTopPosition: function() {
var rt = window[appNamespace],
dm = rt.utils.dom,
stsr = rt.products.insearch.settings,
node = stsr.instance.hook.node;
var currentHeight = parseInt(rt.utils.dom.element.getStyle(node, "height"));
node.style.top = (dm.viewport.getHeight() + dm.document.getScrollTop() - currentHeight) + "px"
},
scrollHandler: function() {
var rt = this.$root,
dm = rt.utils.dom,
docHeight = dm.document.getHeight(),
currentScroll = dm.document.getScrollTop() + dm.viewport.getHeight(),
stsr = this.settings;
if (currentScroll == 0) {
currentScroll = window.pageYOffset || (document.body.parentElement ? document.body.parentElement.scrollTop : 0)
}
if (docHeight <= currentScroll) {
if (stsr.state == "open") {
return
}
this.closeBanner(stsr.oldIE ? 5 : 4);
if (!stsr.animating.up) {
rt.event.repeat("SRAnimateUp", stsr.animationInterval)
}
}
},
closeBanner: function(delay) {
this.$root.event.repeat("SRAnimateDown", this.settings.animationInterval, null, delay * 1000)
},
setInsearchStylesheet: function() {
var rt = this.$root,
b = rt.browser,
dms = rt.utils.dom.style,
hdrCss, btnCss, hdrCls = "IL_SR_BG",
skinPath = this.getSkinPath();
if (b.IE && b.getVersion(true) < 8) {
hdrCss = skinPath + "hdr-btns.png";
btnCss = skinPath + "btn.png"
} else {
hdrCss = "data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAB4AAAAeCAYAAAA7MK6iAAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAAB+hJREFUeNrEV3tMm9cVP7Y/29gY/MBvg3klgFJGAnFeBUpok03NOhJeaVcSdVvGEu2fbdqmNm23bkmqRk1bbVm0PiKtTaVtSkLTh9SQlLY0CWSDpkugy8MmCY+AwRiwzbDBYJudc+FzP0e0+W+70pG/ex733Hvuub9zLPr9/gPAj/n5edDr9TA2NmbG6fJF9i3kuZEHIpEorvvbZ59hv7y9WCyGWCwGJpMJPB5PBrKykWJITp1O652Y8DE9fg0OEscGpIOl999fbjQaUEMEXq8Xbjid7ch/Guk8fPP4DtKBB8rLHXp9Gm5knjYRc7qcnyD/KaR/8YpCx3vWrllzZN26tRIJ7p4fmfYMKCkuLv380qXWf3Z0/AxZR77G6TMPlJftL161SiSMTFamXby6pGRz+8WLFZevXPkRsv4qdFyBix9ZuXKlZGYmzBh+v5+FXqvVsnlhYaE4Eo0cvnTpCydOW+5yWrdhw/oD+fkFEJqeWXJXDodDFolE/vLvq1ev08m55ORkkMvkLxcUFEimF40+bvkYOjo62HdJSQk8vOVh9p2fly/q6+v/QzAYvE+wpsRisbycnZUDZD/q8YA8SQ5qtYYJMdSQtDgvLPyWrH9g4EWplNtEMc2z2qyrZ2dnIRyewcTyQmdnJzz51K9h794nobu7G0ZGRpgsHA6D1WpdgTZFvFeZTFaabrPZF+Qz4Ha74bXXXofhYTc4nTfg6BtHYXJykskikTmyfxDNzFw0EimkU/Mhlkg42LZtKwSD00CbofuibOXlqmQV8Urws3vBsdQhtF+etxzm5ubg2Ftvo6MI7NjRwE7Ly1FX1NMTyOPkSUkKUiAn/DAYjeByuqC19VNYsWIFyOXyuBzvGRQKhSoeZwknj0SicTn9yBVJbJ6UlASRWJRFih9R1MWDiLg0ne5OIDAJKSkpCckQDE1BUVERONY4YCb8VcIEAgFIVipd/BxP0OsP+EEqk7I5hfps81loaHic8ABOHj8J1TXVkJK6sH4Aw45ZPinChy1veueUJzc3Vy10HJ5ZcIYRSdjQzVs3p6q3VlkMBsMUzZ0ul+n8hbaB3JxcGXM8NIQRM4AMo8ThtY16RhAOxOx1zKP89q2b7sYf78qg5Aqr1al/HB4exjBG4xSbj7GwCnkjuAjqvoo2U4K9eJRKxTEvno50bOnpIEaHc3MRmMbNa7Q6JC2TDQ4OEjK+RIgmordKBzt+sukTVC4lyFxqjI+PI6bGOhoe/34lTqd5/sxCZNRo34a5UKjRaJe0p2elUinP1lZXf5eumnfMEvZ085lXh9zuBsw3kVKpBAKgUCjEFjebTccf2bJlN12TcMFFx5Tp+rMftbzpGR19hGwVCiUCUAxfRwgTLRyzZ6Qf/fbmzT8nk7shk8K389H6ukNd3d31Pp+/gJho4EIYbDp34cLle+D0GNL36mtr1l3p6qqZnPxPLpaOWG5O1tXiVcXH29rbbgiVhSf+nw4x/J8Gt+/A8wn1eHEzhEz5FBF6MUhfUCbyNZfGc795NqEecxzHkIowBWkt0jJKIqRrSF20/DfV49qUlNRDaWm6bEoQGqHQNExMjPcj3u7F6d/vcZBdGo1mn1arsyoQvegcWFDI3jk1NfULlDcvVY9/l5WV9ZzRaEpYSaVKAaPRmInF4299fX1UHPYu4ZCO8edly5bv0el0CQJCRLPZnI848eGdOwO/QtYrwjveSk7NZgtrYYgI7sa8Y/E5bSg7O5u6iMeWcLwbkW8PYQCvfzfZbDaR3W4n8KhkJ0bAB6lU9qLVaouvcrG9HaFulBmkYQtTWlbG+LSx8fGJF/x+34nFfoqBT1qafr9eb2ATQkCZVMbsaAwhWimxehFkpqdniHw+30EspevoxEWIu3lSTA6iWawkg3cG4Qc/fAJ27twBHqzFM9Mh4OXYi2WhoYPfJKJVhclk1PPyZKUCmk+fhglEut7bt+H8ufNYSpOZTCaVgj5NT4mXyeHl5KtTU+PVRSvTwqOP1cMs1lRKDCpvKrwnXq7B2orO6K47aS6VSldiQsXlVpsNtm+vgxMnmjDTJdDYuCseGnbnWKX6B/qzOKwiHMd2I4sL1WotuFwuONN8BjZteghSMMF4oCFddBxXxrlEykkT7Cd8fqzTEpZz3rFxwNYIBPpMJraYzX2hUJAVeyHRm9y4cSOsdjiovYnzg6ir0aivfZW1KmdQYN/X18t6tp/sboR6PPmpd06xGs7LQxhF7GbHCDIlb751bKi0tNQkbEspuQgszBZzAsBgm+rbVlVl0Wo1rK3o7x/QII67N6xfr6B5b28vqFPVoEvTMbCg+sxhRKhGx6IxaP9H+217hj2XkiuKz+BgT08PKLDo84QlDFiVEfBoUa1Gc4hquODa/Cg7TLWWdKhVstms7DsJT5iTkwP2TDubX8fmz2K27KeejC8S4nffe78J25hqbEsS/qrwJ73cdYV67Q/qampqFqFQOOQnTjY149+XysLC+/BmE+0pch2fd0I0Gn0b8+GJu6sT99m5c/uwk/glprwMn8hCAR8dBe+odxb/kvzpwcpK+hsz+zVwqfyopeUlfyDQaDaZOYNBzxyOYAMwMT4xjfX8+fKyshf49y+ETEL4p+traw9fvXatyu0ezqONWSzmm5UVFe9/2trqvgdOh5B+ur2u7mD3l19WDQ25cygyGRnp1x+qrPzgQlvbmFD5vwIMAAZsT2nNzBrxAAAAAElFTkSuQmCC";
btnCss = "data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAF0AAABICAYAAACUavnrAAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAAA4JJREFUeNrsnL9u01AUxs+xbxOS1LQVBQkGJBgQMPUNGCshMiB1zgqoOwMViBfoxMYGqjqwMIBgYqC8AQsStAyVaAmllDZN4j+xL/fGdsgD9J4I8X1SFDvZfv70+dxzj60eP3119vXGx9V6rXLzdP2U0gSdtNh8umEct/ePXn7ebt9nutZ6dvHyhdZsUKcsA3JX8n2mvV/HtLN38ET5Qb1prgJ1+xHIuHS7sXuSZvagqcy5l//IIOMYOudB4ivSpG2seGDuVgZ4kd5a2TOtNSHO3d9MM51DHlYrWZYRjC5gdp3l0K3t7QWA0SWgF06nwumQ80inEvMwXlINn0soG3e6xl1UyO3j8QKnyzrdhvsgRaaLBfsoXuB0UXlAAOiADgE6oEOA/s9B94FBVL6p03mLmBfAQmqBpDcVZ/EKJ701s0CaAxHHseJxW081HilD/c1sw1vu9JMl4/qGbREAz8nzZtKdoF5Z/51kGyqhynxXBYtXrp+7MV2rKrQETl52U7obJtGX7fbPOI7e2UxfNb+3dvcO0YNxCt5uiOq75iBR7FEzihMKowRkBBxvZOde2GNDHmMvAtDNJ6XUloykAVy2aFTlFYDkpP6GPCSSLyV0DzN1MrlScFcMp8tSHzkd0OWYs4XOebxgWSRBvRjBGMaLgc6gLpQubOOFTbyYxRG2MwSMXk54FfGCWBdLlzxefEOcUTYKOt3Gi4/ei6jT82hntALkynRMA0xCgA7o/w90zL3Iylea9JapFxfQCnCr4WPq8cAebqo0Dh909neeK6XmCRvTTqn3++Gu1pWHitL47XHv6B771dvmn4Aw9+IoxvWhTsMXVJ35oGiqMR/MnLl19dL5xelaBe97cWJytm8ZiT993e12euF7uzhaNaBb334c5I/cgbob8Pk98445ipU5afbjhHphDDIC4M3SP597sQ0v7aMR4Bw62bkXKude0HsRlMYIhiTt4luVhTskFzFw+gSsnm9MI9FFrZ47Hb1GWadb8ogXWeqj7TpILl+KWUagkBRKxslA5+Gd1EOjSyDRxzLdQwUzieoFETOBTEf9Ig+dMEAqCr18/AXQ3cc5jznd57wBg4hxuiQa7fj7SmvaYs/OvaB8cQ3dzr2YsnFTZYNopXfwfc1An8OutFtFcdJmXbXve0nfVDlZPu4NlgxyvO/FjTyPdSeoVdbTRG/8EWAAta8y0OqpUAcAAAAASUVORK5CYII="
}
dms.addRule("." + hdrCls, ['background-image : url("', hdrCss, '")'].join(""));
dms.addRule("#IL_SR_BTN", ['background-image : url("', btnCss, '")'].join(""))
},
insearchClick: function(event) {
var rt = this.$root,
stsr = this.settings,
hook = stsr.instance.hook,
hookId = hook.id,
node = hook.node,
dmel = rt.utils.dom.element,
adArea = dmel.$("AD_AREA"),
data = rt.helpers.getHookData(hook.id),
ad = data.ads[0];
if (ad.template != "text" && adArea && dmel.inHierarchy(event.element, adArea) && ad.content && ad.content.match(/<object |<embed /i) && ad.content.match(/clicktag/i)) {
return
}
if (ad.template == "external") {
return
}
rt.event.stop("SRAnimateUp");
rt.event.disable("SRAnimateUp");
rt.event.stop("SRAnimateDown");
rt.event.disable("SRAnimateDown");
rt.event.dom.unbind(window, "scroll", this.scrollHandler);
var parent = node.parentNode;
parent.removeChild(node);
rt.utils.timer.stop("adView" + hookId);
var reuseWindow = rt.helpers.getHookBehavior(hookId).adsReuseWindow;
if (!reuseWindow) {
try {
rt.settings.adWin = window.open("", hookId)
} catch (ex) {
rt.settings.adWin = null;
rt.logger.error("insearch click: Unable to open new window", this.insearchClick)
}
}
rt.event.fire("productClick", {
hookId: hookId,
clickType: "onWin"
})
},
yahooClick: function(event) {
this.insearchClick(event)
}
}, {
settings: {
prodId: "IL_INSEARCH",
prodCode: "s",
prodName: "insearch",
instance: null,
sentences: {},
oldIE: (function() {
var b = $root.browser;
return (b.IE && (document.compatMode == "BackCompat" || b.getVersion(true) < 9))
}()),
animationInterval: $root.browser.IE ? 7 : 10,
initialBannerShowTime: 15,
rv: "1",
bannerTimeoutClose: null,
state: "closed",
animating: {
down: false,
up: false,
mouseover: false,
mouseout: false
},
behavior: {
def: {
skin: "brand",
theme: "def",
heightOpen: 155,
heightClose: 55,
tb: "white",
tp: "searchingFor",
bt: "clickHere",
thumb: false,
favicon: false,
titlePrefixColor: "#4E4E4E",
titleTermColor: "#4E4E4E"
},
skins: {
click: {
brand: "insearchClick",
yahoo: "yahooClick"
}
}
},
themes: {
color: {
def: "#003366",
lightBlue: "#1b8ede",
green: "#67b045",
orange: "#f3933b",
red: "#dd3c42",
pink: "#d84189",
purple: "#5939aa"
},
tb: {
gray: "height:55px; background-color:#F1F1F2;",
white: "height:55px; background-color:#FFFFFF;",
grayLine: "height:53px; border-bottom:2px solid #F1F1F2; background-color:#FFFFFF;"
}
}
}
}, true);
insearch.bind({
event: "renderProduct",
listener: {
renderInsearch: function() {
var rt = this.$root,
imp = rt.comm.settings.responses.impression,
srst = this.settings,
prodCode;
if (imp.prs["s"]) {
delete imp.prs["o"];
delete rt.settings.productRenderStatus["o"];
prodCode = srst.prodCode
} else {
if (imp.prs["o"]) {
prodCode = srst.prodCode = "o";
delete rt.settings.productRenderStatus["s"]
}
}
var prod = imp.prs[prodCode];
if (!prod || !prod.sentences || !prod.sentences.length) {
rt.event.fire("productRenderStatus", {
prod: "s",
status: "none"
});
rt.event.fire("productRenderStatus", {
prod: "o",
status: "none"
});
return
}
rt.event.fire("productRenderStatus", {
prod: prodCode,
status: "during"
});
rt.event.fire("initInsearch")
}
}
});
insearch.bind({
event: "initInsearch",
listener: {
init: function() {
var rt = this.$root,
ut = rt.utils,
stsr = this.settings,
instance, resImp = rt.comm.settings.responses.impression,
bh = rt.settings.behavior,
senteceIndex = resImp.prs[stsr.prodCode].sentences[0],
bhsr = stsr.behavior,
getadsDelay = 0;
bhsr.impression = rt.helpers.renameBehaviorProperties(resImp.prs[stsr.prodCode].behavior || {});
bhsr.merged = rt.helpers.sanitize(ut.object.extend({}, bh.def, bhsr.def, bh.impression, bhsr.impression, bh.customer), bh.sanitizer);
if (!this.skins[bhsr.merged.skin]) {
bhsr.merged.skin = bhsr.def.skin
}
instance = stsr.instance = {
sentence: ut.object.keys(resImp.sentences)[senteceIndex],
node: ut.dom.createDOMFragment({
tag: "div",
id: stsr.prodId,
cls: rt.settings.baseClass,
parent: document.body
})
};
var hook = instance.hook = rt.helpers.createHook(stsr.prodId, instance.sentence, instance.node, 0, this, stsr.prodCode, stsr.prodName, false, instance);
rt.event.fire("getAds", {
hookId: hook.id,
callback: "getadsResponseInsearch"
}, getadsDelay)
}
}
});
insearch.bind({
event: "getadsResponseInsearch",
listener: {
setAdData: function(event) {
var rt = this.$root,
st = rt.settings,
data = event.data,
hookId = data.lid,
hook = st.hooksMap[hookId],
ad;
if (!hook) {
rt.logger.error("Error: Misssing hook.", this.setAdData);
return false
}
if (data.ads.length) {
ad = data.ads[0];
ad.midx = 0;
rt.helpers.setAdThumbnail(ad);
if (ad.trackerURL) {
rt.helpers.hitTrackerURL(ad.trackerURL)
}
}
ad = data.ads[hook.currentAdIndex];
if (ad && ad.template == "external") {
data = rt.externalTags.setExternalTagData(hook, data)
}
rt.helpers.setHookData(hookId, data);
if (hook.externalTag) {
rt.externalTags.updateViewedTags(hook.id)
}
rt.event.fire("createInsearchUnit", {
hookId: hookId
})
}
}
});
insearch.bind({
event: "createInsearchUnit",
listener: {
createInsearchUnit: function(event) {
var rt = this.$root,
st = rt.settings,
hookId = event.data.hookId,
hook = st.hooksMap[hookId],
msg = "",
stsr = this.settings,
data = rt.helpers.getHookData(hookId),
bh = stsr.behavior.merged;
if (!data.ads.length) {
msg = "received no ad."
}
if (msg) {
rt.event.fire("productRenderStatus", {
prod: stsr.prodCode,
status: "failed",
reason: msg
});
return
}
if (data.skin) {
bh.skin = data.skin
}
if (data.theme) {
bh.theme = data.theme
}
this.skins[bh.skin](hookId);
this.setEventHandlers(hook);
rt.event.repeat("SRAnimateUp", stsr.animationInterval);
rt.event.fire("productRenderStatus", {
prod: stsr.prodCode,
status: "after"
})
}
}
});
insearch.bind({
event: "SRAnimateUp",
listener: {
animateUp: function() {
var rt = this.$root,
stsr = this.settings,
ut = rt.utils,
dmel = ut.dom.element,
hook = stsr.instance.hook,
node = hook.node,
anim = stsr.animating,
b = rt.browser;
var heightOpen = stsr.behavior.merged.heightOpen;
if (stsr.state == "open") {
rt.event.stop("SRAnimateUp");
return
}
var currentHeight = parseInt(dmel.getStyle(node, "height"));
if (currentHeight >= heightOpen) {
rt.event.stop("SRAnimateUp");
rt.utils.timer.stop("inSearchAnimateUp");
rt.utils.timer.start("adView" + hook.id);
stsr.state = "open";
anim.up = false;
rt.utils.cookie.remove("refc");
if (stsr.oldIE) {
this.updateTopPosition()
}
rt.event.fire("sendAdView", {
hookId: hook.id,
params: {
prod_t: hook.prod
}
});
return
}
if (!anim.up) {
anim.up = true;
stsr.state = "animating";
rt.utils.timer.start("inSearchAnimateUp")
}
var newHeight, newTop, step, utd = ut.dom.document,
vpHeight = ut.dom.viewport.getHeight(),
docScroll = utd.getScrollTop();
newTop = vpHeight + docScroll - currentHeight;
if (b.IE && b.getVersion(true) > 6) {
step = 3;
if (b.getVersion() >= 9) {
newTop = false
}
} else {
if (stsr.oldIE) {
step = null;
newHeight = heightOpen;
newTop = vpHeight + docScroll - heightOpen
} else {
step = 2;
newTop = false
}
}
if (step) {
newHeight = Math.min(currentHeight + step, heightOpen)
}
if (newTop) {
dmel.setStyle(node, {
top: newTop + "px"
})
}
dmel.setStyle(node, {
height: newHeight + "px"
})
}
}
});
insearch.bind({
event: "SRAnimateDown",
listener: {
animateDown: function() {
var rt = this.$root,
dmel = rt.utils.dom.element,
stsr = this.settings,
hook = stsr.instance.hook,
node = hook.node,
anim = stsr.animating,
b = rt.browser;
var heightClose = stsr.behavior.merged.heightClose;
if (stsr.state == "closed") {
rt.event.stop("SRAnimateDown");
return
}
var currentHeight = parseInt(dmel.getStyle(node, "height"));
if (currentHeight <= heightClose || anim.up || anim.mouseover) {
anim.down = false;
rt.event.stop("SRAnimateDown");
stsr.state = currentHeight <= heightClose ? "closed" : "animating";
rt.utils.timer.clear("adView" + hook.id);
return
}
if (!anim.down) {
anim.down = true;
stsr.state = "animating"
}
var dm = rt.utils.dom,
vpHeight = dm.viewport.getHeight(),
docScroll = dm.document.getScrollTop(),
newHeight, currentTop = parseInt(dmel.getStyle(node, "top")),
step = 1,
newTop;
if (!stsr.oldIE) {
newTop = false
} else {
if (b.IE && b.getVersion(true) > 6 && b.getVersion(true) < 9) {
step = 2;
newTop = currentTop + step
} else {
if (stsr.oldIE) {
step = false;
newHeight = heightClose;
newTop = vpHeight + docScroll - heightClose
}
}
}
if (step) {
newHeight = Math.max(currentHeight - step, heightClose)
}
dmel.setStyle(node, {
height: newHeight + "px"
});
if (newTop) {
dmel.setStyle(node, {
top: newTop + "px"
})
}
}
}
});
insearch.$create("skins", {
brand: function(hookId) {
var rt = this.$root,
b = rt.browser,
ut = rt.utils,
dm = ut.dom,
st = rt.settings,
stsr = this.$parent.settings,
data = rt.helpers.getHookData(hookId),
instance = stsr.instance,
hdrCls = "IL_SR_BG",
srPos = "",
srIEStyle = {},
skinPath = this.$parent.getSkinPath(),
sentence, content, tpl, html, nodeStyle, so = window.orientation,
ibh = stsr.behavior.merged,
hook = st.hooksMap[hookId],
themeColor;
var ad = data.ads[0];
rt.helpers.setActualTemplate(ad);
if (ad.template == "text") {
var textLength = (ad.thumbURL && ad.thumbURL != "no-image") ? 145 : 180;
var pos = ad.displayedURL.indexOf("/");
if (pos != -1) {
ad.displayedURL = ad.displayedURL.substr(0, pos)
}
ad.title = ut.string.truncateToChar(ad.title, 52, " ", "...");
ad.text = ut.string.truncateToChar(ad.text, textLength, " ", "...");
ad.thumbURL = (ad.thumbURL != "no-image") ? ad.thumbURL : false
}
if (ad.contentUrl) {
content = rt.bubble.templates.external(hook, 0)
} else {
content = rt.helpers.parseTokens(hook)
}
this.$parent.setInsearchStylesheet();
instance.height = ibh.heightClose;
if (ad.template == "text") {
instance.fullWidth = 722
} else {
instance.fullWidth = data.width > 0 ? data.width : 722;
ibh.heightOpen = (data.height > 0 ? data.height : 90) + 55
}
instance.left = Math.ceil((dm.viewport.getWidth() - instance.fullWidth) / 2);
sentence = ((stsr.prodCode == "o") ? data.sentence : st.impression.params.refq).replace(/</g, "<");
var sentenceTruncated = ut.string.truncate(sentence, 38, "...");
if (stsr.oldIE) {
srPos = "absolute";
srIEStyle = {
top: (dm.viewport.getHeight() + dm.document.getScrollTop() - ibh.heightClose) + "px",
overflow: "hidden"
}
} else {
srPos = "fixed";
srIEStyle = {
bottom: 0
}
}
if (b.Firefox && b.getVersion(true) < 4) {
rt.utils.object.extend(srIEStyle, {
overflow: "hidden"
})
}
themeColor = stsr.themes.color[ibh.theme];
tpl = '<% if (oldIE || oldFF){ %> <img src="<%= skinPath %>in-search-shadow.png" alt="" width="<%= instance.fullWidth+20 %>" height="<%= ibh.heightOpen+10 %>" class="<%= baseCls %>" style="position:absolute; top:-10px; left:-10px; width:<%= instance.fullWidth+20 %>px; height=<%= ibh.heightOpen+10 %>px; overflow:hidden;" /> <% } %> <%-- Header --%> <div class="<%= baseCls %>" style="position:absolute; top:0; left:0; width:<%= instance.fullWidth %>px; <%= titleBase %>; cursor: pointer;"> <% if (ibh.favicon){ %><div class="<%= baseCls %>" style="position:absolute; left:15px; width:16px; height:16px; top:12px; background:url(<%= ibh.favicon %>) no-repeat scroll 0 0 transparent;"></div><% } %> <div class="<%= baseCls %>" style="position:absolute; width:<%= instance.fullWidth - 181 %>px; height:24px; left:<%= ibh.favicon ? 35 : 15 %>px; top:10px; color:<%= ibh.titlePrefixColor %>; font-family: Trebuchet MS,Arial,sans-serif; font-size:15pt; font-weight:normal; font-style:normal;"><%= titlePrefix %> <span class="<%= baseCls %>" title="<%= sentence %>" style="color:<%= ibh.titleTermColor %>; font-weight: bold; font-size:15pt;"><%= sentenceTruncated %></span>?</div> <div id="IL_SR_LOGO" class="<%= baseCls %>" style="position:absolute; top:10px; right:47px; width:48px; height:11px; cursor:pointer; font-size:1px; <% if (oldIE || oldFF){ %>background:url(<%= skinPath %>logo11.png) no-repeat scroll 0 0 transparent;<% } %>"> <% if (!(oldIE || oldFF)){ %> <svg version="1.1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" x="0px" y="0px" width="48px" height="11px" viewBox="0 0 636 144" enable-background="new 0 0 636 144" xml:space="preserve"> <g> <%-- dot (first) --%> <path id="IL_SR_LOGO_DOT1" fill="<%= ibh.theme == \'def\' ? \'#208CE5\' : themeColor %>" d="M16.918,24.865c5.848,0,10.57-4.735,10.57-10.583s-4.722-10.57-10.57-10.57 S6.334,8.434,6.334,14.282S11.07,24.865,16.918,24.865"/> <%-- in --%> <path fill="<%= themeColor %>" d="M88.085,43.784H77.024c-17.149,0-31.181,14.031-31.181,31.182v34.796 c0,0.218,0.016,0.415,0.027,0.618v5.185c0,5.71-4.672,10.382-10.382,10.382h-0.467c-5.71,0-10.382-4.672-10.382-10.382V92.608 h0.015V45.889v-0.025c0-1.124-0.885-2.033-2.01-2.08h-11.49c-1.09,0.047-1.949,0.907-1.986,1.996v46.828h0.04 c-0.015,0.355-0.04,0.707-0.04,1.066v22.246c0,14.031,11.479,25.512,25.511,25.512h1.151c14.031,0,25.511-11.48,25.511-25.512 v-5.466v-4.62v-28.89c0.082-9.872,8.159-17.948,18.031-17.948h6.366c9.871,0,17.948,8.076,18.042,17.948v28.89v4.62v28.873 c0.013,0.023,0.013,0.034,0.013,0.048c0,1.111,0.883,2.008,1.983,2.057h11.505c1.077-0.036,1.936-0.887,1.985-1.973v-27.966v-5.659 V74.966C119.267,57.815,105.234,43.784,88.085,43.784"/> <%-- f (part) --%> <path fill="<%= themeColor %>" d="M155.069,56.972v82.643c-0.072,0.992-0.886,1.78-1.903,1.818h-11.014 c-1.062-0.038-1.912-0.897-1.912-1.962c0-0.024,0-0.048-0.023-0.073V34.456c0.716-17.064,14.923-30.744,32.179-30.744h8.536 c0.025,0,0.038,0.011,0.06,0.011c1.053,0,1.915,0.849,1.974,1.901v11.037c-0.035,1.016-0.85,1.844-1.878,1.889h-8.692 c-9.509,0-17.327,7.75-17.327,17.268v6.301V56.972z"/> <%-- f (part) --%> <path fill="<%= themeColor %>" d="M151.99,59.104h28.873c0.023-0.012,0.034-0.012,0.047-0.012 c1.111,0,2.008-0.884,2.057-1.984V45.604c-0.036-1.078-0.887-1.938-1.973-1.986h-27.965"/> <%-- o --%> <path fill="<%= themeColor %>" d="M276.24,107.925h0.158V76.608c-0.37-18.164-15.248-32.825-33.494-32.825 h-16.756v0.022c-17.875,0.431-32.322,14.924-32.679,32.803h-0.026v31.316c0,18.213,14.601,33.064,32.705,33.496v0.012h16.589h0.021 h0.146C261.304,141.349,276.24,126.354,276.24,107.925 M208.93,107.925L208.93,107.925V77.289c0-9.914,8.096-18.02,18.021-18.02 h15.953c9.946,0,18.02,8.106,18.02,18.02v30.636h-0.167c0,9.949-8.074,18.021-17.999,18.021h-15.807 C217.026,125.946,208.93,117.874,208.93,107.925"/> <%-- l --%> <path fill="<%= themeColor %>" d="M312.844,139.376L312.844,139.376c0,1.064-0.798,1.938-1.829,2.045h-11.816 c-1.027-0.107-1.837-0.98-1.837-2.045h-0.013V5.769h0.013c0-1.135,0.908-2.033,2.031-2.057h11.432 c1.124,0.024,2.019,0.922,2.019,2.057V139.376z"/> <%-- dot (second) --%> <path id="IL_SR_LOGO_DOT2" fill="<%= ibh.theme == \'def\' ? \'#208CE5\' : themeColor %>" d="M341.662,24.865c5.848,0,10.57-4.735,10.57-10.583s-4.723-10.57-10.57-10.57 s-10.584,4.722-10.584,10.57S335.814,24.865,341.662,24.865"/> <%-- in (second) --%> <path fill="<%= themeColor %>" d="M412.829,43.784h-11.061c-17.149,0-31.181,14.031-31.181,31.182v34.796 c0,0.218,0.016,0.415,0.026,0.618v5.185c0,5.71-4.672,10.382-10.382,10.382h-0.468c-5.71,0-10.382-4.672-10.382-10.382V92.608 h0.016V45.723v-0.025c0-1.123-0.885-2.033-2.01-2.08h-11.49c-1.091,0.047-1.949,0.908-1.986,1.996v46.994h0.04 c-0.015,0.355-0.04,0.707-0.04,1.066v22.246c0,14.031,11.479,25.512,25.512,25.512h1.15c14.031,0,25.512-11.48,25.512-25.512 v-5.466v-4.62v-28.89c0.082-9.872,8.158-17.948,18.029-17.948h6.367c9.871,0,17.947,8.076,18.041,17.948v28.89v4.62v28.873 c0.014,0.023,0.014,0.034,0.014,0.048c0,1.111,0.883,2.008,1.982,2.057h11.506c1.076-0.036,1.936-0.887,1.984-1.973v-27.966v-5.659 V74.966C444.01,57.815,429.979,43.784,412.829,43.784"/> <%-- k --%> <path fill="<%= themeColor %>" d="M480.277,139.376L480.277,139.376V91.735h0.146h9.255l40.656,48.766 c0.599,0.549,1.15,0.906,1.841,0.932h16.073c0.882-0.025,2.869-0.322,1.794-2.056l-0.013-0.024l-47.58-56.777l44.599-36.815 c0.015-0.049,0.015-0.049,0.036-0.073c1.066-1.734-0.886-2.032-1.78-2.069H527.08c-0.621,0.024-1.15,0.324-1.666,0.791 l-36.812,31.075h-8.325V5.769c0-1.135-0.896-2.033-2.02-2.057h-11.422c-1.124,0.024-2.033,0.922-2.033,2.057v133.607 c0,1.064,0.803,1.938,1.844,2.045h11.802C479.476,141.313,480.277,140.44,480.277,139.376"/> <%-- s --%> <path fill="<%= themeColor %>" d="M603.208,84.782H577.99c-6.91-0.114-12.508-5.785-12.508-12.783 c0-6.996,5.598-12.895,12.508-12.895h39.271c1.146,0,2.08-0.959,2.08-2.111v0.191V45.752v-0.037c0-1.164-0.935-2.097-2.08-2.097 H577.99c-15.451,0-28.008,12.73-28.008,28.381c0,15.651,12.557,28.381,28.008,28.27h24.252c6.911,0.111,12.508,5.812,12.508,12.795 c0,6.996-5.597,12.896-12.508,12.896H591.56l0.001-0.014h-28.874c-0.022,0.014-0.034,0.014-0.047,0.014 c-1.11,0-2.007,0.896-2.056,2.01v11.449c0.035,1.092,0.886,1.963,1.973,2.014h0.225h27.74h12.224 c15.209-0.279,27.491-12.9,27.491-28.369C630.236,97.737,618.191,85.202,603.208,84.782"/> </g> </svg> <% } %> </div> <div class="<%= baseCls %> <%= hdrCls %>" id="IL_SR_HELP" style="position:absolute; right:26px; top:9px; width:15px; height:15px; background-position:0 0; cursor:pointer; font-size:1px;"></div> <div class="<%= baseCls %> <%= hdrCls %>" id="IL_SR_X" style="position:absolute; right:10px; top:9px; width:15px; height:15px; background-position:-15px 0; cursor:pointer; font-size:1px;"></div> </div> <%-- Body --%> <div id="IL_SR_AD_AREA" class="<%= baseCls %>" style="position:absolute; top:55px; left:0; width:<%= instance.fullWidth %>px; height:<%= ad.template == \'text\' ? 125 : data.height %>px; background-color:#ffffff; cursor: pointer;"> <% if (ad.template == \'text\'){ %> <% if (ibh.thumb && ad.thumbURL){ %> <div class="<%= baseCls %>" style="margin-left:15px; float:left; width:110px; background-color:#e8e8e8; -moz-box-shadow:2px 2px 5px #888; -webkit-box-shadow:2px 2px 5px #888; box-shadow:2px 2px 5px #888;"> <img class="<%= baseCls %>" src="<%= ad.thumbURL %>" width="110" height="82"> </div> <% } %> <div class="<%= baseCls %>" style="width:<%= instance.fullWidth - (ibh.thumb && ad.thumbURL ? 307 : 182) %>px; float:left; margin-left:30px;"> <div class="<%= baseCls %>" style="color:#1122CC; font-family:Trebuchet MS,Arial,sans-serif; font-size:12pt; font-weight:normal; text-decoration:none;"><%= ad.title %></div> <div class="<%= baseCls %>" style="color:#222222; font-family:Trebuchet MS,Arial,sans-serif; font-size:10pt; font-weight:normal; padding-top:4px;"><%= ad.text %></div> <div class="<%= baseCls %>" style="color:#009933; font-family:Trebuchet MS,Arial,sans-serif; font-size:10pt; font-weight:normal; padding-top:4px; overflow:hidden;"><%= ad.displayedURL %></div> </div> <div id="IL_SR_BTN" class="<%= baseCls %>" style="position:absolute; right:24px; font-family:Trebuchet MS,Arial,sans-serif; font-size:10pt; font-weight:bold; cursor:pointer; text-align:center; width:93px; height:24px; top:59px; line-height:24px; color:#ffffff;"><%= btnText %></div> <% } else { %> <% if (ad.actualTemplate == "iframe"){ %> <iframe name="IL_SR_FRAME" class="<%= baseCls %>" src="<%= st.blankURL %>" width="<%= data.width %>" height="<%= data.height %>" frameborder="0" scrolling="no"></iframe> <%= rt.helpers.getEchoForm(content, "IL_SR_FRAME", "IL_SR_FORM") %> <% } else { %> <%= content %> <% } %> <% } %> </div>';
html = ut.VeST(tpl, {
rt: rt,
st: st,
baseCls: st.baseClass,
hdrCls: hdrCls,
ibh: ibh,
instance: instance,
data: data,
ad: ad,
content: content,
sentence: sentence,
sentenceTruncated: sentenceTruncated,
skinPath: skinPath,
oldIE: stsr.oldIE,
oldFF: b.Firefox && b.getVersion(true) < 4,
themeColor: themeColor,
titleBase: stsr.themes.tb[ibh.tb],
titlePrefix: rt.helpers.translate(data.tp || ibh.tp),
btnText: rt.helpers.translate(data.bt || ibh.bt)
});
var boxShadow = "0 2px 6px 2px rgba(0, 0, 0, 0.5)";
nodeStyle = ut.object.extend({
position: srPos,
zIndex: st.baseZIndex,
width: instance.fullWidth + "px",
height: instance.height + "px",
left: instance.left + "px",
borderTop: "2px solid " + themeColor,
borderLeft: "1px solid #a7a9ab",
borderRight: "1px solid #a7a9ab",
backgroundColor: "#FFFFFF",
boxShadow: boxShadow,
MozBoxShadow: boxShadow,
WebkitBoxShadow: boxShadow,
oBoxShadow: boxShadow,
msBoxShadow: boxShadow
}, srIEStyle);
dm.element.setStyle(hook.node, nodeStyle);
hook.node.innerHTML = html;
if (ad.actualTemplate == "iframe") {
var form = dm.element.$("IL_SR_FORM");
if (form) {
form.submit()
}
}
},
yahoo: function(hookId) {
var rt = this.$root,
b = rt.browser,
ut = rt.utils,
dm = ut.dom,
st = rt.settings,
stsr = this.$parent.settings,
data = rt.helpers.getHookData(hookId),
instance = stsr.instance,
hdrCls = "IL_SR_BG",
srPos = "",
srIEStyle = {},
skinPath = this.$parent.getSkinPath(),
sentence, content, tpl, html, nodeStyle, so = window.orientation,
ibh = stsr.behavior.merged,
hook = st.hooksMap[hookId],
themeColor, i;
for (i = 0; i < data.ads.length; i++) {
var pos = data.ads[i].displayedURL.indexOf("/");
if (pos != -1) {
data.ads[i].displayedURL = data.ads[i].displayedURL.substr(0, pos)
}
data.ads[i].title = ut.string.truncateToChar(data.ads[i].title, 52, " ", "...");
data.ads[i].text = ut.string.truncateToChar(data.ads[i].text, 110, " ", "...");
data.ads[i].displayedURL = ut.string.truncate(data.ads[i].displayedURL, 25, "...")
}
content = rt.helpers.parseTokens(hook);
this.$parent.setInsearchStylesheet();
instance.height = ibh.heightClose;
instance.fullWidth = 722;
instance.left = Math.ceil((dm.viewport.getWidth() - instance.fullWidth) / 2);
sentence = ((stsr.prodCode == "o") ? data.sentence : st.impression.params.refq).replace(/</g, "<");
var sentenceTruncated = ut.string.truncate(sentence, 23, "...");
if (stsr.oldIE) {
srPos = "absolute";
srIEStyle = {
top: (dm.viewport.getHeight() + dm.document.getScrollTop() - ibh.heightClose) + "px",
overflow: "hidden"
}
} else {
srPos = "fixed";
srIEStyle = {
bottom: 0
}
}
if (b.Firefox && b.getVersion(true) < 4) {
rt.utils.object.extend(srIEStyle, {
overflow: "hidden"
})
}
themeColor = stsr.themes.color[ibh.theme];
tpl = '<% if (oldIE || oldFF){ %> <img src="<%= skinPath %>in-search-shadow.png" alt="" width="<%= instance.fullWidth+20 %>" height="<%= ibh.heightOpen+10 %>" class="<%= baseCls %>" style="position:absolute; top:-10px; left:-10px; width:<%= instance.fullWidth+20 %>px; height=<%= ibh.heightOpen+10 %>px; overflow:hidden;" /> <% } %> <%-- Header --%> <div id="IL_SR_YAHOO_HEADER" class="<%= baseCls %>" style="position:absolute; top:0; left:0; width:<%= instance.fullWidth %>px; height:34px; background-color:#f0f1f5; cursor: default; border-bottom:1px solid <%= themeColor %>;"> <!-- Results Tab --> <div id="IL_SR_YAHOO_RESULTS_TAB" class="<%= baseCls %>" style="position:absolute; width:450px; height:30px; left:0; top:4px; cursor:pointer; font-size:1px; background-color:#ffffff; border-top:1px solid <%= themeColor %>; border-right:1px solid <%= themeColor %>;"> <div class="<%= baseCls %>" style="padding-left:15px; padding-top:3px; color:<%= ibh.titlePrefixColor %>; font-family: Trebuchet MS,Arial,sans-serif; font-size:13pt; font-weight:normal; font-style:normal; "><%= titlePrefix %> <span class="<%= baseCls %>" title="<%= sentence %>" style="color:<%= ibh.titleTermColor %>; font-weight: bold; font-size:13pt;"><%= sentenceTruncated %></span>?</div> </div> <%-- Search Tab --%> <div id="IL_SR_YAHOO_SEARCH_TAB" class="<%= baseCls %>" style="position:absolute; width:100px; height:29px; left:454px; top:4px; cursor:pointer; font-size:1px; background-color:#ffffff; border-top:1px solid <%= themeColor %>; border-right:1px solid <%= themeColor %>; border-left:1px solid <%= themeColor %>;"> <div class="<%= baseCls %>" style="padding-left:30px; padding-top:3px; color:#4E4E4E; font-family: Trebuchet MS,Arial,sans-serif; font-size:12pt; font-weight:normal; font-style:normal; background:url(<%= skinPath %>search.png) no-repeat scroll 12px 6px transparent;">Search</div> </div> <div class="<%= baseCls %>" style="position:absolute; top:8px; right:44px; width:30px; height:16px; cursor:default; font-size:10pt; color:#4E4E4E;">Ads</div> <div id="IL_SR_YAHOO_HELP" class="<%= baseCls %> IL_SR_BG" style="position:absolute; right:26px; top:9px; width:15px; height:15px; background-position:0 0; cursor:pointer; font-size:1px;"></div> <div id="IL_SR_X" class="<%= baseCls %> IL_SR_BG" style="position:absolute; right:10px; top:9px; width:15px; height:15px; background-position:-15px 0; cursor:pointer; font-size:1px;"></div> </div> <%-- BODY --%> <div style="position:absolute; top:35px; left:0; width:722px; height:125px; background-color:#ffffff; cursor: pointer;" class="<%= baseCls %>" id="IL_SR_AD_AREA"> <div id="IL_SR_YAHOO_RESULTS_CONTENT" class="<%= baseCls %>" style="position:absolute; top:0px; left:0; width:722px; height:125px; "> <div class="<%= baseCls %>" style="margin-left:15px; margin-right:15px; padding-bottom:2px; font-family:Trebuchet MS,Arial,sans-serif; font-size:9pt; color:#99a7c9;">2 results found:</div> <%-- Result 1 --%> <div style="position:relative; padding-bottom:10px; border-bottom:1px solid #eeeeee; margin-left:15px; margin-right:15px;" class="<%= baseCls %>"> <span class="<%= baseCls %>" style="display:inline; color:#1122CC; font-family:Trebuchet MS,Arial,sans-serif; font-size:12pt; font-weight:normal; text-decoration:none;"><%= ads[0].title %></span> <span class="<%= baseCls %>" style="display:inline; color:#222222; font-family:Trebuchet MS,Arial,sans-serif; font-size:11pt; font-weight:normal; text-decoration:none; padding-left:8px;"><%= ads[0].text %></span> <div style="position:absolute; bottom:10px; right:30px; color:#009933; font-family:Trebuchet MS,Arial,sans-serif; font-size:10pt; font-weight:normal; overflow:hidden;" class="<%= baseCls %>"><%= ads[0].displayedURL %></div> </div> <%-- Result 2 --%> <div id="IL_SR_YAHOO_RESULT2" style="position:relative; padding-bottom:10px; padding-left:15px; padding-right:15px;" class="<%= baseCls %>"> <span class="<%= baseCls %>" style="display:inline; color:#1122CC; font-family:Trebuchet MS,Arial,sans-serif; font-size:12pt; font-weight:normal; text-decoration:none;"><%= ads[1].title %></span> <span class="<%= baseCls %>" style="display:inline; color:#222222; font-family:Trebuchet MS,Arial,sans-serif; font-size:11pt; font-weight:normal; text-decoration:none; padding-left:8px;"><%= ads[1].text %></span> <div style="position:absolute; bottom:10px; right:30px; color:#009933; font-family:Trebuchet MS,Arial,sans-serif; font-size:10pt; font-weight:normal; overflow:hidden;" class="<%= baseCls %>"><%= ads[1].displayedURL %></div> </div> </div> <div id="IL_SR_YAHOO_SEARCH_CONTENT" class="<%= baseCls %>" style="display:none; position:absolute; top:0; left:0; width:722px; height:125px; cursor:default;"> <form id="IL_SR_YAHOO_SEARCH_FORM" action="http://search.yahoo.com/search" class="<%= baseCls %>" method="get" name="sf1" role="search"> <img src="<%= skinPath %>yahoo_logo_us_20120910.png" width="202" height="50" alt="" class="<%= baseCls %>" style="position:absolute; display:block; top: 35px; left: 80px;"/> <div class="<%= baseCls %>" style="position:absolute; top:40px; left: 290px; height:30px; padding:4px 6px; border:1px solid #b5bfca; border-radius:7px; background-color:#d8dae2;"> <input type="text" autocomplete="off" value="<%= sentence %>" title="Search" name="p" class="<%= baseCls %>" style="float:left; border:1px inset #cccccc; font-family:Trebuchet MS,Arial,sans-serif; font-size:12pt; height:26px; line-height:26px; width:200px; background-color:#ffffff;"/> <span class="<%= baseCls %>" style="background-color:#FFE572; border:1px solid #DD9715; padding:0; float:left; margin-left:3px; overflow:hidden;"> <button id="IL_SR_YAHOO_SUBMIT_BTN" type="submit" value="Search" class="<%= baseCls %>" style="background-color:transparent; border-style:none; font-family:Trebuchet MS,Arial,sans-serif; font-size:12pt; padding:0; width:100px; cursor:pointer; font-weight:bold; height:26px; line-height:26px; text-align:center; overflow:visible;">Search</button> </span> </div> </form> </div> </div>';
html = ut.VeST(tpl, {
rt: rt,
st: st,
baseCls: st.baseClass,
hdrCls: hdrCls,
ibh: ibh,
instance: instance,
data: data,
ads: data.ads,
content: content,
sentence: sentence,
sentenceTruncated: sentenceTruncated,
skinPath: skinPath,
oldIE: stsr.oldIE,
oldFF: b.Firefox && b.getVersion(true) < 4,
themeColor: themeColor,
titleBase: stsr.themes.tb[ibh.tb],
titlePrefix: rt.helpers.translate(data.tp || ibh.tp),
btnText: rt.helpers.translate(data.bt || ibh.bt)
});
var boxShadow = "0 2px 6px 2px rgba(0, 0, 0, 0.5)";
nodeStyle = ut.object.extend({
position: srPos,
zIndex: st.baseZIndex,
width: instance.fullWidth + "px",
height: instance.height + "px",
left: instance.left + "px",
borderTop: "2px solid " + themeColor,
borderLeft: "1px solid #a7a9ab",
borderRight: "1px solid #a7a9ab",
boxShadow: boxShadow,
MozBoxShadow: boxShadow,
WebkitBoxShadow: boxShadow,
oBoxShadow: boxShadow,
msBoxShadow: boxShadow
}, srIEStyle);
dm.element.setStyle(hook.node, nodeStyle);
hook.node.innerHTML = html;
stsr.selectedTab = "results";
var dmel = rt.utils.dom.element,
prefix = "IL_SR_YAHOO_",
resultsTabId = prefix + "RESULTS_TAB",
searchTabId = prefix + "SEARCH_TAB",
resultsContent = dmel.$(prefix + "RESULTS_CONTENT"),
searchContent = dmel.$(prefix + "SEARCH_CONTENT"),
resultsTab = dmel.$(resultsTabId),
searchTab = dmel.$(searchTabId);
var yahooHelp = dmel.$("IL_SR_YAHOO_HELP");
rt.event.dom.bind(yahooHelp, {
event: "click",
listener: function(event) {
rt.utils.dom.event.stop(event.domEvent);
window.open("http://www.infolinks.com/", "_blank")
}
});
rt.event.dom.bind(yahooHelp, {
event: "mouseover",
data: {
el: yahooHelp,
pos: "0 -15px"
},
listener: this.$parent.setBackgroundPosition
});
rt.event.dom.bind(yahooHelp, {
event: "mouseout",
data: {
el: yahooHelp,
pos: "0 0"
},
listener: this.$parent.setBackgroundPosition
});
rt.event.dom.bind(resultsTab, {
event: "click",
listener: function(event) {
if (stsr.selectedTab == "results") {
rt.utils.dom.event.stop(event.domEvent);
event.$root.products.insearch.yahooClick(event);
return
}
rt.utils.dom.event.stop(event.domEvent);
stsr.selectedTab = "results";
resultsTab.style.height = "30px";
searchTab.style.height = "29px";
searchContent.style.display = "none";
resultsContent.style.display = "block"
}
});
rt.event.dom.bind(searchTab, {
event: "click",
listener: function(event) {
rt.utils.dom.event.stop(event.domEvent);
stsr.selectedTab = "search";
resultsTab.style.height = "29px";
searchTab.style.height = "30px";
resultsContent.style.display = "none";
searchContent.style.display = "block"
}
});
rt.event.dom.bind(dmel.$("IL_SR_YAHOO_HEADER"), {
event: "click",
listener: function(event) {
rt.utils.dom.event.stop(event.domEvent)
}
});
rt.event.dom.bind(dmel.$("IL_SR_YAHOO_SEARCH_CONTENT"), {
event: "click",
listener: function(event) {
rt.utils.dom.event.stop(event.domEvent)
}
});
rt.event.dom.bind(dmel.$("IL_SR_YAHOO_RESULT2"), {
event: "click",
listener: function() {
hook.currentAdIndex = 1
}
});
rt.event.dom.bind(dmel.$("IL_SR_YAHOO_SUBMIT_BTN"), {
event: "click",
listener: function() {
dmel.$("IL_SR_YAHOO_SEARCH_FORM").submit()
}
})
}
}, {});
var inframe = products.$create("inframe", {
getPageMargins: function() {
var rt = this.$root,
stif = this.settings,
dm = rt.utils.dom,
wrapper = dm.findWidestNode(),
result = {
left: 0,
right: 0
};
if (wrapper && wrapper.node != document.body) {
var offset = dm.element.offset(wrapper.node);
var width = dm.element.getActualWidth(wrapper.node);
var docWidth = dm.document.getWidth();
result = {
left: offset.left - stif.buffer,
right: docWidth - width - offset.left - 2 * stif.buffer
}
}
return result
},
buildImpPageMarginsParam: function() {
var stif = this.settings,
stifw = stif.width,
margins = stif.margins = this.getPageMargins();
return [margins.left > stifw.thin ? margins.left > stifw.wide ? "w" : "t" : "", margins.right > stifw.thin ? margins.right > stifw.wide ? "w" : "t" : ""].join("*").replace(/^\*$/, "")
},
buildGetadsPageMarginsParam: function(bs) {
var uta = this.$root.utils.array,
stif = this.settings,
instance = stif.instance,
arr = [];
if (/THIN|AUTO/.test(bs)) {
uta.push(arr, stif.width.thin, "*", stif.height)
}
if ((instance.left || instance.right).width >= stif.width.wide && /WIDE|AUTO/.test(bs)) {
uta.push(arr, arr.length ? "~" : "", stif.width.wide, "*", stif.height)
}
return arr.join("")
},
renderUnit: function(side) {
var rt = this.$root,
ut = rt.utils,
dm = ut.dom,
dms = dm.style,
dmel = dm.element,
st = rt.settings,
stif = this.settings,
b = rt.browser,
instance = stif.instance,
html, bh = stif.behavior.merged,
skinPath = this.getSkinPath(),
bgCss, bgCls = "IL_IF_BG",
hook = instance[side].hook,
hookId = hook.id,
data = rt.helpers.getHookData(hookId),
ad, content = "",
node = dmel.$("IL_IF_" + side.toUpperCase()),
i, adsTpl = "",
src = "",
adsHTML = "";
var template = rt.utils.array.map(data.ads, function(item) {
return item.template
})[0];
for (i = 0; i < data.ads.length; i++) {
ad = data.ads[i];
hook.currentAdIndex = ad.midx;
rt.helpers.setActualTemplate(ad);
if (/iframe|external/.test(ad.actualTemplate)) {
adsTpl = '<iframe name="IL_IF_FRAME_<%= sideUpper %>" class="<%= baseCls %>" src="<%= src %>" width="<%= width %>" height="<%= height %>" frameborder="0" scrolling="no"></iframe>';
if (ad.contentUrl) {
src = rt.helpers.parseTokens(hook, ad.contentUrl)
} else {
src = st.blankURL;
content = rt.helpers.parseTokens(hook, ad.content);
adsTpl += '<%= rt.helpers.getEchoForm(content, "IL_IF_FRAME_" + sideUpper, "IL_IF_FORM_" + sideUpper) %>'
}
adsHTML += ut.VeST(adsTpl, {
rt: rt,
baseCls: st.baseClass,
sideUpper: side.toUpperCase(),
src: src,
width: instance[side].width,
height: stif.height,
content: content
})
} else {
if (ad.actualTemplate == "text") {
adsTpl = '<div class="<%= baseCls %> IL_IF_AD" data-midx="<%= ad.midx %>" style="overflow:hidden; padding:<% if (adIndex==0){ %>30px 7px <% } %>15px 7px;<% if(adIndex==numOfAds-1){ %>height:600px;<% } %>"> <div class="<%= baseCls %>" style="color:#1122CC; font-family:Arial,sans-serif; font-size:11pt; font-weight:bold; line-height:11pt; padding-bottom:2px; max-height:22pt; overflow:hidden;"><%= ad.title %></div> <div class="<%= baseCls %>" style="color:#666666; font-family:Arial,sans-serif; font-size:10pt; font-weight:normal; line-height:13pt; padding-bottom:2px;"><%= ad.text %></div> <div class="<%= baseCls %>" style="color:#009933; font-family:Arial,sans-serif; font-size:9pt; font-weight:normal; text-decoration:underline; padding-bottom:2px; overflow:hidden; white-space:nowrap;"><%= ad.displayedURL %></div> </div>';
adsHTML += ut.VeST(adsTpl, {
baseCls: st.baseClass,
ad: ad,
adIndex: i,
numOfAds: data.ads.length
})
} else {
adsHTML += rt.helpers.parseTokens(instance[side].hook, ad.content)
}
}
}
if (b.IE && b.getVersion(true) < 8) {
bgCss = skinPath + "hdr-btns.png"
} else {
bgCss = "data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAB4AAAAeCAYAAAA7MK6iAAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAAB+hJREFUeNrEV3tMm9cVP7Y/29gY/MBvg3klgFJGAnFeBUpok03NOhJeaVcSdVvGEu2fbdqmNm23bkmqRk1bbVm0PiKtTaVtSkLTh9SQlLY0CWSDpkugy8MmCY+AwRiwzbDBYJudc+FzP0e0+W+70pG/ex733Hvuub9zLPr9/gPAj/n5edDr9TA2NmbG6fJF9i3kuZEHIpEorvvbZ59hv7y9WCyGWCwGJpMJPB5PBrKykWJITp1O652Y8DE9fg0OEscGpIOl999fbjQaUEMEXq8Xbjid7ch/Guk8fPP4DtKBB8rLHXp9Gm5knjYRc7qcnyD/KaR/8YpCx3vWrllzZN26tRIJ7p4fmfYMKCkuLv380qXWf3Z0/AxZR77G6TMPlJftL161SiSMTFamXby6pGRz+8WLFZevXPkRsv4qdFyBix9ZuXKlZGYmzBh+v5+FXqvVsnlhYaE4Eo0cvnTpCydOW+5yWrdhw/oD+fkFEJqeWXJXDodDFolE/vLvq1ev08m55ORkkMvkLxcUFEimF40+bvkYOjo62HdJSQk8vOVh9p2fly/q6+v/QzAYvE+wpsRisbycnZUDZD/q8YA8SQ5qtYYJMdSQtDgvLPyWrH9g4EWplNtEMc2z2qyrZ2dnIRyewcTyQmdnJzz51K9h794nobu7G0ZGRpgsHA6D1WpdgTZFvFeZTFaabrPZF+Qz4Ha74bXXXofhYTc4nTfg6BtHYXJykskikTmyfxDNzFw0EimkU/Mhlkg42LZtKwSD00CbofuibOXlqmQV8Urws3vBsdQhtF+etxzm5ubg2Ftvo6MI7NjRwE7Ly1FX1NMTyOPkSUkKUiAn/DAYjeByuqC19VNYsWIFyOXyuBzvGRQKhSoeZwknj0SicTn9yBVJbJ6UlASRWJRFih9R1MWDiLg0ne5OIDAJKSkpCckQDE1BUVERONY4YCb8VcIEAgFIVipd/BxP0OsP+EEqk7I5hfps81loaHic8ABOHj8J1TXVkJK6sH4Aw45ZPinChy1veueUJzc3Vy10HJ5ZcIYRSdjQzVs3p6q3VlkMBsMUzZ0ul+n8hbaB3JxcGXM8NIQRM4AMo8ThtY16RhAOxOx1zKP89q2b7sYf78qg5Aqr1al/HB4exjBG4xSbj7GwCnkjuAjqvoo2U4K9eJRKxTEvno50bOnpIEaHc3MRmMbNa7Q6JC2TDQ4OEjK+RIgmordKBzt+sukTVC4lyFxqjI+PI6bGOhoe/34lTqd5/sxCZNRo34a5UKjRaJe0p2elUinP1lZXf5eumnfMEvZ085lXh9zuBsw3kVKpBAKgUCjEFjebTccf2bJlN12TcMFFx5Tp+rMftbzpGR19hGwVCiUCUAxfRwgTLRyzZ6Qf/fbmzT8nk7shk8K389H6ukNd3d31Pp+/gJho4EIYbDp34cLle+D0GNL36mtr1l3p6qqZnPxPLpaOWG5O1tXiVcXH29rbbgiVhSf+nw4x/J8Gt+/A8wn1eHEzhEz5FBF6MUhfUCbyNZfGc795NqEecxzHkIowBWkt0jJKIqRrSF20/DfV49qUlNRDaWm6bEoQGqHQNExMjPcj3u7F6d/vcZBdGo1mn1arsyoQvegcWFDI3jk1NfULlDcvVY9/l5WV9ZzRaEpYSaVKAaPRmInF4299fX1UHPYu4ZCO8edly5bv0el0CQJCRLPZnI848eGdOwO/QtYrwjveSk7NZgtrYYgI7sa8Y/E5bSg7O5u6iMeWcLwbkW8PYQCvfzfZbDaR3W4n8KhkJ0bAB6lU9qLVaouvcrG9HaFulBmkYQtTWlbG+LSx8fGJF/x+34nFfoqBT1qafr9eb2ATQkCZVMbsaAwhWimxehFkpqdniHw+30EspevoxEWIu3lSTA6iWawkg3cG4Qc/fAJ27twBHqzFM9Mh4OXYi2WhoYPfJKJVhclk1PPyZKUCmk+fhglEut7bt+H8ufNYSpOZTCaVgj5NT4mXyeHl5KtTU+PVRSvTwqOP1cMs1lRKDCpvKrwnXq7B2orO6K47aS6VSldiQsXlVpsNtm+vgxMnmjDTJdDYuCseGnbnWKX6B/qzOKwiHMd2I4sL1WotuFwuONN8BjZteghSMMF4oCFddBxXxrlEykkT7Cd8fqzTEpZz3rFxwNYIBPpMJraYzX2hUJAVeyHRm9y4cSOsdjiovYnzg6ir0aivfZW1KmdQYN/X18t6tp/sboR6PPmpd06xGs7LQxhF7GbHCDIlb751bKi0tNQkbEspuQgszBZzAsBgm+rbVlVl0Wo1rK3o7x/QII67N6xfr6B5b28vqFPVoEvTMbCg+sxhRKhGx6IxaP9H+217hj2XkiuKz+BgT08PKLDo84QlDFiVEfBoUa1Gc4hquODa/Cg7TLWWdKhVstms7DsJT5iTkwP2TDubX8fmz2K27KeejC8S4nffe78J25hqbEsS/qrwJ73cdYV67Q/qampqFqFQOOQnTjY149+XysLC+/BmE+0pch2fd0I0Gn0b8+GJu6sT99m5c/uwk/glprwMn8hCAR8dBe+odxb/kvzpwcpK+hsz+zVwqfyopeUlfyDQaDaZOYNBzxyOYAMwMT4xjfX8+fKyshf49y+ETEL4p+traw9fvXatyu0ezqONWSzmm5UVFe9/2trqvgdOh5B+ur2u7mD3l19WDQ25cygyGRnp1x+qrPzgQlvbmFD5vwIMAAZsT2nNzBrxAAAAAElFTkSuQmCC"
}
dms.addRule("." + bgCls, ['background-image : url("', bgCss, '")'].join(""));
var otherSide = (side == "left") ? "right" : "left";
var themeColor = stif.themes.color[bh.theme];
var tpl = '<div class="<%= baseCls %>" style="position:absolute; top:0; <%= otherSide %>: 0; width:<%= width %>px; height:<%= height+32 %>px; border-bottom: 2px solid <%= themeColor %>;<% if (template == "text"){ %>border-<%= otherSide %>:1px solid #cccccc;<% } %>"> <%-- unit --%> <div class="<%= baseCls %> IL_IF_AD_AREA" data-midx="<%= midx %>" style="position:absolute; top:0; left:0; width:<%= width %>px; height:<%= height %>px; text-align:center; overflow:hidden;"> <%= adsHTML %> </div> <%-- footer --%> <div class="<%= baseCls %> IL_IF_FOOTER" style="position:absolute; bottom:0; left:0; width:<%= width %>px; height:32px; cursor: pointer; background-color:#f1f1f2;"> <div id="IL_IF_LOGO_<%= sideUpper %>" class="<%= baseCls %>" style="position:absolute; width:53px; height:12px; top:9px; <%= side %>:10px; cursor:pointer; font-size:1px; <% if (oldIE || oldFF){ %>background:url(<%= skinPath %>logo.png) no-repeat scroll 0 0 transparent;<% } %>"> <% if (!oldIE && !oldFF){ %> <svg version="1.1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" x="0px" y="0px" width="53px" height="12px" viewBox="0 0 636 144" enable-background="new 0 0 636 144" xml:space="preserve"> <g> <!-- dot (first) --> <path id="IL_IF_LOGO_<%= sideUpper %>_LOGO_DOT_1" fill="<%= bh.theme == \'def\' ? \'#208CE5\' : themeColor %>" d="M16.918,24.865c5.848,0,10.57-4.735,10.57-10.583s-4.722-10.57-10.57-10.57 S6.334,8.434,6.334,14.282S11.07,24.865,16.918,24.865"/> <!-- in --> <path fill="#003366" d="M88.085,43.784H77.024c-17.149,0-31.181,14.031-31.181,31.182v34.796 c0,0.218,0.016,0.415,0.027,0.618v5.185c0,5.71-4.672,10.382-10.382,10.382h-0.467c-5.71,0-10.382-4.672-10.382-10.382V92.608 h0.015V45.889v-0.025c0-1.124-0.885-2.033-2.01-2.08h-11.49c-1.09,0.047-1.949,0.907-1.986,1.996v46.828h0.04 c-0.015,0.355-0.04,0.707-0.04,1.066v22.246c0,14.031,11.479,25.512,25.511,25.512h1.151c14.031,0,25.511-11.48,25.511-25.512 v-5.466v-4.62v-28.89c0.082-9.872,8.159-17.948,18.031-17.948h6.366c9.871,0,17.948,8.076,18.042,17.948v28.89v4.62v28.873 c0.013,0.023,0.013,0.034,0.013,0.048c0,1.111,0.883,2.008,1.983,2.057h11.505c1.077-0.036,1.936-0.887,1.985-1.973v-27.966v-5.659 V74.966C119.267,57.815,105.234,43.784,88.085,43.784"/> <!-- f (part) --> <path fill="#003366" d="M155.069,56.972v82.643c-0.072,0.992-0.886,1.78-1.903,1.818h-11.014 c-1.062-0.038-1.912-0.897-1.912-1.962c0-0.024,0-0.048-0.023-0.073V34.456c0.716-17.064,14.923-30.744,32.179-30.744h8.536 c0.025,0,0.038,0.011,0.06,0.011c1.053,0,1.915,0.849,1.974,1.901v11.037c-0.035,1.016-0.85,1.844-1.878,1.889h-8.692 c-9.509,0-17.327,7.75-17.327,17.268v6.301V56.972z"/> <!-- f (part) --> <path fill="#003366" d="M151.99,59.104h28.873c0.023-0.012,0.034-0.012,0.047-0.012 c1.111,0,2.008-0.884,2.057-1.984V45.604c-0.036-1.078-0.887-1.938-1.973-1.986h-27.965"/> <!-- o --> <path fill="#003366" d="M276.24,107.925h0.158V76.608c-0.37-18.164-15.248-32.825-33.494-32.825 h-16.756v0.022c-17.875,0.431-32.322,14.924-32.679,32.803h-0.026v31.316c0,18.213,14.601,33.064,32.705,33.496v0.012h16.589h0.021 h0.146C261.304,141.349,276.24,126.354,276.24,107.925 M208.93,107.925L208.93,107.925V77.289c0-9.914,8.096-18.02,18.021-18.02 h15.953c9.946,0,18.02,8.106,18.02,18.02v30.636h-0.167c0,9.949-8.074,18.021-17.999,18.021h-15.807 C217.026,125.946,208.93,117.874,208.93,107.925"/> <!-- l --> <path fill="#003366" d="M312.844,139.376L312.844,139.376c0,1.064-0.798,1.938-1.829,2.045h-11.816 c-1.027-0.107-1.837-0.98-1.837-2.045h-0.013V5.769h0.013c0-1.135,0.908-2.033,2.031-2.057h11.432 c1.124,0.024,2.019,0.922,2.019,2.057V139.376z"/> <!-- dot (second) --> <path id="IL_IF_LOGO_<%= sideUpper %>_LOGO_DOT_2" fill="<%= bh.theme == \'def\' ? \'#208CE5\' : themeColor %>" d="M341.662,24.865c5.848,0,10.57-4.735,10.57-10.583s-4.723-10.57-10.57-10.57 s-10.584,4.722-10.584,10.57S335.814,24.865,341.662,24.865"/> <!-- in (second) --> <path fill="#003366" d="M412.829,43.784h-11.061c-17.149,0-31.181,14.031-31.181,31.182v34.796 c0,0.218,0.016,0.415,0.026,0.618v5.185c0,5.71-4.672,10.382-10.382,10.382h-0.468c-5.71,0-10.382-4.672-10.382-10.382V92.608 h0.016V45.723v-0.025c0-1.123-0.885-2.033-2.01-2.08h-11.49c-1.091,0.047-1.949,0.908-1.986,1.996v46.994h0.04 c-0.015,0.355-0.04,0.707-0.04,1.066v22.246c0,14.031,11.479,25.512,25.512,25.512h1.15c14.031,0,25.512-11.48,25.512-25.512 v-5.466v-4.62v-28.89c0.082-9.872,8.158-17.948,18.029-17.948h6.367c9.871,0,17.947,8.076,18.041,17.948v28.89v4.62v28.873 c0.014,0.023,0.014,0.034,0.014,0.048c0,1.111,0.883,2.008,1.982,2.057h11.506c1.076-0.036,1.936-0.887,1.984-1.973v-27.966v-5.659 V74.966C444.01,57.815,429.979,43.784,412.829,43.784"/> <!-- k --> <path fill="#003366" d="M480.277,139.376L480.277,139.376V91.735h0.146h9.255l40.656,48.766 c0.599,0.549,1.15,0.906,1.841,0.932h16.073c0.882-0.025,2.869-0.322,1.794-2.056l-0.013-0.024l-47.58-56.777l44.599-36.815 c0.015-0.049,0.015-0.049,0.036-0.073c1.066-1.734-0.886-2.032-1.78-2.069H527.08c-0.621,0.024-1.15,0.324-1.666,0.791 l-36.812,31.075h-8.325V5.769c0-1.135-0.896-2.033-2.02-2.057h-11.422c-1.124,0.024-2.033,0.922-2.033,2.057v133.607 c0,1.064,0.803,1.938,1.844,2.045h11.802C479.476,141.313,480.277,140.44,480.277,139.376"/> <!-- s --> <path fill="#003366" d="M603.208,84.782H577.99c-6.91-0.114-12.508-5.785-12.508-12.783 c0-6.996,5.598-12.895,12.508-12.895h39.271c1.146,0,2.08-0.959,2.08-2.111v0.191V45.752v-0.037c0-1.164-0.935-2.097-2.08-2.097 H577.99c-15.451,0-28.008,12.73-28.008,28.381c0,15.651,12.557,28.381,28.008,28.27h24.252c6.911,0.111,12.508,5.812,12.508,12.795 c0,6.996-5.597,12.896-12.508,12.896H591.56l0.001-0.014h-28.874c-0.022,0.014-0.034,0.014-0.047,0.014 c-1.11,0-2.007,0.896-2.056,2.01v11.449c0.035,1.092,0.886,1.963,1.973,2.014h0.225h27.74h12.224 c15.209-0.279,27.491-12.9,27.491-28.369C630.236,97.737,618.191,85.202,603.208,84.782"/> </g> </svg> <% } %> </div> <div id="IL_IF_HELP_<%= sideUpper %>" class="<%= baseCls %> <%= cls %>" style="width:15px; height:15px; position:absolute; top:9px; <%= otherSide %>:27px; background-position:0 0; cursor:pointer; font-size:1px;"></div> <div id="IL_IF_X_<%= sideUpper %>" class="<%= baseCls %> <%= cls %>" style="width:15px; height:15px; position:absolute; top:9px; <%= otherSide %>:9px; background-position:-15px 0; cursor:pointer; font-size:1px;"></div> </div> </div>';
html = ut.VeST(tpl, {
side: side,
sideUpper: side.toUpperCase(),
bh: bh,
baseCls: st.baseClass,
cls: bgCls,
otherSide: otherSide,
width: instance[side].width,
height: stif.height,
adsHTML: adsHTML,
themeColor: themeColor,
oldIE: stif.oldIE,
oldFF: b.Firefox && b.getVersion(true) < 4,
skinPath: skinPath,
template: template,
midx: data.ads[0].midx
});
var nodeStyle = {
position: stif.oldIE ? "absolute" : "fixed",
top: stif.oldIE ? dm.document.getScrollTop() : 0,
width: 0,
height: stif.height + 34 + "px",
overflow: "hidden",
display: (stif.margins[side] < instance[side].width) ? "none" : "block",
cursor: "pointer",
backgroundColor: "#FFFFFF"
};
nodeStyle[side] = 0;
dmel.setStyle(node, nodeStyle);
node.innerHTML = html;
if (ad.actualTemplate == "iframe") {
var form = dm.element.$("IL_IF_FORM_" + side.toUpperCase());
if (form) {
form.submit()
}
}
this.setUnitEventHandlers(side)
},
getSkinPath: function() {
var stif = this.settings;
return ["http:/", this.$root.settings.hosts.resources, "static", "skins", stif.skin, stif.prodName, stif.rv, ""].join("/")
},
setGeneralEventHandlers: function() {
var evdm = this.$root.event.dom;
evdm.bind(window, {
event: "scroll",
listener: this.scrollHandler
});
evdm.bind(window, {
event: "resize",
listener: this.resizeHandler
})
},
setUnitEventHandlers: function(side) {
var rt = this.$root,
st = rt.settings,
ut = rt.utils,
stif = this.settings,
dm = ut.dom,
dmel = dm.element,
evdm = rt.event.dom,
hook = stif.instance[side].hook,
node = hook.node,
data = rt.helpers.getHookData(hook),
midx, i;
var xBtn = dmel.$(stif.prodId + "_X_" + side.toUpperCase());
if (xBtn) {
evdm.bind(xBtn, {
event: "click",
data: {
side: side
},
listener: function(event) {
rt.event.repeat("effectSlideClose", stif.animationInterval, event.data)
}
});
evdm.bind(xBtn, {
event: "mouseover",
data: {
el: xBtn,
pos: "-15px -15px"
},
listener: this.setBackgroundPosition
});
evdm.bind(xBtn, {
event: "mouseout",
data: {
el: xBtn,
pos: "-15px 0"
},
listener: this.setBackgroundPosition
})
}
var ifLogo = dmel.$(stif.prodId + "_LOGO_" + side.toUpperCase());
if (ifLogo) {
evdm.bind(ifLogo, {
event: "click",
listener: function(event) {
rt.utils.dom.event.stop(event.domEvent);
if (st.homeUrl) {
window.open(st.homeUrl, "_blank")
}
}
})
}
var helpBtn = dmel.$(stif.prodId + "_HELP_" + side.toUpperCase());
if (helpBtn) {
evdm.bind(helpBtn, {
event: "click",
listener: function(event) {
rt.utils.dom.event.stop(event.domEvent);
if (st.helpUrl) {
window.open(st.helpUrl, "_blank")
}
}
});
evdm.bind(helpBtn, {
event: "mouseover",
data: {
el: helpBtn,
pos: "0 -15px"
},
listener: this.setBackgroundPosition
});
evdm.bind(helpBtn, {
event: "mouseout",
data: {
el: helpBtn,
pos: "0 0"
},
listener: this.setBackgroundPosition
})
}
var adNodes = ut.dom.filterByClass("IL_IF_AD", null, node);
if (!adNodes.length) {
adNodes = ut.dom.filterByClass("IL_IF_AD_AREA", null, node)
}
if (!adNodes.length) {
adNodes = [node]
}
for (i = 0; i < adNodes.length; i++) {
midx = adNodes[i].getAttribute("data-midx");
midx = midx ? parseInt(midx) : hook.currentAdIndex;
evdm.bind(adNodes[i], {
event: "click",
data: {
hookId: hook.id,
midx: midx
},
listener: this.inframeClick
})
}
},
scrollHandler: function() {
var stif = this.settings,
dm = this.$root.utils.dom,
side, node;
var viewport = dm.viewport.getHeight();
var height = stif.height + 34;
var scroll = dm.document.getScrollTop();
for (side in stif.instance) {
node = stif.instance[side].hook.node;
if (viewport > height) {
if (stif.oldIE) {
node.style.position = "absolute";
node.style.top = scroll + "px"
} else {
node.style.position = "fixed";
node.style.top = 0
}
} else {
node.style.position = "absolute";
if (scroll == 0) {
node.style.top = "0"
} else {
if (scroll >= height - viewport) {
node.style.top = (scroll - height + viewport) + "px"
}
}
}
}
},
resizeHandler: function() {
var side, margins = this.getPageMargins(),
instance = this.settings.instance;
for (side in instance) {
instance[side].hook.node.style.display = margins[side] > instance[side].width ? "block" : "none"
}
},
setBackgroundPosition: function(event) {
event.data.el.style.backgroundPosition = event.data.pos
},
inframeClick: function(event) {
var rt = this.$root,
st = rt.settings,
stif = rt.products.inframe.settings,
hookId = event.data.hookId,
hook = st.hooksMap[hookId],
data = rt.helpers.getHookData(hookId),
parent, side, node, ad = rt.helpers.getAdByMidx(data.ads, event.data.midx);
hook.currentAdIndex = event.data.midx;
rt.event.stop("effectSlideOpen");
rt.event.disable("effectSlideOpen");
rt.event.stop("effectSlideClose");
rt.event.disable("effectSlideClose");
rt.event.dom.unbind(window, "scroll", this.scrollHandler);
rt.event.dom.unbind(window, "resize", this.resizeHandler);
for (side in stif.instance) {
node = stif.instance[side].hook.node;
parent = node.parentNode;
parent.removeChild(node)
}
if (ad.template != "text" && ad.content.match(/<object |<embed /i) && ad.content.match(/clicktag/i)) {
return
}
rt.utils.timer.stop("adView" + hookId);
var reuseWindow = rt.helpers.getHookBehavior(hookId).adsReuseWindow;
if (!reuseWindow) {
try {
rt.settings.adWin = window.open("", hookId)
} catch (ex) {
rt.settings.adWin = null
}
}
rt.event.fire("productClick", {
hookId: hookId,
clickType: "onWin"
})
}
}, {
settings: {
prodId: "IL_IF",
prodCode: "f",
prodName: "inframe",
width: {
thin: 120,
wide: 160
},
height: 600,
effect: "slide",
buffer: 15,
instance: {},
behavior: {
def: {
ifp: "DOUBLE",
bs: "AUTO",
theme: "def"
}
},
themes: {
color: {
def: "#003366",
lightBlue: "#1b8ede",
green: "#67b045",
orange: "#f3933b",
red: "#dd3c42",
pink: "#d84189",
purple: "#5939aa"
}
},
sentences: {},
oldIE: (function() {
var b = $root.browser;
return (b.IE && (document.compatMode == "BackCompat" || b.getVersion(true) < 9))
}()),
skin: "brand",
rv: "1",
animationInterval: $root.browser.IE ? 7 : 10,
bidRequestTimeout: 750
}
}, true);
inframe.bind({
event: "renderProduct",
listener: {
renderInframe: function() {
var rt = this.$root,
st = rt.settings,
imp = rt.comm.settings.responses.impression,
stif = this.settings,
stifw = stif.width,
bh = stif.behavior,
instance = stif.instance,
prodCode = stif.prodCode,
prod = imp.prs[prodCode];
if (!prod || !prod.sentences || !prod.sentences.length) {
rt.event.fire("productRenderStatus", {
prod: prodCode,
status: "none"
});
return
}
var margins = stif.margins,
side, result = {
left: 0,
right: 0
},
bhm = bh.merged = rt.utils.object.extend({}, st.behavior.def, bh.def, st.behavior.impression, imp.prs[prodCode].behavior, st.behavior.customer, {
adsReuseWindow: true
});
for (side in result) {
if ((new RegExp(side.toUpperCase() + "|DOUBLE")).test(bhm.ifp)) {
result[side] = /WIDE|AUTO/.test(bhm.bs) && margins[side] >= stifw.wide ? stifw.wide : /THIN|AUTO/.test(bhm.bs) && margins[side] >= stifw.thin ? stifw.thin : 0
}
}
if (bhm.ifp == "SINGLE") {
var sizes = {
thin: 1,
wide: 1
},
size;
for (size in sizes) {
if ((new RegExp(size.toUpperCase() + "|AUTO")).test(bhm.bs)) {
side = margins.left >= stifw[size] && margins.right >= stifw[size] ? ["left", "right"][Math.floor(Math.random() * 2)] : margins.left > stifw[size] ? "left" : margins.right > stifw[size] ? "right" : null;
if (side) {
result[side] = stifw[size]
}
}
}
if (result.left && result.right) {
if (result.left < result.right) {
result.left = 0
} else {
result.right = 0
}
}
}
if (Math.min(result.left, result.right) > 0 && result.left != result.right) {
result.left = result.right = Math.min(result.left, result.right)
}
for (side in result) {
if (result[side]) {
instance[side] = {
width: result[side]
}
}
}
if (!(instance.left || instance.right)) {
rt.event.fire("productRenderStatus", {
prod: prodCode,
status: "none"
})
} else {
rt.event.fire("productRenderStatus", {
prod: prodCode,
status: "during"
});
rt.event.fire("initInframe")
}
}
}
});
inframe.bind({
event: "initInframe",
listener: {
init: function() {
var rt = this.$root,
ut = rt.utils,
stif = this.settings,
resImp = rt.comm.settings.responses.impression,
sentenceIndex = resImp.prs[stif.prodCode].sentences[0],
instance = stif.instance,
side, node, id;
stif.sentence = ut.object.keys(resImp.sentences)[sentenceIndex];
for (side in instance) {
id = [stif.prodId, side.toUpperCase()].join("_");
node = ut.dom.createDOMFragment({
tag: "div",
id: id,
cls: [rt.settings.baseClass, stif.prodId].join(" "),
parent: document.body
});
instance[side].hook = rt.helpers.createHook(id, stif.sentence, node, 0, this, stif.prodCode, stif.prodName, false, instance[side])
}
rt.event.fire("getAds", {
hookId: (instance.left || instance.right).hook.id,
params: {
as: this.buildGetadsPageMarginsParam(stif.behavior.merged.bs),
nm: (instance.left && instance.right) ? 2 : 1
},
bidRequestTimeout: stif.bidRequestTimeout,
callback: "getadsResponseInframe"
})
}
}
});
inframe.bind({
event: "getadsResponseInframe",
listener: {
setAdData: function(event) {
var rt = this.$root,
response = event.data,
data = {},
hook, ad, stif = this.settings,
instance = stif.instance,
side, i, numOfAds = response.ads.length,
hasTextAds = false;
if (!numOfAds) {
rt.event.fire("productRenderStatus", {
prod: stif.prodCode,
status: "failed",
reason: "received no ads."
});
return false
} else {
for (i = 0; i < numOfAds; i++) {
ad = response.ads[i];
ad.midx = i;
if (ad.trackerURL) {
rt.helpers.hitTrackerURL(ad.trackerURL)
}
if (ad.template == "text") {
hasTextAds = true
}
}
}
if (numOfAds == 2 && !hasTextAds) {
response.divide = true
}
stif.adViewParams = {
midx: rt.utils.array.range(0, numOfAds - 1).join("~"),
bdc: rt.utils.array.times((instance.left || instance.right).hook.bdc, numOfAds).join("~"),
emd: rt.utils.array.map(response.ads, function(ad) {
return ad.emd || ""
}).join("~")
};
if (instance.left && instance.right) {
instance.right.hook.bdc = instance.left.hook.bdc;
if (instance.left.hook.externalTag) {
instance.right.hook.externalTag = instance.left.hook.externalTag
}
data.left = response;
data.right = rt.utils.object.clone(response, true);
if (response.divide) {
var division = Math.ceil(numOfAds / 2);
data.left.ads.splice(division, numOfAds);
data.right.ads.splice(0, division)
}
} else {
for (side in instance) {
data[side] = response
}
}
for (side in instance) {
hook = instance[side].hook;
if (response.width > -1) {
instance[side].width = response.width
}
ad = data[side].ads[hook.currentAdIndex];
if (ad && ad.template == "external") {
data[side] = rt.externalTags.setExternalTagData(hook, data[side])
}
rt.helpers.setHookData(hook.id, data[side]);
if (hook.externalTag) {
rt.externalTags.updateViewedTags(hook.id)
}
}
rt.event.fire("createInframe")
}
}
});
inframe.bind({
event: "createInframe",
listener: {
createInframe: function() {
var rt = this.$root,
stif = this.settings,
side;
for (side in stif.instance) {
this.renderUnit(side)
}
this.setGeneralEventHandlers();
rt.event.repeat("effectSlideOpen", stif.animationInterval);
rt.event.fire("productRenderStatus", {
prod: stif.prodCode,
status: "after"
})
}
}
});
inframe.bind({
event: "effectSlideOpen",
listener: {
effectSlideOpen: function() {
var rt = this.$root,
stif = this.settings,
ut = rt.utils,
dmel = ut.dom.element,
b = rt.browser,
instance = stif.instance,
newWidth, side, hook;
var currentWidth = parseInt(dmel.getStyle((instance.left || instance.right).hook.node, "width"));
var endWidth = (instance.left || instance.right).width;
if (currentWidth >= endWidth) {
rt.event.stop("effectSlideOpen");
for (side in instance) {
hook = instance[side].hook;
rt.utils.timer.start("adView" + hook.id)
}
rt.event.fire("sendAdView", {
hookId: hook.id,
params: {
prod_t: hook.prod,
bdc: stif.adViewParams.bdc,
midx: stif.adViewParams.midx,
emd: stif.adViewParams.emd
}
});
return
}
newWidth = b.IE && b.getVersion(true) < 7 ? endWidth : Math.min(currentWidth + 2, endWidth);
for (side in instance) {
dmel.setStyle(instance[side].hook.node, {
width: newWidth + "px"
})
}
}
}
});
inframe.bind({
event: "effectSlideClose",
listener: {
effectSlideClose: function(event) {
var rt = this.$root,
stif = this.settings,
dmel = rt.utils.dom.element,
b = rt.browser,
side = event.data.side,
node = stif.instance[side].hook.node;
var current = parseInt(dmel.getStyle(node, "width"));
if (current <= 0) {
rt.event.stop("effectSlideClose");
node.parentNode.removeChild(node);
delete stif.instance[side];
return
}
var width = b.IE && b.getVersion(true) < 7 ? 0 : Math.max(current - 2, 0);
dmel.setStyle(node, {
width: width + "px"
})
}
}
});
var externalTags = $root.$create("externalTags", {
init: function() {
var rt = this.$root,
imp = rt.comm.settings.responses.impression,
i, leni, ut = rt.utils,
uta = ut.array,
uto = ut.object,
ad, etst = this.settings;
if (!imp.messages) {
return
}
if (rt.browser.isMobile()) {
delete imp.messages;
return
}
etst.bidCallbackVar = (rt.settings.white_label || "infolinks") + "_etag";
for (i = 0, leni = imp.messages.length; i < leni; i++) {
ad = imp.messages[i].ads[0];
ad.prs = uta.toObject(ad.prs ? ad.prs.split(",") : uta.discard(uta.discard(uto.keys(imp.prs), "s"), "o"), {}, true);
imp.messages[i].msg = i;
if (ad.emd) {
etst.tags[ad.emd] = imp.messages[i]
}
}
},
getProductAdSizes: function(prod, hook) {
switch (prod) {
case "i":
return [{
w: 300,
h: 250
}];
case "r":
return [{
w: 300,
h: 250
}];
case "t":
return [{
w: 300,
h: 250
}];
case "s":
return [{
w: 728,
h: 90
}];
case "o":
return [{
w: 728,
h: 90
}];
case "f":
return [{
w: hook.instance.width || 160,
h: 600
}]
}
},
setExternalTagData: function(hook, data) {
var uto = this.$root.utils.object,
cai = hook.currentAdIndex,
ad = data.ads[cai];
if (ad.content) {
ad.content = this.$root.utils.base64.decodeBase64(ad.content);
hook.externalTag = true
} else {
if (ad.url || ad.contentUrl) {
if (ad.url) {
ad.contentUrl = ad.url
}
hook.externalTag = true
} else {
var bidInvocation = hook.externalTag,
etst = this.settings,
emd = data.ads[cai].emd,
tag = etst.tags[emd],
i, leni, responses = etst.bidResponses[bidInvocation];
for (i = 0, leni = responses.length; i < leni; i++) {
if (responses[i].emd == emd) {
data.width = responses[i].size.w;
data.height = responses[i].size.h;
data.ads[cai].contentUrl = responses[i].result[tag.ads[0].jat];
uto.extend(data.ads[cai], tag.ads[0])
}
}
}
}
data.cacheOverride = true;
return data
},
getBidData: function(bidInvocation) {
var rt = this.$root,
etst = this.settings;
if (rt.what(bidInvocation) != "number") {
return {}
}
var bids = etst.bidResponses[bidInvocation];
var emd = rt.utils.array.map(bids, function(bid) {
return bid.emd || ""
});
var nj = rt.utils.array.map(bids, function(bid) {
var p = bid.result[etst.tags[bid.emd].ads[0].jpt];
return rt.utils.base64.encodeBase64((rt.what(p) == "number" ? p : -1).toString()).split("").reverse().join("") || ""
});
var jsd = rt.utils.array.map(bids, function(bid) {
return [bid.size.w, bid.size.h].join("*") || ""
});
return {
emd: emd.join("~"),
nj: nj.join("~"),
jsd: jsd.join("~")
}
},
updateViewedTags: function(hookId) {
var rt = this.$root,
hook = rt.settings.hooksMap[hookId],
data = rt.helpers.getHookData(hookId);
var emd = data.ads[hook.currentAdIndex].emd,
etst = rt.externalTags.settings;
if (emd) {
if (!etst.uemd[emd]) {
etst.uemd[emd] = {}
}
if (!etst.uemd[emd][hook.prod]) {
etst.uemd[emd][hook.prod] = 0
}
etst.uemd[emd][hook.prod]++
}
},
getViewedTagsParam: function() {
var rt = this.$root,
etst = this.settings,
uto = rt.utils.object,
emd, val = [],
prod;
if (!uto.keys(etst.uemd).length) {
return {}
}
for (emd in etst.uemd) {
for (prod in etst.uemd[emd]) {
rt.utils.array.push(val, [emd, prod, etst.uemd[emd][prod]].join("!"))
}
}
return {
uemd: val.join("~")
}
}
}, {
settings: {
bidInvocation: 0,
bidResponses: {},
bidCount: 0,
tags: {},
bidRequestTimeout: 300,
uemd: {}
}
}, true);
externalTags.bind({
event: "sendBids",
listener: {
sendBids: function(event) {
var rt = this.$root,
etst = this.settings,
emd, tag, ad, jsonUrl, i, leni, hook = rt.settings.hooksMap[event.data.hookId],
sizes = this.getProductAdSizes(hook.prod, hook);
rt.utils.timer.start("externalBid" + (++etst.bidInvocation));
etst.bidResponses[etst.bidInvocation] = [];
etst.bidResponses[etst.bidInvocation].bids = 0;
etst.bidResponses[etst.bidInvocation].responses = 0;
for (emd in etst.tags) {
tag = etst.tags[emd];
ad = tag.ads[0];
if (ad.prs && !ad.prs[hook.prod]) {
continue
}
if (!ad.jsonUrl) {
continue
}
if (!ad.jat) {
ad.jat = "ad"
}
if (!ad.jat) {
ad.jpt = "cpm"
}
for (i = 0, leni = sizes.length; i < leni; i++) {
jsonUrl = ad.jsonUrl.replace(/\{WIDTH\}/g, sizes[i].w).replace(/\{HEIGHT\}/g, sizes[i].h);
etst.bidCount++;
etst.bidResponses[etst.bidInvocation].bids++;
rt.comm.loadScript([jsonUrl, "&callback=", etst.bidCallbackVar, etst.bidCount].join(""), null, "setExternalBidResponse", rt.utils.object.extend({
emd: emd,
bidInvocation: etst.bidInvocation,
bidCount: etst.bidCount,
hookId: hook.id,
size: sizes[i]
}, event.data))
}
}
}
}
});
externalTags.bind({
event: "setExternalBidResponse",
listener: {
setExternalBidResponse: function(event) {
var rt = this.$root,
etst = this.settings,
bidCount = event.data.bidCount,
bidInvocation = event.data.bidInvocation,
tag = etst.tags[event.data.emd],
ad = tag.ads[0],
jct, response = window[etst.bidCallbackVar + bidCount],
hook = rt.settings.hooksMap[event.data.hookId],
bidResponses = etst.bidResponses[bidInvocation];
response.emd = event.data.emd;
response.size = event.data.size;
if (ad.jct) {
jct = new RegExp(ad.jct.replace(/([\[\]])/g, "\\$1"), "g");
response.result[ad.jat] = response.result[ad.jat].replace(jct, "@encode@@start@@end@@encode@")
}
rt.utils.array.push(bidResponses, response);
bidResponses.responses++;
if (bidResponses.responses >= bidResponses.bids) {
if (hook.killBids) {
delete hook.killBids
} else {
hook.externalTag = bidInvocation;
rt.event.fire("sendGetAds", event.data)
}
}
}
}
});
var updater = $root.$create("updater", {
handleUpdaterImpression: function(event) {
var rt = this.$root,
response, ust = this.settings,
instance = ust.instances[ust.instances.length - 1];
instance.complete = true;
response = rt.helpers.processImpressionResponse(event.data);
if (rt.what(response) != "object") {
rt.logger.error("Bad Impression response.", true);
return
}
instance.impression = response;
if (!instance.impression.prs[rt.products.intext.settings.prodCode]) {
return
}
rt.event.fire("initIntext", {
updater: instance
})
}
}, {
settings: {
def: {
interval: 10,
container: null,
tag: null
},
counter: 0,
instances: []
}
}, true);
updater.bind({
event: "initUpdater",
listener: {
init: function() {
var rt = this.$root,
ust = this.settings,
hp = rt.helpers,
cont = hp.getVar("updater_container");
ust.interval = hp.getVar("updater_interval") || ust.def.interval;
ust.container = cont ? rt.utils.dom.element.$(cont) : ust.def.container;
ust.tag = hp.getVar("updater_tag") || ust.def.tag;
rt.event.repeat("updaterContentChange", ust.interval * 1000)
}
}
});
updater.bind({
event: "updaterContentChange",
listener: {
updaterContentChange: function() {
var rt = this.$root,
ut = rt.utils,
ust = this.settings,
harvested, instance, i, leni, text = [],
nodes = [];
if (ust.instances.length && !ust.instances[ust.counter - 1].complete) {
return
}
var containers = rt.utils.dom.filterByClass(ust.className, ust.tag, ust.container);
for (i = 0, leni = containers.length; i < leni; i++) {
if (containers[i].getAttribute("iceupdated") == "true") {
continue
}
rt.harvest.settings.enabled = true;
harvested = rt.harvest.getHarvestedText(containers[i]);
if (harvested.text.length > 0) {
containers[i].setAttribute("iceupdated", "true");
ut.array.push(text, harvested.text);
nodes = ut.array.concat(nodes, harvested.nodes)
}
}
if (!text.length) {
return
}
instance = ust.instances[ust.counter++] = {
nodes: nodes,
text: text.join("P"),
complete: false
};
rt.event.unbind("afterImpression");
rt.event.bind({
event: "afterImpression",
listener: this.handleUpdaterImpression
});
rt.event.fire("beforeImpression", {
ptxt: instance.text,
updater: ust.counter
})
}
}
});
var demo = $root.$create("demo", {
isDemo: function() {
var rt = this.$root,
hp = rt.helpers,
std = this.settings;
std.demo = hp.getVar("demo");
std.custom = hp.getVar("custom");
return (std.demo || std.custom)
},
convertCustom: function(custom) {
var rt = this.$root,
uto = rt.utils.object,
prods = ["intext", "tagcloud"],
prod, i, leni, prs = {},
prodCode;
if (custom.related) {
if (!custom.tagcloud) {
custom.tagcloud = custom.related
}
delete custom.related
}
for (i = 0, leni = prods.length; i < leni; i++) {
prod = prods[i];
if (custom[prod]) {
prodCode = prod.charAt(0);
if (custom[prod] === true) {
prs[prodCode] = {
behavior: {},
sentences: ["ALL"]
}
} else {
if ((custom[prod].sentences && custom[prod].sentences.length) || custom[prod].marker) {
prs[prodCode] = uto.extend({}, custom[prod])
}
}
}
}
var data = {
containers: custom.hooks && custom.hooks.containers ? custom.hooks.containers : null,
responses: {
gsd: uto.extend(custom.verification ? custom.verification.response : {}, {
prs: uto.keys(prs).join(",")
}),
impression: {
rauth: {
rsd: "1",
rsk: "1",
rcs: "1"
},
sentences: custom.hooks && custom.hooks.sentences ? rt.utils.array.toObject(custom.hooks.sentences, {}, "1") : null,
prs: prs
},
getads: {
catchall: rt.what(custom.hover.response) == "array" ? custom.hover.response[0] : custom.hover.response[rt.utils.object.keys(custom.hover.response)[0]]
}
}
};
rt.event.fire("setDemoData", data)
},
reRouteEvents: function() {
var rt = this.$root,
ev = rt.event;
ev.unbind("beforeGSD");
ev.bind({
event: "beforeGSD",
listener: this.beforeGSD
});
ev.unbind("afterGSD");
ev.bind({
event: "afterGSD",
listener: this.afterGSD
});
ev.unbind("beforeImpression");
ev.bind({
event: "beforeImpression",
listener: this.beforeImpression
});
ev.unbind("afterImpression");
ev.unbind("getAds");
ev.bind({
event: "getAds",
listener: this.getAds
});
ev.unbind("sendAdView");
ev.unbind("sendImpressionLog");
ev.unbind("startClick");
ev.bind({
event: "startClick",
listener: rt.comm.doRedirect
})
},
beforeGSD: function() {
this.$root.event.fire("afterGSD")
},
afterGSD: function() {
var rt = this.$root;
if (/i|r|t/.test(rt.comm.settings.responses.gsd.prs)) {
rt.event.fire("beforeHarvest")
} else {
rt.event.fire("beforeImpression")
}
},
beforeImpression: function() {
var rt = this.$root,
prs = rt.utils.array.toObject(rt.comm.settings.responses.gsd.prs.split(","), {}, true);
if (rt.helpers.getVar("inframe_disable") === true) {
delete prs["f"]
}
if (prs["f"]) {
var gpmp = rt.products.inframe.buildImpPageMarginsParam();
if (!gpmp) {
delete prs["f"]
}
}
rt.event.fire("preRenderProducts")
},
getAds: function(event) {
var rt = this.$root,
hookId = event.data.hookId,
st = rt.settings,
hook = st.hooksMap[hookId],
getads = rt.comm.settings.responses.getads,
s2cm = this.settings.sentences2ContainersMap,
i, j, ad, cb;
var data = rt.helpers.getHookData(hookId);
if (!data) {
if (getads.sentences && getads.sentences[hook.sentence]) {
data = getads.sentences[hook.sentence]
} else {
if (getads.containers && getads.containers[s2cm[hook.sentence]]) {
data = getads.containers[s2cm[hook.sentence]]
} else {
if (getads.catchall) {
data = getads.catchall
}
}
}
}
data = data ? rt.utils.object.clone(data, true) : "pending";
data.lid = hook.id;
data.sentence = hook.sentence;
var props = ["redirectURL", "title", "text"];
for (i = 0; i < data.ads.length; i++) {
ad = data.ads[0];
for (j = 0; j < props.length; j++) {
if (ad[props[j]]) {
ad[props[j]] = ad[props[j]].replace("@sentence@", hook.sentence)
}
}
}
hook.bdc = ++st.bdc;
switch (hook.prod) {
case "s":
cb = "getadsResponseInsearch";
break;
case "f":
cb = "getadsResponseInframe";
break;
default:
cb = "getadsResponse"
}
rt.event.fire(cb, data)
}
}, {
settings: {
custom: false,
demo: false,
sentences2ContainersMap: {}
}
}, true);
demo.bind({
event: "demo",
listener: {
init: function() {
var rt = this.$root,
std = this.settings;
this.reRouteEvents();
if (std.custom) {
this.convertCustom(std.custom)
} else {
if (std.demo) {
rt.comm.loadScript(std.demo)
}
}
}
}
});
demo.bind({
event: "setDemoData",
listener: {
setDemoData: function(event) {
var rt = this.$root,
st = rt.settings,
data = event.data,
imp, i, leni, dmel = rt.utils.dom.element,
el, sentence, dst = this.settings,
hp = rt.helpers;
rt.helpers.getCustomerId();
dst.data = data;
imp = st.impression = {
params: {}
};
if (data.ref) {
st.ref = imp.params.ref = data.ref
}
if (data.refq) {
st.refq = imp.params.refq = data.refq
}
hp.setDefaultWebsiteDirectives(data.responses.gsd);
if (!data.responses.impression.sentences) {
data.responses.impression.sentences = {}
}
if (data.containers) {
for (i = 0, leni = data.containers.length; i < leni; i++) {
el = dmel.$(data.containers[i]);
if (!el || !el.firstChild || el.firstChild.nodeType != st.nodeTypes.TEXT) {
continue
}
sentence = rt.utils.string.trim(el.firstChild.nodeValue.toLowerCase().replace(/\s+/g, ""));
data.responses.impression.sentences[sentence] = "1";
dst.sentences2ContainersMap[sentence] = data.containers[i]
}
}
hp.normalizeSentenceLists(data.responses.impression);
rt.comm.settings.responses = data.responses;
rt.event.fire("loadPlugins")
}
}
});
var bubble = $root.$create("bubble", {
hookDblClick: function(event) {
this.$root.utils.dom.event.stop(event.domEvent)
},
hookClick: function(event) {
var rt = this.$root,
st = rt.settings,
domEvt = event.domEvent,
sender = domEvt.target || domEvt.srcElement,
ut = rt.utils,
hookId = event.data.hookId,
hook = st.hooksMap[hookId],
bst = this.settings,
ad;
ut.dom.event.stop(domEvt);
if (st.clickStatus == "complete") {
return
}
if (hook.externalTag) {
st.clickStatus = "complete";
return
}
hook.clickType = (sender.className.indexOf(bst.cls + "_simlink") != -1 || ut.dom.element.inHierarchy(sender, hook.node)) ? hook.bubble.status == "open" ? "onLinkAfterWinOpen" : "onLink" : "onWin";
st.clickStatus = "pending";
ut.timer.stop("adView" + hookId);
var reuseWindow = rt.helpers.getHookBehavior(hookId).adsReuseWindow;
var data = rt.helpers.getHookData(hookId);
if (hook.bubble.status != "open" && (bst.dcbbs || (data && data.dcbbs))) {
st.clickStatus = "none";
delete hook.clickType;
return
}
if (rt.what(data) == "object") {
ad = data.ads[hook.currentAdIndex];
if (hook.clickType == "onWin" && ad.template == "html" && ad.content.match(/<object |<embed /i) && ad.content.match(/clicktag/i)) {
st.clickStatus = "complete";
return
}
if ((hook.clickType == "onLink" || hook.clickType == "onLinkAfterWinOpen") && ad.redirectURL == "") {
st.clickStatus = "none";
delete hook.clickType
} else {
if (hook.bubble.status == "open" || hook.clickType == "onWin" || !data.dcbbs) {
if (!reuseWindow) {
st.adWin = window.open("", hook.node.id)
}
rt.event.fire("productClick", {
hookId: hookId
})
}
}
} else {
if (!reuseWindow) {
st.adWin = window.open("", hook.node.id)
}
}
},
getSkinPath: function(skin) {
var rt = this.$root,
sk = this.skins,
rv = skin && sk[skin] && sk[skin].settings.rv ? sk[skin].settings.rv + "/" : "";
return ["http://", rt.settings.hosts.resources, "/static/skins/", skin ? skin + "/intext/" : "", rv].join("")
},
preloadImages: function(path, images) {
var loaderPath = this.getSkinPath(false);
var loaderImages = ["loader.gif", "loader-bg.png"];
for (i = 0, leni = loaderImages.length; i < leni; i++) {
img = new Image();
img.src = loaderPath + loaderImages[i]
}
if (!images) {
return
}
var rt = this.$root,
b = rt.browser,
img, i, leni;
images = rt.utils.string.qw(images);
for (i = 0, leni = images.length; i < leni; i++) {
img = new Image();
img.src = [path, images[i], ".png"].join("")
}
},
adjustBubblePosition: function(hook, dimensions) {
var rt = this.$root,
st = rt.settings,
ut = rt.utils,
dm = ut.dom,
dmel = dm.element,
b = rt.browser,
pos = hook.pos;
var node = hook.node;
var nodeHeight = node.offsetHeight;
hook.isMultiline = (hook.fontSize * 2 < nodeHeight);
var right, left, top, bottom, scrollTop = dm.document.getScrollTop(),
scrollLeft = dm.document.getScrollLeft();
var width = dimensions.width,
height = dimensions.height;
var bbldir = rt.helpers.getHookBehavior(hook.id).bubbleDirection;
if (hook.isMultiline) {
var linesCount = Math.floor(nodeHeight / (parseInt(dmel.getStyle(node, "lineHeight"), 10) || hook.fontSize + 2));
if (linesCount < 2) {
linesCount = 2
}
var lineHeight = Math.floor(nodeHeight / linesCount);
var mouseX = hook.domEvent.pageX || hook.domEvent.clientX + scrollLeft;
var mouseY = hook.domEvent.pageY || hook.domEvent.clientY + scrollTop;
right = mouseX > (pos.left + pos.left + node.offsetWidth) / 2 ? pos.left + node.offsetWidth - 20 : pos.left;
left = right + 20 - width;
top = pos.top - height;
if (mouseY - pos.top > lineHeight) {
top += lineHeight
}
bottom = top + lineHeight + height
} else {
right = pos.left;
left = pos.left - width + ((!b.IE || !node.offsetWidth) ? 20 : node.offsetWidth);
top = pos.top - height;
bottom = pos.top + (node.offsetHeight || 18)
}
var allpos = {
TR: {
rect: [right, top, right + width, top + height],
clear: true,
inBounds: true
},
TL: {
rect: [left, top, left + width, top + height],
clear: true,
inBounds: true
},
BR: {
rect: [right, bottom, right + width, bottom + height],
clear: true,
inBounds: true
},
BL: {
rect: [left, bottom, left + width, bottom + height],
clear: true,
inBounds: true
}
};
if ((right + width > dm.document.getWidth() + scrollLeft) || (bbldir && bbldir.indexOf("L") != -1)) {
allpos.TR.inBounds = allpos.BR.inBounds = false
}
if (left < 0 || (bbldir && bbldir.indexOf("R") != -1)) {
allpos.TL.inBounds = allpos.BL.inBounds = false
}
if ((bottom + height > dm.document.getHeight() + scrollTop) || (bbldir && bbldir.indexOf("T") != -1)) {
allpos.BR.inBounds = allpos.BL.inBounds = false
}
if (top < scrollTop || (bbldir && bbldir.indexOf("B") != -1)) {
allpos.TR.inBounds = allpos.TL.inBounds = false
}
if (st.unhoverableAreas) {
for (var key in allpos) {
if (!allpos[key].inBounds) {
continue
}
for (var i = 0, leni = st.unhoverableAreas.length; i < leni; i++) {
if (ut.doRectsOverlap(allpos[key].rect, st.unhoverableAreas[i])) {
allpos[key].clear = false;
break
}
}
}
}
for (key in allpos) {
if (!allpos[key].inBounds) {
continue
}
if (allpos[key].clear) {
hook.orientationY = key.charAt(0);
hook.orientationX = key.charAt(1);
return {
left: allpos[key].rect[0],
top: allpos[key].rect[1]
}
}
}
for (key in allpos) {
if (allpos[key].inBounds) {
hook.orientationY = key.charAt(0);
hook.orientationX = key.charAt(1);
return {
left: allpos[key].rect[0],
top: allpos[key].rect[1]
}
}
}
hook.orientationY = "T";
hook.orientationX = "R";
if (bbldir) {
if (bbldir.length == 2) {
hook.orientationY = bbldir.charAt(0);
hook.orientationX = bbldir.charAt(1)
} else {
if (bbldir == "T" || bbldir == "B") {
hook.orientationY = bbldir
}
if (bbldir == "R" || bbldir == "L") {
hook.orientationX = bbldir
}
}
}
return {
left: allpos[hook.orientationY + hook.orientationX].rect[0],
top: allpos[hook.orientationY + hook.orientationX].rect[1]
}
},
getPreloaderPosition: function(hook, dimensions) {
var pos = this.adjustBubblePosition(hook, dimensions);
if (hook.orientationY == "T") {
pos.top = pos.top + dimensions.height - 31
}
if (hook.orientationX == "L") {
pos.left = pos.left + dimensions.width - 31
}
return pos
},
renderAdsContent: function(hook, data) {
var rt = this.$root,
adsHTML = "",
ad;
for (var i = 0, leni = data.ads.length; i < leni; i++) {
ad = data.ads[i];
rt.helpers.setActualTemplate(ad);
adsHTML += this.templates[ad.actualTemplate](hook, i)
}
return adsHTML
},
afterBubbleRendered: function(container, data, hook) {
var rt = this.$root,
i, leni, form;
for (i = 0, leni = data.ads.length; i < leni; i++) {
if (data.ads[i].actualTemplate == "iframe") {
form = container.getElementsByTagName("form");
if (form.length && form[0].className.indexOf(this.settings.cls + "_ad_form") != -1) {
form[0].submit()
}
}
}
var anchors = container.getElementsByTagName("a"),
href;
for (i = 0, leni = anchors.length; i < leni; i++) {
if (anchors[i].href) {
href = anchors[i].href;
anchors[i].removeAttribute("href");
rt.event.dom.bind(anchors[i], {
event: "click",
listener: (function() {
return function(domEvt) {
rt.utils.dom.event.stop(domEvt.domEvent);
rt.event.fire("productClick", {
hookId: hook.id,
url: href,
clickType: "onWin"
})
}
})()
})
}
}
var objects = container.getElementsByTagName("object");
for (i = 0; i < objects.length; i++) {
rt.utils.dom.event.disableEventBubbling("click", objects[i])
}
var embeds = container.getElementsByTagName("embed");
for (i = 0; i < embeds.length; i++) {
rt.utils.dom.event.disableEventBubbling("click", embeds[i])
}
}
}, {
settings: {
initialized: false,
activeHook: null,
base: {
status: "closed",
node: null,
pos: null
},
def: {
width: 316,
height: 176
},
cls: "ice_it",
oldIE: (function() {
var b = $root.browser;
return b.IE && b.getVersion(true) < 9
})(),
oldFF: (function() {
var b = $root.browser;
return b.Firefox && b.getVersion(true) < 4
})()
}
}, true);
bubble.bind({
event: "initBubble",
listener: {
initBubble: function(event) {
var rt = this.$root,
hp = rt.helpers,
bst = rt.bubble.settings;
bst.initialized = true;
bst.dcbbs = hp.getVar("deny_click_before_bubble_show") || false;
this.skins[rt.products[event.data].settings.behavior.merged.skin].init()
}
}
});
bubble.bind({
event: "hookMouseover",
listener: {
hookMouseover: function(event) {
var rt = this.$root,
st = rt.settings,
hookId = event.data.hookId,
bh = rt.helpers.getHookBehavior(hookId),
hook = st.hooksMap[hookId],
hrd = bh.hoverRequestDelay;
delete hook.killHoverStart;
if (st.clickStatus != "none") {
return
}
if (hook.bubble.status.indexOf("open") == 0) {
hrd = 0
}
var de = event.data.domEvent || event.domEvent;
hook.domEvent = {
pageX: de.pageX,
pageY: de.pageY,
clientX: de.clientX,
clientY: de.clientY
};
rt.event.fire(hook.type + "HookMouseover", {
hookId: hookId
});
rt.event.fire("hookHoverStart", {
hookId: hookId
}, hrd)
}
}
});
bubble.bind({
event: "hookMouseout",
listener: {
hookMouseout: function(event) {
var rt = this.$root,
st = rt.settings,
hookId = event.data.hookId,
hook = st.hooksMap[hookId];
hook.killHoverStart = true;
rt.event.fire(hook.type + "HookMouseout", {
hookId: hook.id
});
rt.event.fire("hideBubble", {
hookId: hook.id
})
}
}
});
bubble.bind({
event: "hookHoverStart",
listener: {
hookHoverStart: function(event) {
var rt = this.$root,
bst = this.settings,
hookId = event.data.hookId,
hook = rt.settings.hooksMap[hookId],
activeHook;
if (hook.killHoverStart) {
delete hook.killHoverStart;
return
}
hook.hovered = true;
if (bst.activeHook && bst.activeHook != hookId) {
activeHook = bst.activeHook;
bst.activeHook = null;
rt.event.fire("closeBubble", {
hookId: activeHook
})
}
bst.activeHook = hookId;
if (hook.bubble.status.indexOf("open") != -1) {
return
}
hook.bubble.status = "opening";
var bubbleShowDelay = rt.helpers.getHookBehavior(hookId).bubbleShowDelay;
var data = rt.helpers.getHookData(hookId);
if (!data) {
rt.event.fire("getAds", event.data)
}
rt.event.fire("showBubble", event.data, bubbleShowDelay)
}
}
});
bubble.bind({
event: "getadsResponse",
listener: {
setAdData: function(event) {
var rt = this.$root,
st = rt.settings,
data = event.data,
hookId = data.lid,
bst = this.settings,
i, leni, ad, hook = st.hooksMap[hookId];
if (!hook) {
rt.logger.error("Error: Misssing hook.", this.setAdData);
return false
}
if (bst.activeHook == hookId && hook.bubble.status == "open") {
return
}
data.sentence = decodeURIComponent(data.sentence);
for (i = 0, leni = data.ads.length; i < leni; i++) {
ad = data.ads[i];
ad.midx = i;
rt.helpers.setAdThumbnail(ad);
if (ad.trackerURL) {
rt.helpers.hitTrackerURL(ad.trackerURL)
}
}
ad = data.ads[hook.currentAdIndex];
if (ad.template == "external") {
data = rt.externalTags.setExternalTagData(hook, data)
} else {
if (hook.externalTag) {
delete hook.externalTag
}
if (!data.width || data.width < 200) {
data.width = bst.def.width
}
if (!data.height || data.height < 60) {
data.height = bst.def.height
}
if (bst.dcbbs) {
data.dcbbs = bst.dcbbs
}
if (data.dcbbs && !rt.helpers.getHookBehavior(hookId).adsReuseWindow) {
data.dcbbs = false
}
if (data.dcbbs && st.clickStatus == "pending") {
st.clickStatus = "none";
st.hookClicked = null
}
}
rt.helpers.setHookData(hookId, data);
if (bst.activeHook != hookId) {
rt.event.fire("closeBubble", {
hookId: hookId
});
return
}
rt.event.fire("showBubble", {
hookId: hookId
})
}
}
});
bubble.bind({
event: "showBubble",
listener: {
showBubble: function(event) {
var rt = this.$root,
st = rt.settings,
hookId = event.data.hookId,
hook = st.hooksMap[hookId],
dm = rt.utils.dom,
rtb = rt.bubble,
bst = rtb.settings;
if (hook.bubble.status == "open") {
return
}
var data = rt.helpers.getHookData(hookId);
hook.pos = dm.element.offset(hook.node);
var preloader = hook.bubble.preloader;
if (data && data != "pending") {
if (preloader) {
preloader.style.display = "none"
}
var skin = data.ads[hook.currentAdIndex].skin || rt.helpers.getHookBehavior(hookId).skin;
rtb.skins[skin].showBubble(hookId)
} else {
if (data == "pending") {
var pos = rtb.getPreloaderPosition(hook, {
width: bst.def.width,
height: bst.def.height
});
if (!preloader) {
var path = rtb.getSkinPath();
preloader = hook.bubble.preloader = dm.createDOMFragment({
tag: "div",
cls: st.baseClass,
parent: document.body,
style: {
position: "absolute",
display: "none",
width: "30px",
height: "30px",
top: "0px",
left: "0px",
zIndex: st.baseZIndex + 101,
background: ['transparent url("', path, 'loader-bg.png") no-repeat scroll 0 0'].join("")
},
children: {
tag: "img",
cls: st.baseClass,
attributes: {
width: 30,
height: 30,
alt: "",
src: path + "loader.gif"
}
}
})
}
dm.element.setStyle(preloader, {
top: pos.top + "px",
left: pos.left + "px",
display: "block"
})
}
}
}
}
});
bubble.bind({
event: "bubbleShowing",
listener: {
bubbleShowing: function(event) {
var rt = this.$root,
st = rt.settings,
hookId = event.data.hookId,
hook = st.hooksMap[hookId],
bh = rt.helpers.getHookBehavior(hookId),
time = bh.bubbleHideDelay,
data = rt.helpers.getHookData(hookId);
hook.bubble.status = "open";
if (hook.externalTag) {
rt.externalTags.updateViewedTags(hookId)
}
rt.event.fire("sendAdView", {
hookId: hookId,
params: {
prod_t: hook.prod
}
});
if (st.clickStatus == "pending") {
rt.event.fire("productClick", {
hookId: hookId
}, time);
return
}
rt.utils.timer.start("adView" + hookId);
if (!hook.hovered) {
rt.event.fire("hideBubble", {
hookId: hookId
})
}
}
}
});
bubble.bind({
event: "hideBubble",
listener: {
hideBubble: function(event) {
var rt = this.$root,
hookId = event.data.hookId,
hook = rt.settings.hooksMap[hookId],
viewTime = null;
hook.hovered = false;
if (hook.bubble.status == "closed") {
return
}
var data = rt.helpers.getHookData(hookId);
if (hook.externalTag && data) {
viewTime = data.ads[hook.currentAdIndex].vt
}
var delay = parseInt(event.data.xBtn ? 0 : (viewTime || rt.helpers.getHookBehavior(hookId).bubbleHideDelay));
rt.event.fire("closeBubble", event.data, delay)
}
}
});
bubble.bind({
event: "closeBubble",
listener: {
closeBubble: function(event) {
var rt = this.$root,
st = rt.settings,
bst = this.settings,
hookId = event.data.hookId,
hook = st.hooksMap[hookId],
data = rt.helpers.getHookData(hookId);
if (bst.activeHook == hookId) {
bst.activeHook = null
}
if (hook.hovered) {
return
}
if (hook.bubble.node) {
hook.bubble.node.style.display = "none"
}
if (hook.bubble.preloader) {
hook.bubble.preloader.style.display = "none"
}
if (st.clickStatus != "pending") {
if (data && data.cacheOverride) {
rt.helpers.clearHookData(hookId);
if (hook.externalTag) {
delete hook.externalTag
}
}
}
if (st.clickStatus == "none") {
rt.utils.timer.clear("adView" + hookId)
}
hook.bubble.status = "closed";
if (data && data != "pending" && data.ads[0].template == "html") {
rt.event.fire("clearBubbleDOM", {
hookId: hookId
}, 1000)
}
}
}
});
bubble.bind({
event: "clearBubbleDOM",
listener: {
clearBubbleDOM: function(event) {
var rt = this.$root,
st = rt.settings,
hookId = event.data.hookId,
hook = st.hooksMap[hookId],
el;
if (hook.bubble.status == "open") {
return
}
el = rt.utils.dom.filterByClass(this.settings.cls + "_bodyMain", null, hook.bubble.node);
if (el.length) {
el[0].innerHTML = ""
}
}
}
});
bubble.bind({
event: "bubbleMouseover",
listener: {
bubbleMouseover: function(event) {
var rt = this.$root,
hookId = event.data.hookId,
hook = rt.settings.hooksMap[hookId],
data = rt.helpers.getHookData(hook.id);
hook.hovered = true;
rt.event.fire((data.ads[hook.currentAdIndex].skin || rt.helpers.getHookBehavior(hookId).skin) + "BubbleMouseover", event.data)
}
}
});
bubble.bind({
event: "bubbleMouseout",
listener: {
bubbleMouseout: function(event) {
var rt = this.$root,
st = rt.settings,
hookId = event.data.hookId,
hook = st.hooksMap[hookId],
data = rt.helpers.getHookData(hook.id);
hook.hovered = false;
rt.event.fire((data.ads[hook.currentAdIndex].skin || rt.helpers.getHookBehavior(hookId).skin) + "BubbleMouseout", event.data);
if (st.clickStatus == "pending") {
return
}
rt.event.fire("hideBubble", event.data)
}
}
});
bubble.$create("templates", {
text: function(hook, adIndex) {
var rt = this.$root,
pr = this.$parent,
st = rt.settings,
b = rt.browser,
data = rt.helpers.getHookData(hook.id),
ad = data.ads[hook.currentAdIndex],
thumbURL = "",
hasThumb = false,
bst = pr.settings;
var skinPath = pr.getSkinPath(data.skin || rt.helpers.getHookBehavior(hook.id).skin);
if (ad.thumbURL != "no-image") {
thumbURL = ad.thumbURL;
hasThumb = true
}
var html = '<div class="<%= cls %>" style="color:#003366; font-family: Arial,sans-serif; font-size:11pt; font-weight:bold; line-height:11pt; margin-left:15px; margin-top:10px; margin-bottom:10px; margin-right:5px; max-height:22pt; overflow:hidden;"><%= ad.title %></div> <div class="<%= cls %>" style="position:absolute; height:88px; width:<%= data.width %>px;"> <%if (hasThumb){ %> <img class="<%= cls %>" width="110" height="82" style="position:absolute; top:0; left:15px; width:110px; height:82px; background-color:#e8e8e8; box-shadow:2px 2px 5px #888; -moz-box-shadow:2px 2px 5px #888; -webkit-box-shadow:2px 2px 5px #888;" src="<%= thumbURL %>"> <% } %> <div class="<%= cls %>" style="position:absolute; top:0; left:<%= hasThumb ? 140 : 15 %>px; width:168px; height:51px; overflow:hidden; color:#666666; font-family: Arial,sans-serif; font-size:10pt; font-weight:normal; line-height:17px;"><%= ad.text %></div> <div id="<%= intextCls %>_btn_<%= hookId %>" class="<%= cls %> <%= intextCls %>_btn" style="position:absolute; display:block; bottom:0px; right:13px; width:93px; height:24px; font-family:Arial,sans-serif; font-size:9pt; font-weight:bold; cursor:pointer; text-align:center; line-height:24px; color:#ffffff;"><%= rt.helpers.translate("clickHere") %></div> </div> <div class="<%= cls %>" style="position:absolute; bottom:12px; left:15px; width:280px; height:15px; color:#003366; font-family: Arial,sans-serif; font-size:9pt; font-weight:normal; text-decoration:underline; overflow:hidden;"><%= ad.displayedURL %></div>';
return rt.utils.VeST(html, {
rt: rt,
intextCls: bst.cls,
cls: st.baseClass,
btnCls: [st.baseClass, " ", bst.cls, "_bg ", bst.cls, "_btn"].join(""),
hookId: hook.id,
data: data,
ad: ad,
thumbURL: thumbURL,
hasThumb: hasThumb,
display: adIndex != hook.currentAdIndex ? "none" : "block",
skinPath: skinPath
})
},
html: function(hook, adIndex) {
var rt = this.$root,
st = rt.settings;
return rt.utils.VeST('<div class="<%= cls %>" style="height:<%= data.height %>px; position:relative; display:<%= display %>;"><%= content %></div>', {
cls: st.baseClass,
adIndex: adIndex,
data: rt.helpers.getHookData(hook.id),
display: adIndex != hook.currentAdIndex ? "none" : "block",
content: rt.helpers.parseTokens(hook)
})
},
iframe: function(hook, adIndex) {
var rt = this.$root,
st = rt.settings,
bst = this.$parent.settings;
var html = '<div class="<%= cls %>" style="display:<%= display %>;"><div cls="<%= cls %>" style="width:<%= data.width %>px; height:<%= data.height %>px;"> <iframe name="<%= iframeName %>" src="<%= st.blankURL %>" width="<%= data.width %>" height="<%= data.height %>" frameborder="0" scrolling="no"></iframe></div><%= rt.helpers.getEchoForm(content, iframeName, null, formCls) %></div>';
return rt.utils.VeST(html, {
rt: rt,
version: rt.version,
cls: st.baseClass,
adIndex: adIndex,
data: rt.helpers.getHookData(hook.id),
display: adIndex != hook.currentAdIndex ? "none" : "block",
content: rt.helpers.parseTokens(hook),
iframeName: bst.cls + "_ad_frame" + adIndex,
formCls: bst.cls + "_ad_form",
st: st
})
},
external: function(hook, adIndex) {
var rt = this.$root,
st = rt.settings,
data = rt.helpers.getHookData(hook.id);
var html = '<div class="<%= cls %>" style="display:<%= display %>; width:<%= data.width %>px; height:<%= data.height %>px;"> <iframe src="<%= contentUrl %>" width="<%= data.width %>" height="<%= data.height %>" frameborder="0" scrolling="no" allowtransparency="true" leftmargin="0" topmargin="0" marginwidth="0" marginheight="0"></iframe></div>';
return rt.utils.VeST(html, {
cls: st.baseClass,
data: data,
display: adIndex != hook.currentAdIndex ? "none" : "block",
contentUrl: rt.helpers.parseTokens(hook, data.ads[adIndex].contentUrl)
})
}
}, null, false);
var skins = bubble.$create("skins", {}, null, false);
skins.$create("brand", {
init: function() {
var rt = this.$root,
dms = rt.utils.dom.style,
bbl = rt.bubble,
bst = bbl.settings,
intextCls = bst.cls,
skinPath = bbl.getSkinPath(this.$id),
images = "";
if (rt.browser.IE || bst.oldFF) {
dms.addRule("." + intextCls + "_btn", ["background:url(", skinPath, "btn.png) no-repeat scroll 0 0 !important;"].join(""));
dms.addRule("." + intextCls + "_bg", ["background:url(", skinPath, "hdr-btns.png) no-repeat scroll 0 0;"].join(""));
images = "btn.png hdr-btns.png loading.gif"
} else {
dms.addRule("." + intextCls + "_btn", ["background:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAF0AAABICAYAAACUavnrAAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAAA4JJREFUeNrsnL9u01AUxs+xbxOS1LQVBQkGJBgQMPUNGCshMiB1zgqoOwMViBfoxMYGqjqwMIBgYqC8AQsStAyVaAmllDZN4j+xL/fGdsgD9J4I8X1SFDvZfv70+dxzj60eP3119vXGx9V6rXLzdP2U0gSdtNh8umEct/ePXn7ebt9nutZ6dvHyhdZsUKcsA3JX8n2mvV/HtLN38ET5Qb1prgJ1+xHIuHS7sXuSZvagqcy5l//IIOMYOudB4ivSpG2seGDuVgZ4kd5a2TOtNSHO3d9MM51DHlYrWZYRjC5gdp3l0K3t7QWA0SWgF06nwumQ80inEvMwXlINn0soG3e6xl1UyO3j8QKnyzrdhvsgRaaLBfsoXuB0UXlAAOiADgE6oEOA/s9B94FBVL6p03mLmBfAQmqBpDcVZ/EKJ701s0CaAxHHseJxW081HilD/c1sw1vu9JMl4/qGbREAz8nzZtKdoF5Z/51kGyqhynxXBYtXrp+7MV2rKrQETl52U7obJtGX7fbPOI7e2UxfNb+3dvcO0YNxCt5uiOq75iBR7FEzihMKowRkBBxvZOde2GNDHmMvAtDNJ6XUloykAVy2aFTlFYDkpP6GPCSSLyV0DzN1MrlScFcMp8tSHzkd0OWYs4XOebxgWSRBvRjBGMaLgc6gLpQubOOFTbyYxRG2MwSMXk54FfGCWBdLlzxefEOcUTYKOt3Gi4/ei6jT82hntALkynRMA0xCgA7o/w90zL3Iylea9JapFxfQCnCr4WPq8cAebqo0Dh909neeK6XmCRvTTqn3++Gu1pWHitL47XHv6B771dvmn4Aw9+IoxvWhTsMXVJ35oGiqMR/MnLl19dL5xelaBe97cWJytm8ZiT993e12euF7uzhaNaBb334c5I/cgbob8Pk98445ipU5afbjhHphDDIC4M3SP597sQ0v7aMR4Bw62bkXKude0HsRlMYIhiTt4luVhTskFzFw+gSsnm9MI9FFrZ47Hb1GWadb8ogXWeqj7TpILl+KWUagkBRKxslA5+Gd1EOjSyDRxzLdQwUzieoFETOBTEf9Ig+dMEAqCr18/AXQ3cc5jznd57wBg4hxuiQa7fj7SmvaYs/OvaB8cQ3dzr2YsnFTZYNopXfwfc1An8OutFtFcdJmXbXve0nfVDlZPu4NlgxyvO/FjTyPdSeoVdbTRG/8EWAAta8y0OqpUAcAAAAASUVORK5CYII=) no-repeat scroll 0 0 !important;"].join(""));
dms.addRule("." + intextCls + "_bg", ["background:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAB4AAAAeCAYAAAA7MK6iAAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAAB+hJREFUeNrEV3tMm9cVP7Y/29gY/MBvg3klgFJGAnFeBUpok03NOhJeaVcSdVvGEu2fbdqmNm23bkmqRk1bbVm0PiKtTaVtSkLTh9SQlLY0CWSDpkugy8MmCY+AwRiwzbDBYJudc+FzP0e0+W+70pG/ex733Hvuub9zLPr9/gPAj/n5edDr9TA2NmbG6fJF9i3kuZEHIpEorvvbZ59hv7y9WCyGWCwGJpMJPB5PBrKykWJITp1O652Y8DE9fg0OEscGpIOl999fbjQaUEMEXq8Xbjid7ch/Guk8fPP4DtKBB8rLHXp9Gm5knjYRc7qcnyD/KaR/8YpCx3vWrllzZN26tRIJ7p4fmfYMKCkuLv380qXWf3Z0/AxZR77G6TMPlJftL161SiSMTFamXby6pGRz+8WLFZevXPkRsv4qdFyBix9ZuXKlZGYmzBh+v5+FXqvVsnlhYaE4Eo0cvnTpCydOW+5yWrdhw/oD+fkFEJqeWXJXDodDFolE/vLvq1ev08m55ORkkMvkLxcUFEimF40+bvkYOjo62HdJSQk8vOVh9p2fly/q6+v/QzAYvE+wpsRisbycnZUDZD/q8YA8SQ5qtYYJMdSQtDgvLPyWrH9g4EWplNtEMc2z2qyrZ2dnIRyewcTyQmdnJzz51K9h794nobu7G0ZGRpgsHA6D1WpdgTZFvFeZTFaabrPZF+Qz4Ha74bXXXofhYTc4nTfg6BtHYXJykskikTmyfxDNzFw0EimkU/Mhlkg42LZtKwSD00CbofuibOXlqmQV8Urws3vBsdQhtF+etxzm5ubg2Ftvo6MI7NjRwE7Ly1FX1NMTyOPkSUkKUiAn/DAYjeByuqC19VNYsWIFyOXyuBzvGRQKhSoeZwknj0SicTn9yBVJbJ6UlASRWJRFih9R1MWDiLg0ne5OIDAJKSkpCckQDE1BUVERONY4YCb8VcIEAgFIVipd/BxP0OsP+EEqk7I5hfps81loaHic8ABOHj8J1TXVkJK6sH4Aw45ZPinChy1veueUJzc3Vy10HJ5ZcIYRSdjQzVs3p6q3VlkMBsMUzZ0ul+n8hbaB3JxcGXM8NIQRM4AMo8ThtY16RhAOxOx1zKP89q2b7sYf78qg5Aqr1al/HB4exjBG4xSbj7GwCnkjuAjqvoo2U4K9eJRKxTEvno50bOnpIEaHc3MRmMbNa7Q6JC2TDQ4OEjK+RIgmordKBzt+sukTVC4lyFxqjI+PI6bGOhoe/34lTqd5/sxCZNRo34a5UKjRaJe0p2elUinP1lZXf5eumnfMEvZ085lXh9zuBsw3kVKpBAKgUCjEFjebTccf2bJlN12TcMFFx5Tp+rMftbzpGR19hGwVCiUCUAxfRwgTLRyzZ6Qf/fbmzT8nk7shk8K389H6ukNd3d31Pp+/gJho4EIYbDp34cLle+D0GNL36mtr1l3p6qqZnPxPLpaOWG5O1tXiVcXH29rbbgiVhSf+nw4x/J8Gt+/A8wn1eHEzhEz5FBF6MUhfUCbyNZfGc795NqEecxzHkIowBWkt0jJKIqRrSF20/DfV49qUlNRDaWm6bEoQGqHQNExMjPcj3u7F6d/vcZBdGo1mn1arsyoQvegcWFDI3jk1NfULlDcvVY9/l5WV9ZzRaEpYSaVKAaPRmInF4299fX1UHPYu4ZCO8edly5bv0el0CQJCRLPZnI848eGdOwO/QtYrwjveSk7NZgtrYYgI7sa8Y/E5bSg7O5u6iMeWcLwbkW8PYQCvfzfZbDaR3W4n8KhkJ0bAB6lU9qLVaouvcrG9HaFulBmkYQtTWlbG+LSx8fGJF/x+34nFfoqBT1qafr9eb2ATQkCZVMbsaAwhWimxehFkpqdniHw+30EspevoxEWIu3lSTA6iWawkg3cG4Qc/fAJ27twBHqzFM9Mh4OXYi2WhoYPfJKJVhclk1PPyZKUCmk+fhglEut7bt+H8ufNYSpOZTCaVgj5NT4mXyeHl5KtTU+PVRSvTwqOP1cMs1lRKDCpvKrwnXq7B2orO6K47aS6VSldiQsXlVpsNtm+vgxMnmjDTJdDYuCseGnbnWKX6B/qzOKwiHMd2I4sL1WotuFwuONN8BjZteghSMMF4oCFddBxXxrlEykkT7Cd8fqzTEpZz3rFxwNYIBPpMJraYzX2hUJAVeyHRm9y4cSOsdjiovYnzg6ir0aivfZW1KmdQYN/X18t6tp/sboR6PPmpd06xGs7LQxhF7GbHCDIlb751bKi0tNQkbEspuQgszBZzAsBgm+rbVlVl0Wo1rK3o7x/QII67N6xfr6B5b28vqFPVoEvTMbCg+sxhRKhGx6IxaP9H+217hj2XkiuKz+BgT08PKLDo84QlDFiVEfBoUa1Gc4hquODa/Cg7TLWWdKhVstms7DsJT5iTkwP2TDubX8fmz2K27KeejC8S4nffe78J25hqbEsS/qrwJ73cdYV67Q/qampqFqFQOOQnTjY149+XysLC+/BmE+0pch2fd0I0Gn0b8+GJu6sT99m5c/uwk/glprwMn8hCAR8dBe+odxb/kvzpwcpK+hsz+zVwqfyopeUlfyDQaDaZOYNBzxyOYAMwMT4xjfX8+fKyshf49y+ETEL4p+traw9fvXatyu0ezqONWSzmm5UVFe9/2trqvgdOh5B+ur2u7mD3l19WDQ25cygyGRnp1x+qrPzgQlvbmFD5vwIMAAZsT2nNzBrxAAAAAElFTkSuQmCC) no-repeat scroll 0 0;"].join(""))
}
dms.addRule("." + intextCls + "_btn_over", "background-position:0 -24px !important;");
bbl.preloadImages(skinPath, images)
},
showBubble: function(hookId) {
var rt = this.$root,
st = rt.settings,
hook = st.hooksMap[hookId],
hp = rt.helpers,
ed = rt.event.dom,
ut = rt.utils,
dmel = ut.dom.element,
node, rtb = rt.bubble,
cls = rtb.settings.cls,
b = rt.browser;
var data = hp.getHookData(hookId);
var pos = hook.bubble.pos = rt.bubble.adjustBubblePosition(hook, {
width: data.width + 2,
height: data.height + 41
});
if (hook.externalTag) {
pos.top += hook.orientationY == "T" ? 80 : -80;
var hookWidth = dmel.getActualWidth(hook.node);
pos.left += hook.orientationX == "L" ? hookWidth + 20 : -20
} else {
pos.top += hook.orientationY == "T" ? -5 : 5;
pos.left += hook.orientationX == "L" ? 30 : 0
}
if (hook.bubble.node && hook.bubble.node.parentNode) {
var parent = hook.bubble.node.parentNode;
parent.removeChild(hook.bubble.node)
}
node = hook.bubble.node = ut.dom.createDOMFragment({
tag: "div",
cls: st.baseClass,
parent: document.body,
style: {
display: "none"
},
innerHTML: this.renderBubble(data.width, data.height, hook)
});
var contentNode = dmel.$([cls, "content", hookId].join("_"));
if (contentNode) {
ed.bind(contentNode, {
event: "mouseenter",
data: {
hookId: hookId
},
listener: function(event) {
rt.event.fire("bubbleMouseover", {
hookId: hookId,
sender: event.domEvent.currentTarget || event.domEvent.srcElement
})
}
});
ed.bind(contentNode, {
event: "mouseleave",
data: {
hookId: hookId
},
listener: function(event) {
rt.event.fire("bubbleMouseout", {
hookId: hookId,
sender: event.domEvent.currentTarget || event.domEvent.srcElement
})
}
})
}
var bodyMain = dmel.$([cls, "body", hookId].join("_"));
if (bodyMain) {
ed.bind(bodyMain, {
event: "click",
data: {
hookId: hookId
},
listener: rtb.hookClick
})
}
var logoNode = dmel.$([cls, "logo", hookId].join("_"));
if (logoNode) {
ed.bind(logoNode, {
event: "click",
data: {
hookId: hookId
},
listener: function(event) {
rt.utils.dom.event.stop(event.domEvent);
if (st.homeUrl) {
window.open(st.homeUrl, "_blank")
}
}
})
}
var xBtn = dmel.$([cls, "x", hookId].join("_"));
if (xBtn) {
ed.bind(xBtn, {
event: "click",
data: {
hookId: hookId
},
listener: function() {
rt.event.fire("hideBubble", {
hookId: hookId,
xBtn: true
})
}
});
ed.bind(xBtn, {
event: "mouseover",
data: {
el: xBtn,
pos: "-15px -15px"
},
listener: this.setBackgroundPosition
});
ed.bind(xBtn, {
event: "mouseout",
data: {
el: xBtn,
pos: "-15px 0"
},
listener: this.setBackgroundPosition
})
}
var helpBtn = dmel.$([cls, "help", hookId].join("_"));
if (helpBtn) {
ed.bind(helpBtn, {
event: "click",
listener: function(event) {
rt.utils.dom.event.stop(event.domEvent);
if (st.helpUrl) {
window.open(st.helpUrl, "_blank")
}
}
});
ed.bind(helpBtn, {
event: "mouseover",
data: {
el: helpBtn,
pos: "0 -15px"
},
listener: this.setBackgroundPosition
});
ed.bind(helpBtn, {
event: "mouseout",
data: {
el: helpBtn,
pos: "0 0"
},
listener: this.setBackgroundPosition
})
}
var btnNode = dmel.$([cls, "btn", hookId].join("_"));
if (btnNode) {
ed.bind(btnNode, {
event: "mouseover",
listener: function(event) {
event.element.className = [st.baseClass, " ", cls, "_btn ", cls, "_btn_over"].join("")
}
});
ed.bind(btnNode, {
event: "mouseout",
listener: function(event) {
event.element.className = [st.baseClass, " ", cls, "_btn "].join("")
}
})
}
rt.bubble.afterBubbleRendered(bodyMain, data, hook);
hook.bubble.node.style.display = "block";
rt.event.fire("bubbleShowing", {
hookId: hookId
})
},
renderBubble: function(width, height, hook) {
var rt = this.$root,
hookId = hook.id,
st = rt.settings,
bh = rt.helpers.getHookBehavior(hookId),
data = rt.helpers.getHookData(hookId),
bst = rt.bubble.settings,
skst = this.settings;
var logo = {
url: bh.bubbleLogoUrl || false,
width: Math.min(bh.bubbleLogoWidth || 53, 120),
height: Math.min(bh.bubbleLogoHeight || 12, 25)
};
var html = '<div id="<%= intextCls %>_<%= hookId %>" class="<%= cls %>" style="position:absolute; top:<%= hook.bubble.pos.top %>px; left:<%= hook.bubble.pos.left %>px; width:<%= width+2 %>px; height:<%= height+41 %>px; z-index:<%= zIndex+3 %>;"> <%-- Box --%> <div id="<%= intextCls %>_content_<%= hookId %>" class="<%= cls %>" style="position:absolute; top:<%= oY == \'T\' ? 0 : 8 %>px; left:0; width:<%= width+2 %>px; height:<%= height+33 %>px; box-shadow:0 0 8px 0 rgba(0, 0, 0, 0.25); -moz-box-shadow:0 0 8px 0 rgba(0, 0, 0, 0.25); -webkit-box-shadow:0 0 8px 0 rgba(0, 0, 0, 0.25);"> <%-- Header --%> <div class="<%= cls %>" style="position:absolute; width:<%= width %>px; height:33px; left:0; <%= oY == \'T\' ? \'bottom\' : \'top\' %>:0; z-index:1; background-color:#f1f1f2; border-<%= oY == \'T\' ? \'bottom\' : \'top\' %>:2px solid <%= themeColor %>; border-left:1px solid #a7a9ab; border-right:1px solid #a7a9ab;"> <% if (bh.favicon){ %><div class="<%= cls %>" style="position:absolute; width:16px; height:16px; left:14px; <%= oY == \'T\' ? \'bottom\' : \'top\' %>:8px; background:url(<%= bh.favicon %>) no-repeat scroll 0 0 transparent;"></div><% } %> <% if (bh.bubbleLogoUrl){ %> <div id="<%= intextCls %>_logo_<%= hookId %>" class="<%= cls %>" style="position:absolute; width:<%= bh.bubbleLogoWidth %>px; height:<%= bh.bubbleLogoHeight %>px; right:56px; top:<%= parseInt((33 - bh.bubbleLogoHeight) / 2) %>px; cursor:pointer; font-size:1px; background-image:url(<%= bh.bubbleLogoUrl %>)"></div> <% } else { %> <div id="<%= intextCls %>_logo_<%= hookId %>" class="<%= cls %>" style="position:absolute; width:53px; height:12px; right:56px; <%= oY == \'T\' ? \'bottom\' : \'top\' %>:9px; cursor:pointer; font-size:1px; <% if (b.IE || bst.oldFF){ %>background:url(<%= skinPath %>logo.png) no-repeat scroll 0 0 transparent;<% } %>"> <% if (!b.IE && !bst.oldFF){ %> <svg version="1.1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" x="0px" y="0px" width="53px" height="12px" viewBox="0 0 636 144" enable-background="new 0 0 636 144" xml:space="preserve"> <g> <!-- dot (first) --> <path id="<%= intextCls %>_logo_dot_<%= hookId %>_1" fill="<%= bh.theme == \'def\' ? \'#208CE5\' : themeColor %>" d="M16.918,24.865c5.848,0,10.57-4.735,10.57-10.583s-4.722-10.57-10.57-10.57 S6.334,8.434,6.334,14.282S11.07,24.865,16.918,24.865"/> <!-- in --> <path fill="#003366" d="M88.085,43.784H77.024c-17.149,0-31.181,14.031-31.181,31.182v34.796 c0,0.218,0.016,0.415,0.027,0.618v5.185c0,5.71-4.672,10.382-10.382,10.382h-0.467c-5.71,0-10.382-4.672-10.382-10.382V92.608 h0.015V45.889v-0.025c0-1.124-0.885-2.033-2.01-2.08h-11.49c-1.09,0.047-1.949,0.907-1.986,1.996v46.828h0.04 c-0.015,0.355-0.04,0.707-0.04,1.066v22.246c0,14.031,11.479,25.512,25.511,25.512h1.151c14.031,0,25.511-11.48,25.511-25.512 v-5.466v-4.62v-28.89c0.082-9.872,8.159-17.948,18.031-17.948h6.366c9.871,0,17.948,8.076,18.042,17.948v28.89v4.62v28.873 c0.013,0.023,0.013,0.034,0.013,0.048c0,1.111,0.883,2.008,1.983,2.057h11.505c1.077-0.036,1.936-0.887,1.985-1.973v-27.966v-5.659 V74.966C119.267,57.815,105.234,43.784,88.085,43.784"/> <!-- f (part) --> <path fill="#003366" d="M155.069,56.972v82.643c-0.072,0.992-0.886,1.78-1.903,1.818h-11.014 c-1.062-0.038-1.912-0.897-1.912-1.962c0-0.024,0-0.048-0.023-0.073V34.456c0.716-17.064,14.923-30.744,32.179-30.744h8.536 c0.025,0,0.038,0.011,0.06,0.011c1.053,0,1.915,0.849,1.974,1.901v11.037c-0.035,1.016-0.85,1.844-1.878,1.889h-8.692 c-9.509,0-17.327,7.75-17.327,17.268v6.301V56.972z"/> <!-- f (part) --> <path fill="#003366" d="M151.99,59.104h28.873c0.023-0.012,0.034-0.012,0.047-0.012 c1.111,0,2.008-0.884,2.057-1.984V45.604c-0.036-1.078-0.887-1.938-1.973-1.986h-27.965"/> <!-- o --> <path fill="#003366" d="M276.24,107.925h0.158V76.608c-0.37-18.164-15.248-32.825-33.494-32.825 h-16.756v0.022c-17.875,0.431-32.322,14.924-32.679,32.803h-0.026v31.316c0,18.213,14.601,33.064,32.705,33.496v0.012h16.589h0.021 h0.146C261.304,141.349,276.24,126.354,276.24,107.925 M208.93,107.925L208.93,107.925V77.289c0-9.914,8.096-18.02,18.021-18.02 h15.953c9.946,0,18.02,8.106,18.02,18.02v30.636h-0.167c0,9.949-8.074,18.021-17.999,18.021h-15.807 C217.026,125.946,208.93,117.874,208.93,107.925"/> <!-- l --> <path fill="#003366" d="M312.844,139.376L312.844,139.376c0,1.064-0.798,1.938-1.829,2.045h-11.816 c-1.027-0.107-1.837-0.98-1.837-2.045h-0.013V5.769h0.013c0-1.135,0.908-2.033,2.031-2.057h11.432 c1.124,0.024,2.019,0.922,2.019,2.057V139.376z"/> <!-- dot (second) --> <path id="<%= intextCls %>_logo_dot_<%= hookId %>_2" fill="<%= bh.theme == \'def\' ? \'#208CE5\' : themeColor %>" d="M341.662,24.865c5.848,0,10.57-4.735,10.57-10.583s-4.723-10.57-10.57-10.57 s-10.584,4.722-10.584,10.57S335.814,24.865,341.662,24.865"/> <!-- in (second) --> <path fill="#003366" d="M412.829,43.784h-11.061c-17.149,0-31.181,14.031-31.181,31.182v34.796 c0,0.218,0.016,0.415,0.026,0.618v5.185c0,5.71-4.672,10.382-10.382,10.382h-0.468c-5.71,0-10.382-4.672-10.382-10.382V92.608 h0.016V45.723v-0.025c0-1.123-0.885-2.033-2.01-2.08h-11.49c-1.091,0.047-1.949,0.908-1.986,1.996v46.994h0.04 c-0.015,0.355-0.04,0.707-0.04,1.066v22.246c0,14.031,11.479,25.512,25.512,25.512h1.15c14.031,0,25.512-11.48,25.512-25.512 v-5.466v-4.62v-28.89c0.082-9.872,8.158-17.948,18.029-17.948h6.367c9.871,0,17.947,8.076,18.041,17.948v28.89v4.62v28.873 c0.014,0.023,0.014,0.034,0.014,0.048c0,1.111,0.883,2.008,1.982,2.057h11.506c1.076-0.036,1.936-0.887,1.984-1.973v-27.966v-5.659 V74.966C444.01,57.815,429.979,43.784,412.829,43.784"/> <!-- k --> <path fill="#003366" d="M480.277,139.376L480.277,139.376V91.735h0.146h9.255l40.656,48.766 c0.599,0.549,1.15,0.906,1.841,0.932h16.073c0.882-0.025,2.869-0.322,1.794-2.056l-0.013-0.024l-47.58-56.777l44.599-36.815 c0.015-0.049,0.015-0.049,0.036-0.073c1.066-1.734-0.886-2.032-1.78-2.069H527.08c-0.621,0.024-1.15,0.324-1.666,0.791 l-36.812,31.075h-8.325V5.769c0-1.135-0.896-2.033-2.02-2.057h-11.422c-1.124,0.024-2.033,0.922-2.033,2.057v133.607 c0,1.064,0.803,1.938,1.844,2.045h11.802C479.476,141.313,480.277,140.44,480.277,139.376"/> <!-- s --> <path fill="#003366" d="M603.208,84.782H577.99c-6.91-0.114-12.508-5.785-12.508-12.783 c0-6.996,5.598-12.895,12.508-12.895h39.271c1.146,0,2.08-0.959,2.08-2.111v0.191V45.752v-0.037c0-1.164-0.935-2.097-2.08-2.097 H577.99c-15.451,0-28.008,12.73-28.008,28.381c0,15.651,12.557,28.381,28.008,28.27h24.252c6.911,0.111,12.508,5.812,12.508,12.795 c0,6.996-5.597,12.896-12.508,12.896H591.56l0.001-0.014h-28.874c-0.022,0.014-0.034,0.014-0.047,0.014 c-1.11,0-2.007,0.896-2.056,2.01v11.449c0.035,1.092,0.886,1.963,1.973,2.014h0.225h27.74h12.224 c15.209-0.279,27.491-12.9,27.491-28.369C630.236,97.737,618.191,85.202,603.208,84.782"/> </g> </svg> <% } %> </div> <% } %> <div class="<%= cls %> <%= intextCls %>_bg" id="<%= intextCls %>_help_<%= hookId %>" style="position:absolute; width:15px; height:15px; right:29px; <%= oY == \'T\' ? \'bottom\' : \'top\' %>:7px; display:block; background-position:0 0; cursor:pointer; font-size:1px;"></div> <div class="<%= cls %> <%= intextCls %>_bg" id="<%= intextCls %>_x_<%= hookId %>" style="position:absolute; width:15px; height:15px; right:13px; <%= oY == \'T\' ? \'bottom\' : \'top\' %>:7px; background-position:-15px 0; cursor:pointer; font-size:1px;"></div> </div> <%-- Body --%> <div id="<%= intextCls %>_body_<%= hookId %>" class="<%= cls %> <%= intextCls %>_bodyMain" style="position:absolute; <%= oY == \'T\' ? \'top\' : \'bottom\' %>:0px; left:0; width:<%= width %>px; height:<%= height %>px; z-index:2; background-color:#ffffff; cursor: pointer; border-<%= oY == \'T\' ? \'top\' : \'bottom\' %>:1px solid #a7a9ab; border-left:1px solid #a7a9ab; border-right:1px solid #a7a9ab;"> <%= rt.bubble.renderAdsContent(hook, data) %> </div> </div> <% if (!hook.externalTag){ %> <%-- Tail --%> <div class="<%= cls %>" style="position:absolute; <%= oY == \'T\' ? \'bottom\' : \'top\' %>:0; <%= oX == \'L\' ? \'right\' : \'left\' %>:15px; width:15px; height:8px; font-size:1px; <% if (b.IE || bst.oldFF){ %>background:url(<%= skinPath %>tail.png) no-repeat scroll <%= tailBgLeft %>px <%= tailBgTop %>px transparent;<% } %>"> <% if (!b.IE && !bst.oldFF){ %> <svg version="1.0" xmlns="http://www.w3.org/2000/svg" width="15px" height="8px" viewBox="0 0 30 16" preserveAspectRatio="xMidYMid meet" style="position:absolute; font-size:1px;"> <g transform="translate(0,16) scale(0.1,-0.1)" fill="<%= themeColor %>" stroke="none"> <% if (oY == \'T\'){ %> <path d="M37 138 c11 -13 30 -42 42 -65 22 -44 54 -73 81 -73 20 0 52 34 75 80 10 19 27 45 38 57 l20 23 -138 0 -138 0 20 -22z"/> <% } else { %> <path d="M109 143 c-9 -10 -31 -43 -49 -73 -18 -30 -38 -58 -44 -62 -6 -4 51 -8 126 -8 l137 0 -22 36 c-73 118 -114 147 -148 107z"/> <% } %> </g> </svg> <% } %> </div> <% } %></div>';
return rt.utils.VeST(html, {
rt: rt,
st: st,
bh: bh,
b: rt.browser,
hookId: hookId,
hook: hook,
data: data,
intextCls: bst.cls,
cls: st.baseClass,
bst: bst,
width: width,
height: height,
oX: hook.orientationX,
oY: hook.orientationY,
zIndex: st.baseZIndex + 100,
logo: logo,
themeColor: rt.products[hook.type].settings.themes.color[bh.theme],
skinPath: rt.bubble.getSkinPath(this.$id),
tailBgLeft: skst.tailMap[bh.theme],
tailBgTop: hook.orientationY == "T" ? -8 : 0
}, hookId + "brand", true)
},
setBackgroundPosition: function(event) {
event.data.el.style.backgroundPosition = event.data.pos
}
}, {
settings: {
rv: 1,
tailMap: {
def: 0,
lightBlue: -15,
green: -30,
orange: -45,
red: -60,
pink: -75,
purple: -90
}
}
}, true);
skins.brand.bind({
event: "brandBubbleMouseover",
listener: {
bubleMouseover: function(event) {
var boxShadow = this.$root.utils.dom.style.supports("boxShadow");
if (boxShadow) {
event.data.sender.style[boxShadow] = "0 0 8px 0 rgba(0, 0, 0, 0.5)"
}
}
}
});
skins.brand.bind({
event: "brandBubbleMouseout",
listener: {
bubleMouseout: function(event) {
var boxShadow = this.$root.utils.dom.style.supports("boxShadow");
if (boxShadow) {
event.data.sender.style[boxShadow] = "0 0 8px 0 rgba(0, 0, 0, 0.25)"
}
}
}
});
skins.$create("less", {
init: function() {
var rtb = this.$root.bubble,
skinPath = rtb.getSkinPath(this.$id);
rtb.preloadImages(skinPath, "x")
},
showBubble: function(hookId) {
var rt = this.$root,
ut = rt.utils,
dmel = ut.dom.element,
st = rt.settings,
hook = st.hooksMap[hookId],
data = rt.helpers.getHookData(hookId),
cls = rt.bubble.settings.cls,
ed = rt.event.dom;
var pos = hook.bubble.pos = rt.bubble.adjustBubblePosition(hook, {
width: data.width + 11,
height: data.height + 22
});
if (hook.externalTag) {
pos.top += hook.orientationY == "T" ? 60 : -60;
var hookWidth = dmel.getActualWidth(hook.node);
pos.left += hook.orientationX == "L" ? hookWidth + 20 : -20
}
if (hook.bubble.node && hook.bubble.node.parentNode) {
var parent = hook.bubble.node.parentNode;
parent.removeChild(hook.bubble.node)
}
hook.bubble.node = ut.dom.createDOMFragment({
tag: "div",
cls: st.baseClass,
parent: document.body,
style: {
display: "none"
},
innerHTML: this.renderBubble(data.width, data.height, hook)
});
var bubbleNode = ut.dom.element.$([cls, "content", hookId].join("_"));
if (bubbleNode) {
ed.bind(bubbleNode, {
event: "mouseenter",
data: {
hookId: hookId
},
listener: function(event) {
rt.event.fire("bubbleMouseover", {
hookId: hookId,
sender: event.domEvent.currentTarget || event.domEvent.srcElement
})
}
});
ed.bind(bubbleNode, {
event: "mouseleave",
data: {
hookId: hookId
},
listener: function(event) {
rt.event.fire("bubbleMouseout", {
hookId: hookId,
sender: event.domEvent.currentTarget || event.domEvent.srcElement
})
}
})
}
var bodyMain = ut.dom.element.$([cls, "body", hookId].join("_"));
if (bodyMain) {
ed.bind(bodyMain, {
event: "click",
data: {
hookId: hookId
},
listener: rt.bubble.hookClick
})
}
var xNode = ut.dom.element.$([cls, "x", hookId].join("_"));
if (xNode) {
ed.bind(xNode, {
event: "click",
data: {
hookId: hookId
},
listener: function() {
rt.event.fire("hideBubble", {
hookId: hookId,
xBtn: true
})
}
})
}
rt.bubble.afterBubbleRendered(bodyMain, data, hook);
hook.bubble.node.style.display = "block";
rt.event.fire("bubbleShowing", {
hookId: hookId
})
},
renderBubble: function(width, height, hook) {
var rt = this.$root,
st = rt.settings,
bst = rt.bubble.settings,
cls = st.baseClass,
hookId = hook.id,
b = rt.browser,
skinPath = rt.bubble.getSkinPath(this.$id),
data = rt.helpers.getHookData(hookId);
var html = '<div id="<%= intextCls %>_<%= hookId %>" class="<%= cls %>" style="<%= abs %> width:<%= width+11 %>px; height:<%= height+22 %>px; top:<%= hook.bubble.pos.top %>px; left:<%= hook.bubble.pos.left %>px; z-index:<%= zIndex+3 %>;"> <% if (!hook.externalTag){ %> <div class="<%= cls %> <%= intextCls %>_head" style="width:100%; height:22px; <%= abs %> left:0; z-index:<%= zIndex+4 %>; <%= (oY == \'T\') ? \'bottom:0;\' : \'top:0;\' %>" > <div id="<%= intextCls %>_x_<%= hookId %>" class="<%= cls %> <%= intextCls %>_x" style="<%= abs %> width:22px; height:22px; background:transparent url(<%= skinPath %>x.png) no-repeat scroll 0 0; cursor:pointer; top:<%= (oY == \'T\') ? \'2px\' : 0 %>; <%= (oX == \'L\') ? \'right:0\' : \'left:0\' %>;"></div> </div> <% } %> <div id="<%= intextCls %>_content_<%= hookId %>" class="<%= cls %> <%= intextCls %>_body" style="<%= abs%> width:<%= width %>px; height:<%= height %>px; zindex:<%= zIndex+3 %>; top:<%= (oY == \'T\') ? 0 : \'22px\' %>; <%= (oX == \'L\') ? \'left:0\' : \'left:11px;\' %>; "> <div id="<%= intextCls %>_body_<%= hookId %>" class="<%= cls %> <%= intextCls %>_bodyMain" style="<%= abs %> top:0; left:0; width:<%= width %>px; height:<%= height %>px; cursor:pointer; color:#000000;"> <%= rt.bubble.renderAdsContent(hook, data) %> </div> </div> </div>';
return rt.utils.VeST(html, {
rt: rt,
hookId: hookId,
hook: hook,
data: data,
intextCls: bst.cls,
cls: st.baseClass,
width: width,
height: height,
oX: hook.orientationX,
oY: hook.orientationY,
abs: "position:absolute;",
zIndex: st.baseZIndex + 100,
skinPath: skinPath
}, hookId + "less", true)
}
}, {
settings: {}
}, true);
event.fire("main")
} catch (ex) {
if (typeof $root == "object" && $root.logger && $root.logger.error) {
$root.logger.error("CatchAll. Exception: " + ex.message, window)
}
}
})() |
#2 JavaScript::Eval (size: 221775, repeated: 1) (function() {
try {
var appNamespace = "$ice";
if (window[appNamespace]) {
if (window[appNamespace].logger && window[appNamespace].logger.error) {
window[appNamespace].logger.error("Global namespace already defined. Aborting.", this)
}
return
}
var what = function(obj) {
return typeof obj == "undefined" || obj === null ? "undefined" : ({}).toString.call(obj).match(/\s([a-z|A-Z]+)/)[1].toLowerCase()
};
var $extend = function(source) {
if (this.$root.what(source) != "object") {
this.$root.logger.warn("source is not an object", this);
return
}
var key;
for (key in source) {
this[key] = source[key]
}
return this
};
var $fn = function(key, fn) {
if (!this || this == window) {
return
}
if (this.$root.what(fn) != "function") {
this.$root.logger.warn(key + " is not a function", this);
return
}
this[key] = fn;
fn.$id = key;
fn.$parent = this;
fn.$root = this.$root
};
var $create = function(id, source, extension, bindable) {
var wsource = what(source),
parent = this || window,
node, key;
if (!/object|function/.test(wsource)) {
return null
}
if (parent[id]) {
node = parent[id]
} else {
var maker = function() {
var node = function() {};
node.prototype.$id = id;
node.prototype.$parent = parent;
node.prototype.$root = parent == window ? null : parent.$root;
node.prototype.$create = $create;
node.prototype.$extend = $extend;
node.prototype.$fn = $fn;
if (bindable && parent != window && parent.$root.event) {
node.prototype.bind = parent.$root.event.bind;
node.prototype.unbind = parent.$root.event.unbind;
node.prototype.fire = parent.$root.event.fire
}
return node
};
node = parent[id] = new(new maker())
}
if (what(extension) == "object") {
node.$extend(extension)
}
for (key in source) {
switch (what(source[key])) {
case "function":
node.$fn(key, source[key]);
break;
case "object":
node.$create(key, source[key]);
break;
default:
node[key] = source[key]
}
}
return node
};
var NodesArray = function() {
this.nodes = []
};
NodesArray.prototype = {
toString: function(separator) {
var result = [],
i, len;
for (i = 0, len = this.nodes.length; i < len; i++) {
result.unshift(this.nodes[i].$id)
}
return result.join(separator || ".")
}
};
var $root = $create(appNamespace, {}, null, false);
$root.what = what;
$root.$root = $root;
$root.$extend({
NodesArray: NodesArray,
$fn: $fn
});
$root.$create("plugins", {}, {}, true);
var versionFile = "ice";
var event = $root.$create("event", {
bind: function(o) {
var rt = this.$root,
ev = rt.event,
ls, key, clone, prop, err = null;
if (!o.event) {
err = ev.msgs.me
} else {
if (!o.listener) {
err = ev.msgs.ml
}
}
if (err) {
rt.logger.error(err, this);
return false
}
o.$root = rt;
if (!ev._listeners[o.event]) {
ev._listeners[o.event] = []
}
ls = ev._listeners[o.event];
var listenerType = rt.what(o.listener);
if (listenerType == "function") {
ls[ls.length] = o
} else {
if (listenerType == "object") {
for (key in o.listener) {
if (this != ev) {
this.$fn(key, o.listener[key])
}
clone = {};
for (prop in o) {
clone[prop] = o[prop]
}
clone.listener = o.listener[key];
ls[ls.length] = clone
}
}
}
return true
},
unbind: function(event, listener) {
var rt = this.$root,
ev = rt.event,
i, len, ls = ev._listeners[event];
if (rt.what(ls) != "array") {
return false
}
if (!listener) {
delete ev._listeners[event]
} else {
for (i = 0, len = ls.length; i < len; i++) {
if (ls[i].listener === listener) {
ls.splice(i--, 1)
}
}
}
return true
},
fire: function(event, data, delay) {
var rt = this.$root,
ls = rt.event._listeners[event],
func, context, o, hasData = rt.what(data) != "undefined",
time, msg;
if (!event || rt.event.disabled || (ls && ls.disabled) || rt.what(ls) != "array") {
return false
}
for (var i = 0, len = ls.length; i < len; i++) {
o = ls[i];
if (hasData) {
o.data = data
}
func = o.listener;
context = func.$parent || window;
if (context == window) {
rt.logger.error("Probable Error: Context is window object. event: " + event, this.fire)
}
if (rt.event.log) {
msg = ['Fire "', func.$id || "Anonymous", '" on "', event, '".', data && data.hookId ? " hookId:" + data.hookId : ""].join("")
}
time = delay && rt.what(delay) == "number" ? delay : o.delay;
if (time) {
return setTimeout((function() {
var clone = rt.utils.object.clone(o);
return function() {
if (msg) {
rt.logger.log(msg, func)
}
func.call(context, clone)
}
}()), time)
} else {
if (msg) {
rt.logger.log(msg, func)
}
func.call(context, o)
}
}
},
repeat: function(event, interval, data, delay) {
var rt = this.$root,
ls = rt.event._listeners[event],
func, context, o, hasData = rt.what(data) != "undefined",
msg, wrapper;
if (!event || rt.event.disabled || (ls && ls.disabled) || rt.what(ls) != "array" || !interval || rt.what(interval) != "number") {
return false
}
if (!delay || rt.what(delay) != "number") {
delay = null
}
for (var i = 0, len = ls.length; i < len; i++) {
o = ls[i];
if (o.repeat || o.delay) {
return
}
if (hasData) {
o.data = data
}
func = o.listener;
context = func.$parent || window;
if (rt.event.log) {
msg = ['Repeat "', func.$id || "Anonymous", '" on "', event, '".'].join("")
}
o.interval = interval;
o.counter = 0;
wrapper = function() {
if (msg && !o.counter) {
rt.logger.log(msg, func)
}
o.counter++;
func.call(context, o)
};
if (delay) {
o.delay = setTimeout(function() {
o.repeat = setInterval(wrapper, interval)
}, delay)
} else {
o.repeat = setInterval(wrapper, interval)
}
}
},
stop: function(event) {
var rt = this.$root,
ls = rt.event._listeners[event],
func, o;
if (!event || !ls) {
return false
}
for (var i = 0, len = ls.length; i < len; i++) {
o = ls[i];
clearInterval(o.repeat);
clearTimeout(o.delay);
delete o.repeat;
delete o.delay;
func = o.listener;
if (rt.event.log) {
rt.logger.log(['Stop "', func.$id || "Anonymous", '" on "', event, '" after ', o.counter, " repetitions."].join(""), func)
}
o.counter = 0
}
},
disable: function(event) {
this.$root.event.able(event, true)
},
enable: function(event) {
this.$root.event.able(event, false)
},
able: function(event, disabled) {
var rt = this.$root,
i;
if (event) {
if (rt.what(event) == "string") {
event = [event]
}
for (i = 0; i < event.length; i++) {
rt.event._listeners[event].disabled = disabled
}
} else {
rt.event.disabled = disabled
}
}
}, {
_listeners: {},
log: true,
msgs: {
me: "Error: Missing event.",
ml: "Error: Misssing listener."
}
}, false);
event.$create("dom", {
bind: function(element, o) {
var rt = this.$root,
nt = rt.settings.nodeTypes,
key, clone, prop, err = null,
func;
function isAChildOf(parent, child) {
if (parent === child) {
return false
}
while (child && child !== parent) {
child = child.parentNode
}
return child === parent
}
if (!element || !(element.nodeType == nt.ELEMENT || element.nodeType == nt.DOCUMENT || element == window)) {
err = this.msgs.mbe
} else {
if (!o.event) {
err = this.$parent.msgs.me
} else {
if (!o.listener) {
err = this.$parent.msgs.ml
}
}
}
if (err) {
rt.logger.error(err, this);
return false
}
if (!element.$iceId) {
element.$iceId = ++this.elementBinder
}
o.element = element;
o.$root = rt;
if (rt.what(o.listener) == "function") {
o.listener = {
a: o.listener
}
} else {
if (rt.what(o.listener) != "object") {
return
}
}
for (key in o.listener) {
clone = {};
for (prop in o) {
clone[prop] = o[prop]
}
clone.listener = o.listener[key];
if (element.addEventListener) {
if (/mouseenter|mouseleave/.test(clone.event)) {
clone.simEvent = clone.event;
clone.event = clone.event.replace(/enter/, "over").replace(/leave/, "out")
}
}
func = (function() {
var reclone = rt.utils.object.clone(clone);
return function(domEvt) {
if (!domEvt) {
domEvt = window.event
}
if (/mouseenter|mouseleave/.test(reclone.simEvent) && domEvt.relatedTarget && this == domEvt.relatedTarget || (isAChildOf(this, domEvt.relatedTarget))) {
return
}
reclone.domEvent = domEvt;
rt.event.dom.fire(reclone)
}
})();
if (element.addEventListener) {
element.addEventListener(clone.event, func, false)
} else {
if (element.attachEvent) {
element.attachEvent("on" + clone.event, func)
}
}
var eID = element.$iceId;
var eL = this._listeners;
if (!eL[eID]) {
eL[eID] = {}
}
if (!eL[eID][clone.event]) {
eL[eID][clone.event] = []
}
rt.utils.array.push(eL[eID][clone.event], {
listener: func,
original: clone.listener
})
}
return true
},
unbind: function(element, event, listener) {
var rt = this.$root,
nt = rt.settings.nodeTypes,
i;
if (!element || !element.$iceId || !(element.nodeType == nt.ELEMENT || element.nodeType == nt.DOCUMENT || element == window)) {
rt.logger.error(this.msgs.mbe, this);
return
}
var eID = element.$iceId;
var ls = rt.event.dom._listeners[eID];
if (!ls || !ls[event]) {
return
}
for (i = 0; i < ls[event].length; i++) {
if (ls[event][i].original == listener) {
if (element.removeEventListener) {
element.removeEventListener(event, ls[event][i].listener, false)
} else {
if (element.detachEvent) {
element.detachEvent("on" + event, ls[event][i].listener)
}
}
ls[event].splice(--i, 1)
}
}
if (ls[event].length == 0) {
delete ls[event]
}
return true
},
fire: function(o) {
var rt = this.$root,
func = o.listener,
context = func.$parent || window,
msg;
if (rt.event.log) {
msg = ['Fire "', func.$id || "Anonymous", '" on "', o.event, '".', o.data && o.data.hookId ? " hookId:" + o.data.hookId : ""].join("")
}
if (o.delay && rt.what(o.delay) == "number") {
setTimeout(function() {
if (msg) {
rt.logger.log(msg, func)
}
func.call(context, o)
}, o.delay)
} else {
if (msg) {
rt.logger.log(msg, func)
}
func.call(context, o)
}
}
}, {
_listeners: {},
elementBinder: 0,
msgs: {
mbe: "Error: Missing or bad element."
}
}, false);
$root.$create("logger", {
log: function(message, context, type) {
if (!type) {
type = "log"
}
this.history[this.history.length] = {
message: message,
type: type,
time: (new Date()).getTime(),
context: context
};
if (this.output == "console" && this.$root.what(window.console) != "undefined") {
console[type](message, this.descent(context))
}
},
info: function(message, context) {
this.log(message, context, "info")
},
warn: function(message, context) {
this.log(message, context, "warn")
},
error: function(message, context, kill) {
this.log(message, context, "error");
if (kill) {
this.$root.event.disable()
}
if (this.errorReporting >= Math.ceil(Math.random() * 100)) {
this.$root.event.fire("sendErrorReport", {
msg: message
})
}
},
descent: function(context) {
var result = new this.$root.NodesArray;
while (context && context.$root && context != window) {
result.nodes[result.nodes.length] = context;
context = context.$parent
}
return result
}
}, {
history: [],
output: "none",
errorReporting: -1
});
$root.$create("browser", new function() {
var ua = this.ua = navigator.userAgent;
var uac = function(str) {
return ua.indexOf(str) != -1
};
var _found = false;
var ver = function(browser) {
if (_found) {
return false
}
var match = ua.match(new RegExp(browser + ".?([0-9][0-9\\.]+)"));
if (match != null) {
_found = true;
return match[1]
}
return false
};
this.IE = ver("MSIE");
if (this.IE == "7.0" && $root.what(Array.isArray) == "function") {
this.IE = "9.0"
}
this.Firefox = ver("Firefox");
this.Chrome = ver("Chrome");
this.Safari = this.Chrome ? false : uac("Safari") && ver("Version");
this.MobileSafari = this.Safari && uac("Mobile") ? this.Safari : false;
this.Opera = uac("Opera") && uac("Presto") ? ver("Version") || ver("Opera") : false;
this.OperaMini = this.Opera && uac("Opera Mini");
this.ucweb = ver("UCWEB") || (uac("UCWEB") ? ver("Browser") : false);
_found = false;
this.AppleWebKit = ver("AppleWebKit");
this.Gecko = ver("Gecko");
this.Mozilla = !this.Gecko && !this.AppleWebKit && uac("Mozilla/");
_found = false;
this.WindowsMobile = uac("Windows Phone OS");
this.Windows = uac("Windows ");
this.Linux = !this.Windows && (uac("Linux ") || uac("Linux;"));
this.Mac = !this.Windows && !this.Linux && uac("Mac ");
this.iPhone = !this.Windows && !this.Linux && uac("iPhone");
this.iPad = !this.Windows && !this.Linux && uac("iPad");
this.Android = (!this.Windows && uac("Android")) ? ver("Android") : false;
this.Nokia = uac("Nokia");
this.getOS = function() {
var os = ["WindowsMobile", "Windows", "iPhone", "Mac", "iPad", "Android", "Nokia", "Linux"],
i, leni = os.length;
for (i = 0; i < leni; i++) {
if (this[os[i]]) {
return os[i]
}
}
return "unknown"
};
this.isMobile = function() {
return !!(this.iPhone || this.iPad || this.Android || this.WindowsMobile || this.OperaMini || this.ucweb)
};
this.getName = function() {
var names = ["IE", "Firefox", "Chrome", "MobileSafari", "Safari", "Opera", "ucweb", "Gecko", "AppleWebKit", "Mozilla"];
for (var i = 0, leni = names.length; i < leni; i++) {
if (this[names[i]]) {
return names[i]
}
}
return "unknown"
};
this.getVersion = function(asFloat) {
var ver = this.IE || this.Firefox || this.Chrome || this.MobileSafari || this.Safari || this.Opera || this.AppleWebKit || this.ucweb || "unknown";
return asFloat ? parseFloat(ver) || -1 : ver
};
this.toString = this.getValue = function() {
return [this.getName(), this.getVersion(), this.getOS()].join(" ")
}
});
var utils = $root.$create("utils", {
VeST: function(template, data, name) {
var fn, v = this.VeST,
c;
if (!(c = v.cache)) {
c = v.cache = {};
v.encQ = function(m) {
return m.split("'").join("\t")
};
v.decQ = function(m) {
return m.split("\t").join("'")
}
}
if (name && c[name]) {
fn = c[name]
} else {
template = template.replace(/<%\-\-[\s\S]*?\-\-%>/g, "");
var tjs = template.replace(/[\r\t\n]/g, " ").replace(/<%.*?%>/g, v.encQ).replace(/'/g, "\\'").replace(/<%.*?%>/g, v.decQ).replace(/<%=(.*?)%>/g, "',$1,'").split("<%").join("');").split("%>").join("p.push('");
tjs = ["var p=[];with(obj||{}){p.push('", tjs, "');}return p.join('');"].join("");
fn = new Function("obj", tjs);
if (name) {
c[name] = fn
}
}
return fn(data)
},
doRectsOverlap: function(r1, r2) {
var temp;
if (r2[0] < r1[0]) {
temp = r1;
r1 = r2;
r2 = temp
}
if (r1[2] < r2[0] || r1[0] > r2[2]) {
return false
}
if (r2[1] < r1[1]) {
temp = r1;
r1 = r2;
r2 = temp
}
if (r1[3] < r2[1] || r1[1] > r2[3]) {
return false
}
return true
}
});
utils.$create("number", {
get: function(counter) {
return this.counters[counter]
},
next: function(counter, start) {
if (this.$root.what(this.counters[counter]) == "undefined") {
this.counters[counter] = this.$root.what(start) == "number" ? start : 0
} else {
this.counters[counter]++
}
return this.counters[counter]
}
}, {
counters: {}
});
utils.$create("string", {
capitalize: function(str) {
var arr = str.split(/\s+/);
if (arr.length > 2) {
arr[0] = arr[0].charAt(0).toUpperCase() + arr[0].slice(1)
} else {
for (var i = 0, len = arr.length; i < len; ++i) {
arr[i] = arr[i].charAt(0).toUpperCase() + arr[i].slice(1)
}
}
return arr.join(" ")
},
qw: function(str) {
return this.trim(str).split(/\s+/)
},
toObject: function(str, key, decode) {
if (str.indexOf("=") == -1) {
return null
}
if (str.indexOf("?") == 0) {
str = str.substring(1)
}
var obj = {},
pairs = str.split("&"),
kv;
for (var i = 0, leni = pairs.length; i < leni; i++) {
kv = pairs[i].split("=");
if (kv.length != 2) {
continue
}
if (decode) {
kv[0] = decodeURIComponent(kv[0]);
kv[1] = decodeURIComponent(kv[1])
}
obj[kv[0]] = kv[1]
}
return this.$root.what(key) != "undefined" ? obj[key] : obj
},
trim: function(str) {
return str.replace(/^\s+|\s+$/g, "")
},
truncate: function(str, len, suffix) {
return str.length <= len ? str : str.substring(0, len) + (suffix || "")
},
truncateToChar: function(str, len, sep, suffix) {
var str2 = str.length <= len ? str : str.substring(0, len);
if (str2.length < str.length) {
str2 = str2.substr(0, str2.lastIndexOf(sep)) + (suffix || "")
}
return str2
}
});
utils.$create("array", {
clone: function(origin, deep) {
var clone = [],
i, leni, rt = this.$root;
for (i = 0, leni = origin.length; i < leni; i++) {
if (deep && /object|array/.test(rt.what(origin[i])) && (!this.cloneDepth || this.cloneDepth < 10)) {
if (!this.cloneDepth) {
this.cloneDepth = 0
}
this.cloneDepth++;
clone[i] = rt.what(origin[i]) == "object" ? this.$parent.object.clone(origin[i], deep) : this.clone(origin[i], deep)
} else {
clone[i] = origin[i]
}
}
delete this.cloneDepth;
return clone
},
concat: function() {
var arr = [];
for (var i = 0, leni = arguments.length; i < leni; i++) {
for (var j = 0, lenj = arguments[i].length; j < lenj; j++) {
arr[arr.length] = arguments[i][j]
}
}
return arr
},
discard: function(arr, item) {
for (var i = arr.length - 1; i >= 0; i--) {
if (arr[i] == item) {
arr.splice(i, 1)
}
}
return arr
},
indexOf: function(arr, item) {
for (var i = 0, leni = arr.length; i < leni; i++) {
if (arr[i] == item) {
return i
}
}
return -1
},
insertionSort: function(arr, prop, asc) {
var i, j, value;
for (i = 1; i < arr.length; i++) {
value = arr[i];
j = i - 1;
while (j >= 0 && (asc ? arr[j][prop] > value[prop] : arr[j][prop] < value[prop])) {
arr[j + 1] = arr[j];
j--
}
arr[j + 1] = value
}
},
map: function(arr, mapper) {
for (var i = 0, leni = arr.length, res = []; i < leni; i++) {
res[i] = mapper(arr[i])
}
return res
},
push: function() {
if (arguments.length < 2) {
return
}
var arr = arguments[0];
for (var i = 1; i < arguments.length; i++) {
arr[arr.length] = arguments[i]
}
},
range: function(start, end) {
var arr = [],
i, what = this.$root.what;
if (what(start) == "number" && what(end) == "number" && start <= end) {
for (i = start; i <= end; i++) {
arr[arr.length] = i
}
}
return arr
},
sum: function(arr) {
var sum = 0,
i, len, what = this.$root.what;
for (i = 0, len = arr.length; i < len; i++) {
if (what(arr[i]) == "number") {
sum += arr[i]
}
}
return sum
},
toObject: function(arr, object, value) {
if (!arr) {
return object
}
var what = this.$root.what;
if (what(arr) != "array") {
arr = [arr]
}
if (!object) {
object = {}
}
var item, key, val;
for (var i = 0, leni = arr.length; i < leni; i++) {
item = arr[i];
key = what(item) == "string" ? item : item != null && what(item.toString) == "function" ? item.toString() : null;
if (key) {
val = (what(value) == "undefined") ? key : (what(value) == "function") ? value(key) : value;
object[key] = val
}
}
return object
},
uniq: function(arr) {
var i, j;
for (i = 0; i < arr.length - 1; i++) {
for (j = i + 1; j < arr.length; j++) {
if (arr[i] === arr[j]) {
arr.splice(j, 1);
j--
}
}
}
return arr
}
});
utils.$create("object", {
clean: function(obj) {
var res = {},
key, val, what = this.$root.what;
for (key in obj) {
val = obj[key];
if (what(val) == "undefined" || val === "" || val === null) {
continue
}
res[key] = obj[key]
}
return res
},
clone: function(origin, deep) {
var clone = {},
key, rt = this.$root;
for (key in origin) {
if (deep && /object|array/.test(rt.what(origin[key])) && (!this.cloneDepth || this.cloneDepth < 10)) {
if (!this.cloneDepth) {
this.cloneDepth = 0
}
this.cloneDepth++;
clone[key] = rt.what(origin[key]) == "object" ? this.clone(origin[key], deep) : this.$parent.array.clone(origin[key], deep)
} else {
clone[key] = origin[key]
}
}
delete this.cloneDepth;
return clone
},
extend: function() {
if (arguments.length < 2) {
return arguments.length ? arguments[0] : {}
}
var key, rt = this.$root,
i, leni, dest = arguments[0],
source;
if (rt.what(dest) != "object") {
return dest
}
for (i = 1, leni = arguments.length; i < leni; i++) {
source = arguments[i];
if (rt.what(source) == "object") {
for (key in source) {
dest[key] = source[key]
}
}
}
return dest
},
hasKey: function(obj, keys) {
if (!(keys instanceof Array)) {
keys = [keys]
}
for (var i = 0, leni = keys.length, what = this.$root.what; i < leni; i++) {
if (what(obj[keys[i]]) != "undefined") {
return true
}
}
return false
},
keys: function(obj) {
var arr = [];
for (var key in obj) {
arr[arr.length] = key
}
return arr
},
renamePorpery: function(o, oldName, newName) {
var rt = this.$root;
if (rt.what(o[oldName]) == "undefined") {
return
}
o[newName] = o[oldName];
delete o[oldName]
},
stringify: function(json, depth) {
var res, rt = this.$root,
type = rt.what(json),
push = rt.utils.array.push,
i, leni, key, sgf = this.stringify;
if (!depth) {
depth = 1
}
if (depth > 10) {
res = '"Exceeded max depth of 10 levels."'
} else {
if (type == "undefined") {
res = "undefined"
} else {
if (type == "number" || type == "boolean") {
res = json
} else {
if (type == "string") {
res = ['"', json.replace(/"/g, '\\"'), '"'].join("")
} else {
if (type == "function") {
res = '"[Function]"'
} else {
if (type == "array") {
res = ["["];
for (i = 0, leni = json.length; i < leni; i++) {
push(res, sgf.call(this, json[i], depth + 1), ",")
}
if (res.length > 1) {
res.pop()
}
push(res, "]");
res = res.join("")
} else {
if (json === null) {
res = "null"
} else {
if (type == "object") {
res = ["{"];
for (key in json) {
push(res, '"', key.replace(/"/g, '\\"'), '":', sgf.call(this, json[key], depth + 1), ",")
}
if (res.length > 1) {
res.pop()
}
push(res, "}");
res = res.join("")
}
}
}
}
}
}
}
}
return res
},
toQueryString: function(obj, useEncoding) {
var res = [],
key, value, push = this.$parent.array.push;
for (key in obj) {
if (useEncoding) {
key = encodeURIComponent(key);
value = encodeURIComponent(obj[key])
} else {
value = obj[key]
}
push(res, res.length ? "&" : "?", key, "=", value)
}
return res.join("")
},
values: function(obj) {
var arr = [];
for (var key in obj) {
arr[arr.length] = obj[key]
}
return arr
}
});
utils.$create("date", {
now: function() {
return new Date().getTime()
}
});
utils.$create("timer", {
start: function(id) {
var time = this.$root.utils.date.now();
this.times[id] = {
start: time
};
return time
},
stop: function(id) {
var rt = this.$root,
o = this.times[id];
if (!o || !o.start) {
rt.logger.warn(['Trying to stop timer "', id, '" which does not exist.'].join(""), this.stop);
return 0
}
o.stop = rt.utils.date.now();
o.delta = o.stop - o.start;
return o.delta
},
delta: function(id) {
var o = this.times[id];
return o && o.delta ? o.delta : 0
},
poll: function(id) {
var o = this.times[id];
if (!o || !o.start) {
return 0
}
return (o.stop || this.$root.utils.date.now()) - o.start
},
clear: function(id) {
delete this.times[id]
}
}, {
times: {}
});
utils.$create("cookie", {
set: function(name, value, expiration) {
expiration = expiration ? ("; expires=" + (this.$root.what(expiration) == "date" ? expiration.toUTCString() : new Date((new Date()).getTime() + expiration * 1000).toUTCString())) : "";
var parts = location.hostname.split(".");
var domain = "; domain=" + [parts[parts.length - 2], parts[parts.length - 1]].join(".");
document.cookie = [name, "=", encodeURIComponent(value), expiration, domain, "; path=/"].join("");
return true
},
has: function(name) {
return this.$parent.array.indexOf(this.$parent.array.map(document.cookie.split(/;\s*/), function(item) {
return item.split("=")[0]
}), name) > -1
},
remove: function(name) {
var parts = location.hostname.split(".");
var domain = "; domain=" + [parts[parts.length - 2], parts[parts.length - 1]].join(".");
document.cookie = [name, "=;expires=", new Date((new Date()).getTime() - 60000).toUTCString(), domain, "; path=/"].join("");
return true
},
get: function(name) {
var cookies = {};
this.$parent.array.map(document.cookie.split(/;\s*/), function(cookie) {
var p = cookie.split("=");
cookies[p[0]] = p[1];
return null
});
return decodeURIComponent(cookies[name]) || null
}
});
utils.$create("base64", {
init: function(str) {
if (!this.reverseBase64Chars) {
this.reverseBase64Chars = {};
for (var i = 0, leni = this.base64Chars.length; i < leni; i++) {
this.reverseBase64Chars[this.base64Chars[i]] = i
}
}
this.base64Str = str;
this.base64Count = 0
},
readBase64: function() {
if (!this.base64Str) {
return this.EOI
}
if (this.base64Count >= this.base64Str.length) {
return this.EOI
}
var c = this.base64Str.charCodeAt(this.base64Count) & 255;
this.base64Count++;
return c
},
encodeBase64: function(str) {
this.init(str);
var result = "";
var inBuffer = new Array(3);
var lineCount = 0;
var done = false;
while (!done && (inBuffer[0] = this.readBase64()) != this.EOI) {
inBuffer[1] = this.readBase64();
inBuffer[2] = this.readBase64();
result += (this.base64Chars[inBuffer[0] >> 2]);
if (inBuffer[1] != this.EOI) {
result += (this.base64Chars[((inBuffer[0] << 4) & 48) | (inBuffer[1] >> 4)]);
if (inBuffer[2] != this.EOI) {
result += (this.base64Chars[((inBuffer[1] << 2) & 60) | (inBuffer[2] >> 6)]);
result += (this.base64Chars[inBuffer[2] & 63])
} else {
result += (this.base64Chars[((inBuffer[1] << 2) & 60)]);
result += ("=");
done = true
}
} else {
result += (this.base64Chars[((inBuffer[0] << 4) & 48)]);
result += ("=");
result += ("=");
done = true
}
lineCount += 4;
if (lineCount >= 76) {
result += ("\n");
lineCount = 0
}
}
return result
},
readReverseBase64: function() {
if (!this.base64Str) {
return this.EOI
}
while (true) {
if (this.base64Count >= this.base64Str.length) {
return this.EOI
}
var nextCharacter = this.base64Str.charAt(this.base64Count);
this.base64Count++;
if (this.reverseBase64Chars[nextCharacter]) {
return this.reverseBase64Chars[nextCharacter]
}
if (nextCharacter == "A") {
return 0
}
}
},
ntos: function(n) {
n = n.toString(16);
if (n.length == 1) {
n = "0" + n
}
n = "%" + n;
return unescape(n)
},
decodeBase64: function(str) {
this.init(str);
var result = "";
var inBuffer = new Array(4);
var done = false;
while (!done && (inBuffer[0] = this.readReverseBase64()) != this.EOI && (inBuffer[1] = this.readReverseBase64()) != this.EOI) {
inBuffer[2] = this.readReverseBase64();
inBuffer[3] = this.readReverseBase64();
result += this.ntos((((inBuffer[0] << 2) & 255) | inBuffer[1] >> 4));
if (inBuffer[2] != this.EOI) {
result += this.ntos((((inBuffer[1] << 4) & 255) | inBuffer[2] >> 2));
if (inBuffer[3] != this.EOI) {
result += this.ntos((((inBuffer[2] << 6) & 255) | inBuffer[3]))
} else {
done = true
}
} else {
done = true
}
}
return result
}
}, {
EOI: -1,
base64Chars: "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_".split(""),
reverseBase64Chars: null,
base64Str: "",
base64Count: 0
});
utils.$create("dom", {
createDOMFragment: function(o) {
var el, rt = this.$root,
key, i, leni, child;
if (o.tag) {
var tag = o.tag.toLowerCase();
el = document.createElement(tag);
if (tag == "input") {
el.type = o.type || "text"
}
if (o.id) {
el.id = o.id
}
if (o.cls) {
el.className = o.cls
}
if (o.style) {
this.element.setStyle(el, o.style)
}
if (o.attributes) {
for (key in o.attributes) {
el.setAttribute(key, o.attributes[key])
}
}
if (rt.what(o.value) != "undefined") {
el.value = o.value
}
if (rt.what(o.innerHTML) != "undefined") {
el.innerHTML = o.innerHTML
}
if (o.events) {
for (key in o.events) {
rt.event.dom.bind(el, {
event: key,
listener: o.events[key]
})
}
}
} else {
if (o.isTextNode && rt.what(o.value) != "undefined") {
el = document.createTextNode(o.value)
} else {
return null
}
}
if (o.isChild) {
el = o.parent.appendChild(el)
}
if (o.tag && o.children) {
if (rt.what(o.children) != "array") {
o.children = [o.children]
}
for (i = 0, leni = o.children.length; i < leni; i++) {
child = o.children[i];
rt.utils.object.extend(child, {
isChild: true,
parent: el
});
this.createDOMFragment(child)
}
} else {
if (o.tag && o.childNodes) {
for (i = 0, leni = o.childNodes.length; i < leni; i++) {
el.appendChild(o.childNodes[i])
}
}
}
if (!o.isChild && o.parent) {
var parent = rt.what(o.parent) == "string" ? this.element.$(o.parent) : o.parent;
if (o.overwrite) {
parent.innerHTML = ""
}
o.before ? parent.insertBefore(el, o.before) : o.after ? this.element.insertAfter(el, o.after) : parent.appendChild(el)
}
return el
},
filterByClass: function(cls, tag, elm) {
if (!this._filterByClass) {
if (document.getElementsByClassName) {
this._filterByClass = function(cls, tag, elm) {
var elements = (elm ? (elm.getElementsByClassName ? elm : document) : document).getElementsByClassName(cls),
els = [];
tag = tag ? tag.toLowerCase() : null;
for (var i = 0, leni = elements.length; i < leni; i++) {
if (!tag || elements[i].tagName.toLowerCase() == tag) {
els[els.length] = elements[i]
}
}
return els
}
} else {
if (document.evaluate) {
this._filterByClass = function(cls, tag, elm) {
tag = tag || "*";
elm = elm || document;
var classes = cls.split(" "),
classesToCheck = "",
xhtmlNamespace = "http://www.w3.org/1999/xhtml",
namespaceResolver = (document.documentElement.namespaceURI === xhtmlNamespace) ? xhtmlNamespace : null,
els = [],
elements, node;
for (var j = 0, jl = classes.length; j < jl; j++) {
classesToCheck += "[contains(concat(' ', @class, ' '), ' " + classes[j] + " ')]"
}
try {
elements = document.evaluate(".//" + tag + classesToCheck, elm, namespaceResolver, 0, null)
} catch (e) {
elements = document.evaluate(".//" + tag + classesToCheck, elm, null, 0, null)
}
while ((node = elements.iterateNext())) {
els[els.length] = node
}
return els
}
} else {
this._filterByClass = function(cls, tag, elm) {
tag = tag || "*";
elm = elm || document;
var classes = cls.split(" "),
classesToCheck = [],
elements = (tag === "*" && elm.all) ? elm.all : elm.getElementsByTagName(tag),
current, els = [],
match;
for (var k = 0, kl = classes.length; k < kl; k++) {
classesToCheck[classesToCheck.length] = new RegExp("(^|\\s)" + classes[k] + "(\\s|$)")
}
for (var l = 0, ll = elements.length; l < ll; l++) {
current = elements[l];
match = false;
for (var m = 0, ml = classesToCheck.length; m < ml; m++) {
match = classesToCheck[m].test(current.className);
if (!match) {
break
}
}
if (match) {
els[els.length] = current
}
}
return els
}
}
}
}
return this._filterByClass(cls, tag, elm)
},
findWidestNode: function() {
var bd = document.body,
i, leni, rt = this.$root,
dm = rt.utils.dom,
dmel = dm.element,
node, widestNode, width, maxWidth = 0,
height, minHeight = 50,
widest = null;
for (i = 0, leni = bd.childNodes.length; i < leni; i++) {
node = bd.childNodes[i];
if (node.nodeType != rt.settings.nodeTypes.ELEMENT || !dmel.isVisible(node)) {
continue
}
width = dmel.getActualWidth(node);
height = dmel.getActualHeight(node);
if (width > maxWidth && height > minHeight) {
maxWidth = width;
widest = {
node: node,
width: width,
height: height
}
}
}
if (!widest) {
widestNode = bd;
widest = {
node: bd,
width: dm.document.getWidth(),
height: dm.document.getHeight()
}
}
return widest
}
});
utils.dom.$create("element", {
$: function(id) {
return document.getElementById(id)
},
getActualWidth: function(el) {
var cssWidth = this.getStyle(el, "width");
var width = parseInt(cssWidth, 10);
return !isNaN(width) && (width > 0) && (cssWidth.match(/px/)) ? width : el.clientWidth || el.offsetWidth
},
getActualHeight: function(el) {
var cssHeight = this.getStyle(el, "height");
var height = parseInt(cssHeight, 10);
return !isNaN(height) && (height > 0) && (cssHeight.match(/px/)) ? height : el.clientHeight || el.offsetHeight
},
getStyle: function(node, prop) {
var dfv = document.defaultView,
style = node.currentStyle || (dfv && dfv.getComputedStyle ? dfv.getComputedStyle(node, null) : null) || node.style;
return prop && style ? style[prop] : style
},
inHierarchy: function(low, high) {
do {
if (low == high) {
return true
}
low = low.parentNode
} while (low);
return false
},
insertAfter: function(newNode, refNode) {
var parent = refNode.parentNode;
return refNode.nextSibling ? parent.insertBefore(newNode, refNode.nextSibling) : parent.appendChild(newNode)
},
isOnViewport: function(node) {
if (!this.isVisible(node)) {
return false
}
return (this.offset(node).top < this.$parent.viewport.getHeight())
},
isVisible: function(node) {
if (!node) {
return false
}
while (node && node.tagName && node.tagName.toLowerCase() != "body") {
var cs = this.getStyle(node);
if (cs["display"] == "none" || cs["visibility"] == "hidden") {
return false
}
node = node.parentNode
}
return true
},
offset: function(node, ancestor) {
var x = 0,
y = 0,
rt = this.$root,
dm = rt.utils.dom,
dmel = dm.element,
b = rt.browser,
parent, body = document.body || document.documentElement;
var pos = "position",
abs = "absolute",
blw = "borderLeftWidth",
btw = "borderTopWidth";
if (!ancestor) {
ancestor = body
}
if (node == ancestor) {
return {
left: 0,
top: 0
}
}
if (node.getBoundingClientRect && !ancestor) {
var box = node.getBoundingClientRect();
var scrollTop = dm.document.getScrollTop();
var scrollLeft = dm.document.getScrollLeft();
return {
left: parseInt(box.left + scrollLeft, 10),
top: parseInt(box.top + scrollTop, 10)
}
}
var hasAbsolute = dmel.getStyle(node, pos) == abs;
parent = node;
while (parent && parent != ancestor) {
x += parent.offsetLeft;
y += parent.offsetTop;
if (!hasAbsolute && dmel.getStyle(parent, pos) == abs) {
hasAbsolute = true
}
if (b.Firefox) {
var bl = parseInt(dmel.getStyle(parent, blw), 10) || 0;
var bt = parseInt(dmel.getStyle(parent, btw), 10) || 0;
x += bl;
y += bt;
if (parent != node && dmel.getStyle(parent, "overflow") != "visible") {
x += bl;
y += bt
}
}
parent = parent.offsetParent
}
if (b.Safari && hasAbsolute) {
x -= body.offsetLeft;
y -= body.offsetTop
}
if (b.Firefox && !hasAbsolute) {
x += parseInt(dmel.getStyle(body, blw), 10) || 0;
y += parseInt(dmel.getStyle(body, btw), 10) || 0
}
parent = node.parentNode;
while (parent && parent != ancestor) {
if (!b.Opera || (parent.tagName.toLowerCase() != "tr" && dmel.getStyle(parent, "display") != "inline")) {
x -= parent.scrollLeft;
y -= parent.scrollTop
}
parent = parent.parentNode
}
var bs = dmel.getStyle(body);
if (ancestor == body && bs.position == abs && bs.left) {
x -= parseInt(bs.left, 10) || 0
}
return {
left: parseInt(x, 10),
top: parseInt(y, 10)
}
},
setStyle: function(node, styles) {
var b = this.$root.browser,
key;
if (!node) {
return null
}
if (!styles) {
styles = {}
}
for (key in styles) {
if (styles[key] != null) {
if ((key == "opacity" || key == "cssFloat") && b.IE) {
if (key == "opacity") {
node.style["filter"] = "alpha(opacity=" + Math.ceil(parseFloat(styles[key]) * 100) + ")"
}
if (key == "cssFloat") {
node.style["styleFloat"] = styles[key]
}
} else {
node.style[key] = styles[key]
}
}
}
return node
},
getData: function(node, dataId) {
return node.dataset ? node.dataset[dataId] : node.getAttribute("data-" + dataId)
},
setData: function(node, dataId, val) {
node.dataset ? (node.dataset[dataId] = val) : node.setAttribute("data-" + dataId, val)
}
});
utils.dom.$create("document", {
getHeight: function() {
var body = document.body,
html = document.documentElement;
return Math.max(body.scrollHeight, body.offsetHeight, html.clientHeight, html.scrollHeight, html.offsetHeight)
},
getWidth: function() {
var d = document,
m = "clientWidth";
return Math.max(d.documentElement[m], d.body[m]) || 0
},
getScrollTop: function() {
var d = document,
m = "scrollTop";
return window.pageYOffset || d.documentElement[m] || d.body[m] || 0
},
getScrollLeft: function() {
var d = document,
m = "scrollLeft";
return window.pageXOffset || d.documentElement[m] || d.body[m] || 0
}
});
utils.dom.$create("viewport", {
getHeight: function() {
var d = document,
de = d.documentElement,
m = "clientHeight";
return window.innerHeight || (de ? (de[m] || d.body[m] || 0) : 0)
},
getWidth: function() {
var d = document,
de = d.documentElement,
m = "clientWidth";
return window.innerWidth || (de ? (de[m] || d.body[m] || 0) : 0)
}
});
utils.dom.$create("style", {
getStylesheet: function() {
var st = this.$root.settings;
if (st.stylesheet) {
return st.stylesheet
}
var cont = document.getElementsByTagName("head");
cont = cont.length ? cont[0] : document.body;
var style = document.createElement("style");
style.type = "text/css";
return (st.stylesheet = cont.appendChild(style))
},
addRule: function(selector, css) {
var stylesheet = this.getStylesheet();
if (stylesheet.styleSheet && stylesheet.styleSheet.addRule) {
stylesheet.styleSheet.addRule(selector, css)
} else {
if (stylesheet.sheet && stylesheet.sheet.insertRule) {
stylesheet.sheet.insertRule([selector, "{", css, "}"].join(""), stylesheet.sheet.cssRules ? stylesheet.sheet.cssRules.length : 0)
}
}
},
addClass: function(el, cls) {
var uta = this.$root.utils.array,
classes = el.className.split(/\s+/);
if (uta.indexOf(classes, cls) == -1) {
uta.push(classes, cls)
}
el.className = classes.join(" ")
},
removeClass: function(el, cls) {
var classes = el.className.split(/\s+/);
this.$root.utils.array.discard(classes, cls);
el.className = classes.join(" ")
},
buildHookUnderlineCSS: function(type, color, imp) {
var bb = "border-bottom:",
td = "text-decoration:",
n = "none",
u = "underline",
i = imp ? " !important;" : ";";
switch (type) {
case "single":
return [bb, "0 ", n, i, td, u, i].join("");
case "dotted":
return [bb, "1px dotted ", color, i, td, n, i].join("");
case "dashed":
return [bb, "1px dashed ", color, i, td, n, i].join("");
case "none":
return [bb, "0 ", n, i, td, n, i].join("");
default:
return [bb, "1px solid ", color, i, td, u, i].join("")
}
},
buildBorderRadius: function(val) {
var what = this.$root.what,
dbs = document.body.style,
css = "border-radius:" + val + ";";
if (what(dbs.borderRadius) == "string") {
return css
} else {
if (what(dbs.MozBorderRadius) == "string") {
return "-moz-" + css
} else {
if (what(dbs.WebkitBorderRadius) == "string") {
return "-webkit-" + css
} else {
return ""
}
}
}
},
buildBoxShadow: function(val) {
var rt = this.$root,
what = rt.what,
b = rt.browser,
dbs = document.body.style,
css = "box-shadow:" + val + ";";
if (what(dbs.boxShadow) == "string") {
return css
} else {
if (what(dbs.MozBoxShadow) == "string") {
return "-moz-" + css
} else {
if (what(dbs.WebkitBoxShadow) == "string" && (!b.Safari || parseFloat(b.AppleWebKit >= 533))) {
return "-webkit-" + css
} else {
return ""
}
}
}
},
buildTextShadow: function(val) {
var what = this.$root.what,
dbs = document.body.style,
css = "text-shadow:" + val + ";";
if (what(dbs.textShadow) == "string") {
return css
} else {
if (what(dbs.MozTextShadow) == "string") {
return "-moz-" + css
} else {
if (what(dbs.WebkitTextShadow) == "string") {
return "-webkit-" + css
} else {
return ""
}
}
}
},
buildLinearGradient: function(start, end, startColor, endColor) {
var b = this.$root.browser,
css = "background-image:";
if (parseFloat(b.Firefox) >= 3.6) {
return [css, "-moz-linear-gradient(", start, ", ", startColor, ", ", endColor, " ", end, "px);"].join("")
} else {
if (parseFloat(b.AppleWebKit) >= 530) {
return [css, "-webkit-gradient(linear, left ", start, ", left ", end, ", from(", startColor, "), to(", endColor, "));"].join("")
} else {
return ""
}
}
},
supports: function(prop) {
var wh = this.$root.what,
dbs = document.body.style,
b = this.$root.browser,
s = "string",
M = "Moz",
W = "Webkit",
cprop = prop.charAt(0).toUpperCase() + prop.substr(1);
switch (prop) {
case "borderRadius":
case "textShadow":
return wh(dbs[prop]) == s ? prop : (wh(dbs[M + cprop]) == s ? M + cprop : (wh(dbs[W + cprop]) == s ? W + cprop : false));
case "boxShadow":
return wh(dbs[prop]) == s ? prop : (wh(dbs[M + cprop]) == s ? M + cprop : ((wh(dbs[W + cprop]) == s && (!b.Safari || parseFloat(b.AppleWebKit >= 533))) ? W + cprop : false));
case "linearGradient":
return (parseFloat(b.Firefox) >= 3.6 || parseFloat(b.AppleWebKit) >= 530) ? prop : false;
default:
return false
}
}
});
utils.dom.$create("event", {
disableEventBubbling: function(element, event) {
if (element.addEventListener) {
element.addEventListener(event, this.stop, false)
} else {
if (element.attachEvent) {
element.attachEvent("on" + event, this.stop)
}
}
},
stop: function(domEvt) {
domEvt.cancelBubble = true;
domEvt.returnValue = false;
if (domEvt.preventDefault) {
domEvt.preventDefault()
}
if (domEvt.stopPropagation) {
domEvt.stopPropagation()
}
}
});
$root.$create("helpers", {
getVar: function(v, context) {
var wl = this.$root.settings.white_label,
s1 = "infolink",
s2 = s1 + "s",
undef = "undefined",
what = this.$root.what;
s1 += "_";
s2 += "_";
var val = wl && what(window[wl + "_" + v]) != undef ? window[wl + "_" + v] : what(window[s2 + v]) != undef ? window[s2 + v] : what(window[s1 + v]) != undef ? window[s1 + v] : null;
if (context) {
context[v] = val
}
return val
},
chanceIntegration: function() {
var percentage = this.getVar("percentage");
if (percentage) {
percentage = percentage > 100 ? 100 : percentage < 0 ? 0 : percentage;
var rnd = Math.random() * 100;
if (rnd > percentage) {
var integrationNode;
try {
integrationNode = this.searchForIntegrationComment(document.body)
} catch (ex) {
integrationNode = null
}
if (integrationNode) {
var js = integrationNode.data;
if (document.readyState != "complete" && !this.getVar("ddw")) {
document.write(js.substring(14, js.length))
}
}
this.$root.logger.log("Stopping on unlucky chance integration.", this.chanceIntegration);
return true
}
}
return false
},
searchForIntegrationComment: function(node) {
switch (node.nodeType) {
case 1:
case 9:
for (var i = 0, leni = node.childNodes.length; i < leni; i++) {
var resultNode = this.searchForIntegrationComment(node.childNodes[i]);
if (resultNode) {
return resultNode
}
}
return null;
case 8:
return node.data.length > 15 && node.data.substr(0, 14) == "IL_INTEGRATION" ? node : null;
default:
return null
}
},
isSupportedClient: function() {
var rt = this.$root,
b = rt.browser,
sv = rt.settings.supportedClients[b.getName()];
return sv && b.getVersion(true) >= sv
},
setHosts: function() {
var rt = this.$root,
host, url, ver, path = "",
re, st = rt.settings,
hosts = st.hosts;
var scripts = document.getElementsByTagName("script"),
resources = rt.helpers.getVar("resources");
if (window.INFOLINKS && window.INFOLINKS._boot) {
st.boot = window.INFOLINKS._boot;
ver = rt.version = st.boot.version;
re = /\/infolinks_main\.js$/
} else {
if (window.$iceboot) {
st.boot = window.$iceboot;
ver = rt.version = st.boot.version;
re = /\/infolinks_main\.js$/
} else {
re = new RegExp(versionFile + ".js$")
}
}
if (resources) {
resources = resources.replace(/^\w+:\/\//, "");
host = resources.substring(0, resources.indexOf("/"));
path = resources.substring(resources.indexOf("/")) + "/"
} else {
for (var i = 0, leni = scripts.length; i < leni; i++) {
if (scripts[i].src.match(re) != null) {
url = scripts[i].src.replace(/^\w+:\/\//, "");
host = url.replace(/\/.*/, "");
path = url.substring(url.indexOf("/"), url.lastIndexOf("/") + 1);
if (!ver) {
var parts = path.split("/");
rt.version = parts[parts.length - 2]
}
break
}
}
}
if (host) {
hosts.resources = host
} else {
hosts.resources = hosts.resourcesDefault;
path = hosts.scriptDefaultPath
}
hosts.router = rt.utils.string.toObject(location.search, "il.mt") || rt.helpers.getVar("metro_server") || hosts.resources.replace(/\bresources\b/, "router");
hosts.thumbnails = hosts.resources.replace(/\bresources\b/, "thumbnails");
if (ver) {
path += ver
}
if (path && path.charAt(path.length - 1) != "/") {
path += "/"
}
hosts.scriptPath = path;
if (path.indexOf("/src/") != -1) {
hosts.src = true
}
},
getCustomerId: function() {
var rt = this.$root,
hp = rt.helpers;
rt.settings.$extend({
customerId: hp.getVar("cid") || hp.getVar("pid") || "null",
websiteId: hp.getVar("wsid") || 0,
customerUrl: document.location.href
})
},
setDefaultWebsiteDirectives: function(data) {
var rt = this.$root,
key, dwd = {
ht: true,
qmin: 1,
ha: null,
hd: null
};
if (!data.wd) {
data.wd = {}
}
for (key in dwd) {
if (rt.what(data.wd[key]) == "undefined") {
data.wd[key] = dwd[key]
}
}
},
getReferrer: function() {
var rt = this.$root,
docRef = document.referrer,
res = {
ref: "",
refq: ""
},
refqIndex, ut = rt.utils,
uts = ut.string,
hasRefc = ut.cookie.has("refc"),
simQuery = ut.string.toObject(location.search, "il.sq");
if (simQuery) {
res = {
refq: decodeURIComponent(simQuery),
ref: ut.base64.decodeBase64("d3d3Lmdvb2dsZS5jb20=")
};
ut.object.extend(rt.settings, res);
return res
}
if (docRef) {
refqIndex = docRef.indexOf("?");
if (refqIndex != -1) {
try {
var queryObj = uts.toObject(docRef.substring(refqIndex + 1));
res.refq = uts.truncate(uts.trim(decodeURIComponent((queryObj.q || queryObj.p || "").replace(/\+/g, " "))), 100, "");
res.ref = docRef.substring(0, refqIndex)
} catch (ex) {
rt.logger.error("Error reading referrer.", this.getReferrer)
}
} else {
if (!hasRefc) {
res.ref = docRef
}
}
res.ref = uts.truncate(res.ref.replace(/^\w+:\/\//, ""), 100, "");
if (res.refq && !hasRefc) {
ut.cookie.set("refc", ut.object.toQueryString(res), 60)
}
}
if (!res.refq && hasRefc) {
ut.object.extend(res, uts.toObject(ut.cookie.get("refc") || ""))
}
ut.object.extend(rt.settings, res);
return res
},
normalizeText: function(text) {
var delimiter = "|";
text = text.replace(/\.|:|;|<|>|=|\?|\(|\)|\[|\]|\{|\}|,|"|\x201C|\x201D|\x96|\x97|\\|\//g, delimiter);
text = text.replace(/['`\-]\W/g, delimiter).replace(/\W['`\-]/g, delimiter);
var re1 = new RegExp("\\s*\\" + delimiter + "+\\s*", "g");
var re2 = new RegExp("\\" + delimiter + "{2,}", "g");
text = text.replace(re1, delimiter).replace(re2, delimiter);
text = text.toLowerCase().replace(/\|/g, "P").replace(/\s/g, "S").replace(/\./g, "D").replace(/'/g, "Q").replace(/\$/g, "M").replace(/\+/g, "A");
return text
},
countWords: function(text) {
var re = new RegExp("P|S", "g");
var matched = text.match(re);
return (matched != null) ? matched.length + 1 : 0
},
getMetaContent: function(name, limit) {
var metas = document.getElementsByTagName("meta");
for (var i = 0, leni = metas.length; i < leni; i++) {
if (metas[i].name && metas[i].name.toLowerCase() == name && metas[i].content) {
return this.normalizeText(this.$root.utils.string.truncateToChar(metas[i].content, limit * 1024, " "))
}
}
return ""
},
getSilverlightVersion: function() {
var plugin = navigator.plugins["Silverlight Plug-In"],
version = -1;
if (plugin) {
version = plugin.description
} else {
try {
var control = new ActiveXObject("AgControl.AgControl");
var checkVersion = 2;
while (control.IsVersionSupported(checkVersion + ".0")) {
checkVersion++
}
checkVersion--;
version = (checkVersion == 1) ? -1 : checkVersion
} catch (ex) {}
}
return version
},
getTagTexts: function(tags, prop, param) {
var rt = this.$root,
ut = rt.utils,
uts = ut.string,
uta = ut.array,
nodes, res = [],
i, leni, j, lenj, val, end = false,
charCount = 0,
tlm = rt.settings.textLimits.merged,
nodesCount = 0,
maxNodes = 20;
if (rt.what(tags) != "array") {
tags = [tags]
}
for (i = 0, leni = tags.length; i < leni; i++) {
nodes = document.getElementsByTagName(tags[i]);
for (j = 0, lenj = nodes.length; j < lenj; j++) {
val = prop == "text" ? (nodes[j].textContent || nodes[j].innerText || "") : prop == "alt" ? nodes[j].alt : "";
if (!val) {
continue
}
val = uts.truncateToChar(val, tlm[param].i, " ");
nodesCount++;
if (charCount + val.length > tlm[param].t * 1024 || nodesCount >= maxNodes) {
end = true;
break
}
uta.push(res, val);
charCount += val.length
}
if (end) {
break
}
}
return this.normalizeText(res.join("|"))
},
processImpressionResponse: function(response) {
var rt = this.$root,
hp = rt.helpers,
component;
if (rt.what(response) != "object") {
return null
}
if (response.components) {
response.prs = {};
for (component in response.components) {
response.prs[component.charAt(0)] = response.components[component]
}
delete response.components
}
hp.normalizeSentenceLists(response);
if (response.messages) {
hp.findMaxBidCount(response)
}
return response
},
findMaxBidCount: function(response) {
var prod, msg, i, maxBDC = 0;
for (prod in response.prs) {
msg = response.prs[prod].messages;
if (!msg) {
continue
}
for (i in msg) {
if (msg[i].bdc > maxBDC) {
maxBDC = msg[i].bdc
}
}
}
this.$root.settings.bdc = maxBDC
},
normalizeSentenceLists: function(response) {
var prs = response.prs,
prod, ut = this.$root.utils,
numOfSentences = ut.object.keys(response.sentences).length;
for (prod in prs) {
if (numOfSentences && prs[prod].sentences.length == 1 && prs[prod].sentences[0] == "ALL") {
prs[prod].sentences = ut.array.range(0, numOfSentences - 1)
}
}
},
getCustomerBehavior: function(str) {
var rt = this.$root,
v, key, i, leni, res = {};
function uc() {
return arguments[1].toUpperCase()
}
var arr = rt.utils.string.qw(str);
for (i = 0, leni = arr.length; i < leni; i++) {
v = rt.helpers.getVar(arr[i]);
if (v != null) {
key = arr[i].replace(/_(\w)/g, uc);
res[key] = v
}
}
return res
},
getImpressionBehavior: function() {
var rt = this.$root,
st = rt.settings,
uto = rt.utils.object,
bi = rt.comm.settings.responses.impression.behavior_imp || {};
uto.renamePorpery(bi, "lc", "linkColor");
uto.renamePorpery(bi, "st", "bubbleShowDelay");
uto.renamePorpery(bi, "rw", "adsReuseWindow");
uto.renamePorpery(bi, "bd", "bubbleDirection");
st.behavior.impression = bi
},
renameBehaviorProperties: function(o) {
var rt = this.$root,
uto = rt.utils.object;
uto.renamePorpery(o, "hc", "highlightCount");
uto.renamePorpery(o, "lc", "linkColor");
uto.renamePorpery(o, "du", "doubleUnderline");
uto.renamePorpery(o, "st", "bubbleShowDelay");
uto.renamePorpery(o, "rw", "adsReuseWindow");
uto.renamePorpery(o, "si", "simanitIcon");
uto.renamePorpery(o, "bd", "bubbleDirection");
uto.renamePorpery(o, "t", "theme");
uto.renamePorpery(o, "ln", "lines");
return o
},
sanitize: function(data, sanitizer, strict) {
var rt = this.$root;
for (var key in data) {
if (strict && rt.what(sanitizer[key]) == "undefined") {
delete data[key];
continue
}
switch (sanitizer[key]) {
case "int":
data[key] = parseInt(data[key], 10) || 0;
break;
case "bool":
data[key] = data[key] == "false" ? false : !! data[key];
break;
case "color":
data[key] = this.validateColorValue(data[key] || "");
break;
case "multiColor":
data[key] = this.validateMultiColorValue(data[key] || "");
break;
case "str":
data[key] = data[key] && data[key].toString ? data[key].toString() : data[key];
break;
case "node":
data[key] = data[key] && data[key].tagName ? data[key] : null;
break;
default:
if (rt.what(sanitizer[key]) == "array") {
if (rt.utils.array.indexOf(sanitizer[key], data[key]) == -1) {
data[key] = sanitizer[key][0]
}
}
}
}
return data
},
validateColorValue: function(color) {
return (color && color.match(/^#?[0-9a-fA-F]{6}$/) != null) ? color.charAt(0) == "#" ? color : "#" + color : "#000000"
},
validateMultiColorValue: function(colorsStr) {
var rt = this.$root,
colors = colorsStr.split(","),
newColors = [],
i, leni;
for (i = 0, leni = colors.length; i < leni; i++) {
if (rt.what(colors[i]) == "string") {
rt.utils.array.push(newColors, this.validateColorValue(colors[i]))
}
}
return (newColors.join(","))
},
createBaseClasses: function() {
var rt = this.$root,
dmst = rt.utils.dom.style,
baseClass = rt.settings.baseClass;
var baseCSS = "margin:0;padding:0;border:0;outline:0;font:normal normal normal 13px trebuchet MS,Arial,sans-serif;vertical-align:baseline;background:transparent;list-style:none;text-decoration:none;text-align:left;float:none;";
dmst.addRule("." + baseClass, baseCSS);
dmst.addRule("." + baseClass + " *", baseCSS);
dmst.addRule("a." + baseClass + ":hover", "background-color:transparent !important;")
},
getHookData: function(hookId) {
var data = this.$root.comm.settings.responses.getads;
return data ? data[hookId] || null : null
},
setHookData: function(hookId, data) {
var res = this.$root.comm.settings.responses;
if (!res.getads) {
res.getads = {}
}
res.getads[hookId] = data
},
clearHookData: function(hookId) {
var data = this.$root.comm.settings.responses.getads;
if (data && data[hookId]) {
data[hookId] = null
}
},
createHook: function(hookId, sentence, node, fontSize, context, prodCode, prodName, hasBubble, instance) {
var rt = this.$root,
st = rt.settings,
sn = context.settings.sentences;
var hook = {
id: hookId,
fontSize: fontSize,
node: node,
parentNode: node.parentNode,
rendered: true,
sentence: sentence,
prod: prodCode,
type: prodName,
hovered: false,
currentAdIndex: 0,
instance: instance
};
st.hooksMap[hook.id] = hook;
if (!sn[sentence]) {
sn[sentence] = {
hooks: [],
rendered: 0
}
}
rt.utils.array.push(sn[sentence].hooks, hook);
sn[sentence].rendered++;
if (hasBubble) {
hook.bubble = rt.utils.object.clone(rt.bubble.settings.base);
rt.helpers.bindHookEvents(hook)
}
return hook
},
getHookBehavior: function(hookId) {
var rt = this.$root,
st = rt.settings,
hook = st.hooksMap[hookId],
prods = rt.products;
switch (hook.prod) {
case "i":
return prods.intext.settings.behavior.merged;
case "t":
return prods.intag.settings.behavior.merged;
case "s":
case "o":
return hook.instance.behavior;
case "f":
return prods.inframe.settings.behavior.merged;
default:
return {}
}
},
bindHookEvents: function(hook) {
var rt = this.$root,
ed = rt.event.dom,
rtb = rt.bubble,
node = hook.node,
data = {
hookId: hook.id
};
ed.bind(node, {
event: "dblclick",
listener: rtb.hookDblClick
});
ed.bind(node, {
event: "mouseenter",
data: data,
listener: rtb.hookMouseover
});
ed.bind(node, {
event: "mouseleave",
data: data,
listener: rtb.hookMouseout
});
ed.bind(node, {
event: "click",
data: data,
listener: rtb.hookClick
})
},
getHookSD: function(hookId) {
var rt = this.$root,
st = rt.settings,
hook = st.hooksMap[hookId],
imp;
if (!hook) {
return {}
}
imp = hook.updater ? hook.updater.impression : rt.comm.settings.responses.impression;
return rt.utils.object.extend({
sdata: hook.sentence,
scs: imp.sentences[hook.sentence]
}, imp.rauth)
},
setAdThumbnail: function(ad) {
if (ad.template == "text" && !ad.thumbURL) {
ad.thumbURL = ["http://", this.$root.settings.hosts.thumbnails, "/thumbnail.jpg?domain=", ad.displayedURL].join("")
}
},
hitTrackerURL: function(trackerURL) {
var rt = this.$root;
if (rt.what(trackerURL) != "array") {
trackerURL = [trackerURL]
}
for (var i = 0; i < trackerURL.length; i++) {
rt.utils.dom.createDOMFragment({
tag: "img",
parent: document.body,
attributes: {
src: trackerURL[i]
},
style: {
display: "none"
}
})
}
},
mapUnhoverableAreas: function() {
var rt = this.$root,
st = rt.settings,
ut = rt.utils,
dmel = ut.dom.element,
b = rt.browser;
var embeds = document.getElementsByTagName("embed");
var objects = document.getElementsByTagName("object");
var arr = ut.array.concat(embeds, objects);
st.unhoverableAreas = [];
for (var i = 0; i < arr.length; i++) {
if (!dmel.isVisible(arr[i])) {
continue
}
if (arr[i].tagName.toLowerCase() == "embed") {
if ((arr[i].getAttribute("wmode") || "").toLowerCase() == "transparent") {
continue
}
} else {
var params = arr[i].getElementsByTagName("param"),
hasWmode = false;
for (var j = 0, lenj = params.length; j < lenj; j++) {
if (params[j].name == "wmode" && params[j].value.toLowerCase() == "transparent") {
hasWmode = true;
break
}
}
if (hasWmode) {
continue
}
}
if (arr[i].tagName.toLowerCase() == "embed" && arr[i].parentNode.tagName.toLowerCase() == "object") {
if (b.IE) {
continue
} else {
ut.array.discard(arr, arr[i].parentNode)
}
}
var width = parseInt(arr[i].width, 10) || arr[i].offsetWidth || 0;
var height = parseInt(arr[i].height, 10) || arr[i].offsetHeight || 0;
if (!width || !height) {
continue
}
var pos = dmel.offset(arr[i]);
ut.array.push(st.unhoverableAreas, [pos.left, pos.top, pos.left + width, pos.top + height])
}
},
hasSpecialTags: function(content, tags) {
content = content.toLowerCase();
if ((tags == "all" || tags == "script") && (content.indexOf("<scr") != -1 || content.indexOf("document.write") != -1)) {
return true
}
return (tags == "all" || tags == "iframe") && content.indexOf("<ifr") != -1
},
parseTokens: function(hook, content) {
var rt = this.$root,
data = this.getHookData(hook.id),
ad = data.ads[hook.currentAdIndex];
if (!content) {
content = ad.content
}
if (ad.template == "html" || ad.template == "external") {
var re = /@start@.*?@end@/,
match, matchUrl, url, redirectUrl, encoded;
while ((match = content.match(re)) != null) {
matchUrl = match[0];
url = matchUrl.substring(7, matchUrl.length - 5);
redirectUrl = rt.comm.getRedirectUrl(hook, url, "onWin");
content = content.replace(re, redirectUrl)
}
re = /@encode@.*?@encode@/;
while ((match = content.match(re)) != null) {
encoded = encodeURIComponent(match[0].substring(8, match[0].length - 8));
content = content.replace(re, encoded)
}
}
if (ad.contentType == "javascript") {
content = ['<script type="text/javascript">', content, "<\/script>"].join("")
}
return content
},
setActualTemplate: function(ad) {
ad.actualTemplate = (ad.echo || (ad.template == "html" || ad.template == "external") && ad.content && this.hasSpecialTags(ad.content, "script")) ? "iframe" : ad.template
},
getPlatform: function() {
var rt = this.$root,
gen = document.getElementsByName("generator"),
i, leni, val, undef = "undefined";
for (i = 0, leni = gen.length; i < leni; i++) {
val = gen[i].getAttribute("content");
if (!val) {
continue
}
if (val.indexOf("WordPress") > -1) {
return "wdp"
}
if (val.indexOf("Joomla") > -1) {
return "jml"
}
if (val.indexOf("blogger") > -1) {
return "bsp"
}
if (val.indexOf("vBulletin") > -1) {
return "vbt"
}
if (val.indexOf("phpBB") > -1) {
return "pbb"
}
if (val.indexOf("weebly") > -1) {
return "wbl"
}
if (val.indexOf("tumblr") > -1) {
return "tbr"
}
}
if (rt.what(window["Drupal"]) != undef) {
return "drl"
}
if (rt.what(window["Joomla"]) != undef) {
return "jml"
}
if (rt.what(window["blogger"]) != undef) {
return "jml"
}
if (rt.what(window["blogger_blog_id"]) != undef) {
return "jml"
}
if (rt.utils.dom.filterByClass("contentpaneopen").length) {
return "jml"
}
if (rt.what(window["vBulletin"]) != undef) {
return "vbt"
}
if (rt.what(window["phpbb"]) != undef) {
return "pbb"
}
if (rt.what(window["positionWeeblyFooter"]) != undef) {
return "wbl"
}
if (rt.what(window["Tumblr"]) != undef) {
return "tbr"
}
if (rt.what(window["ipb"]) != undef) {
return "ipb"
}
var links = document.getElementsByTagName("link"),
href;
for (i = 0, leni = links.length; i < leni; i++) {
href = links[i].getAttribute("href");
if (!href) {
continue
}
if (href.indexOf("wp-content") > -1) {
return "wdp"
}
if (href.indexOf("support-files") > -1) {
return "sbi"
}
}
return ""
},
getSiteLanguage: function() {
if (this.getSiteLanguage.lang) {
return this.getSiteLanguage.lang
}
var lang = "en";
return this.getSiteLanguage.lang = lang
},
translate: function(key) {
var tr = this.$root.settings.translations;
return tr[key] ? tr[key][this.getSiteLanguage()] : key
},
getEchoForm: function(content, iframeName, formId, formCls) {
var rt = this.$root,
st = rt.settings,
echo = "http://" + st.hosts.router + "/echo.htm";
var html = '<form <% if (formId){ %>id="<%= formId %>"<% } %> <% if (formCls){ %>class="<%= formCls %>"<% } %> method="post" action="<%= echo %>" target="<%= iframeName %>" accept-charset="utf-8" style="display:none;"> <input type="hidden" name="echo" value="<%= encodeURIComponent(content.split(\'\').reverse().join(\'\')) %>" /> <input type="hidden" name="pid" value="<%= cid %>" /> <input type="hidden" name="wsid" value="<%= wsid %>" /> <input type="hidden" name="jsv" value="<%= jsv %>" /> </form>';
return rt.utils.VeST(html, {
echo: echo,
content: content,
iframeName: iframeName,
formId: formId,
formCls: formCls,
cid: st.customerId,
wsid: st.websiteId,
jsv: rt.version,
nocache: rt.utils.number.next("echo")
})
}
});
var comm = $root.$create("comm", {
loadScript: function(url, params, event, data) {
var $comm = this,
rt = this.$root,
qstr = "",
qarr = [],
cbfunc;
if (rt.what(params) == "object") {
for (var key in params) {
rt.utils.array.push(qarr, (qarr.length || url.indexOf("?") != -1) ? "&" : "?", encodeURIComponent(key), "=", encodeURIComponent(params[key]))
}
qstr = qarr.join("")
} else {
if (rt.what(params) == "string") {
qstr = params
}
}
url += qstr;
if (url.match(/^\w+:\/\//) == null) {
url = "http://" + url
}
if (event) {
cbfunc = function(url) {
var rt = $comm.$root,
ls = $comm.loadedScripts;
if (ls[url]) {
return true
}
ls[url] = true;
if (rt.what(data) == "undefined") {
rt.event.fire(event)
} else {
rt.event.fire(event, data)
}
}
} else {
cbfunc = function() {
$comm.loadedScripts[url] = true
}
}
if (this.loadedScripts[url]) {
cbfunc()
} else {
this.loadedScripts[url] = false;
var script = document.createElement("script");
script.type = "text/javascript";
script.charset = "UTF-8";
script.onreadystatechange = function() {
if (/complete|loaded/.test(this.readyState) && !$comm.loadedScripts[url]) {
cbfunc(url)
}
};
script.onload = function() {
cbfunc(url)
};
script.src = url;
var container = document.getElementsByTagName("head");
container = container[0] || document.body;
script = container.appendChild(script);
return true
}
},
supportsCORS: function() {
var xhr = window.XMLHttpRequest ? new XMLHttpRequest() : null;
return this.settings.cors = (xhr && "withCredentials" in xhr)
},
sendRequest: function(options, beforeSend) {
var rt = this.$root,
b = rt.browser,
st = rt.settings,
cst = this.settings,
uta = rt.utils.array,
hasBeforeSend = rt.what(beforeSend) == "function",
ptxt, removeParams, totalLength, ptxtMaxLength, i, leni;
var urlCharLimit = {
IE: 2048,
Other: 8192
};
if (b.iPhone || b.iPad) {
var inputs = [],
formContainer;
if (hasBeforeSend) {
beforeSend.call(rt, "i")
}
for (var key in options.params) {
uta.push(inputs, {
tag: "input",
type: "hidden",
attributes: {
name: key
},
value: options.params[key]
})
}
formContainer = document.getElementById("IL_FORM_CONT");
if (formContainer) {
var parent = formContainer.parentNode;
parent.removeChild(formContainer)
}
formContainer = rt.utils.dom.createDOMFragment({
tag: "div",
parent: document.body,
id: "IL_FORM_CONT",
style: {
display: "none"
},
children: [{
tag: "form",
id: "IL_FORM",
children: inputs,
attributes: {
method: options.method,
action: options.url,
target: "IL_FRAME"
}
}, {
tag: "div",
id: "IL_FRAME_CONT",
innerHTML: '<iframe id="IL_FRAME" name="IL_FRAME" src="' + st.blankURL + '" width="1" height="1" frameborder="0" scrolling="no"></iframe>'
}]
});
if (formContainer) {
document.getElementById("IL_FORM").submit()
}
} else {
if (cst.mode == "cors") {
if (hasBeforeSend) {
beforeSend.call(rt, "a")
}
this.sendAjaxRequest(options)
} else {
if (cst.mode == "messaging") {
if (cst.messagingReady) {
if (hasBeforeSend) {
beforeSend.call(rt, "a")
}
var message = rt.utils.object.stringify({
action: "ajax",
data: options
});
this.sendMessage(message)
} else {
rt.utils.array.push(this.pendingRequests, [options, beforeSend])
}
} else {
if (cst.mode == "flash") {
if (b.IE) {
if (hasBeforeSend) {
beforeSend.call(rt, "f")
}
this.flash.embedIE(options)
} else {
if (this.flash.flashLoadAmount == 10 && this.flash.flashElement) {
if (hasBeforeSend) {
beforeSend.call(rt, "f")
}
this.flash.sendURLRequest(options.url, options.method, options.params, options.onSuccess, options.onSuccess, 1)
} else {
rt.utils.array.push(this.pendingRequests, [options, beforeSend])
}
}
} else {
if (hasBeforeSend) {
beforeSend.call(rt, "s")
}
ptxt = options.params.ptxt;
removeParams = rt.utils.string.qw("ptxt plinks pimgs phdrs pdesc page_keyw ptitle"), i, leni = removeParams.length;
for (i = 0, leni = removeParams.length; i < leni; i++) {
options.params[removeParams[i]] = ""
}
rt.utils.object.clean(options.params);
totalLength = rt.utils.object.toQueryString(options.params).length + options.url.length + document.location.href.length + navigator.userAgent.length + document.cookie.length + 400;
ptxtMaxLength = urlCharLimit[b.IE ? "IE" : "Other"] - totalLength;
if (ptxtMaxLength < 0) {
rt.logger.error("Request too long for GET.", this.sendRequest);
return
}
options.params.ptxt = (ptxtMaxLength > 0) ? ptxt.substring(0, ptxtMaxLength) : "";
options.params.twnum = rt.helpers.countWords(options.params.ptxt);
this.loadScript(options.url, options.params)
}
}
}
}
},
sendMessage: function(message) {
var rt = this.$root,
commFrame = rt.utils.dom.element.$("iceCommFrame");
if (commFrame && commFrame.contentWindow) {
commFrame.contentWindow.postMessage(message, "*")
} else {
rt.logger.error("Could not get comm frame.", this.sendMessage)
}
},
receiveMessage: function(event) {
var de = event.domEvent,
message = de.data,
data, rt = this.$root,
lg = rt.logger;
var origin = (de.origin || de.domain).replace("http://", "");
if (origin.indexOf(this.settings.responses.gsd.rs) != 0) {
return
}
if (message.charAt(0) == "(" && message.charAt(message.length - 1) == ")") {
message = message.substring(1, message.length - 1)
}
try {
data = rt.what(window.JSON) != "undefined" && window.JSON.parse ? window.JSON.parse(message) : eval("(" + message + ")")
} catch (ex) {
lg.error("Data parsing failed: " + ex.message + ". message:" + message + " ", this.receiveMessage);
return
}
if (data.action == "error") {
lg.error(data.data, this.receiveMessage)
} else {
if (data.action == "event") {
rt.event.fire(data.type, data.data)
} else {
if (!data.action) {
rt.event.fire("afterImpression", data)
}
}
}
},
sendAjaxRequest: function(o) {
var rt = this.$root,
xhr, xdr, xhrc = window.XMLHttpRequest ? new XMLHttpRequest() : null;
if (rt.what(o) != "object") {
return null
}
if (xhrc && "withCredentials" in xhrc) {
xhr = xhrc
} else {
if (window.XDomainRequest) {
xdr = new XDomainRequest()
}
}
if (!xhr && !xdr) {
return null
}
if (xhr) {
xhr.onreadystatechange = function() {
if (!req || !req.xhr) {
return
}
if (req.xhr.readyState == 4) {
reqComplete(req)
}
}
} else {
xdr.onload = function() {
reqComplete(req)
}
}
function reqComplete(req) {
if (req.done || req.aborted) {
return
}
var o = req.xhr || req.xdr;
req.done = true;
if (req.xdr || req.xhr.status == 200) {
if (req.onSuccess) {
rt.comm.handleAjaxResponse({
action: "event",
type: req.onSuccess,
data: o.responseText
})
}
} else {
if (req.xdr || req.xhr.status != 0) {
rt.comm.handleAjaxResponse({
action: "error",
data: "Ajax request failed."
})
}
}
}
function reqTimeout() {
if (!req || req.done) {
return
}
var o = req.xhr || req.xdr;
req.aborted = true;
o.abort();
rt.comm.handleAjaxResponse({
action: "error",
data: "Ajax request timed out."
});
if (req.xhr) {
delete req.xhr["onreadystatechange"]
}
}
function process() {
var o = req.xhr || req.xdr,
params = req.params || {},
method = req.method || "GET",
url = req.url || window.location.href;
req.queryString = (req.queryString ? req.queryString + "&" : "") + rt.utils.object.toQueryString(params, true).substr(1);
if (req.method == "GET" && req.queryString) {
req.url += ((req.url.indexOf("?") > -1) ? "&" : "?") + req.queryString
}
if (req.timeout > 0) {
setTimeout(reqTimeout, req.timeout)
}
if (req.xhr) {
req.xhr.open(method, url, true)
} else {
req.xdr.open(method, url)
}
if (method == "POST") {
if (req.xhr && rt.what(req.xhr.setRequestHeader) == "function") {
req.xhr.setRequestHeader("Content-type", "application/x-www-form-urlencoded")
}
o.send(req.queryString)
} else {
o.send()
}
}
var req = rt.utils.object.extend({
xhr: xhr,
xdr: xdr,
process: process
}, o);
req.process();
return req
},
handleAjaxResponse: function(response) {
var rt = this.$root,
data;
if (response.action == "error") {
rt.logger.error(response.data, this.handleAjaxResponse)
} else {
if (response.action == "event") {
try {
data = rt.what(window.JSON) != "undefined" && window.JSON.parse ? window.JSON.parse(response.data) : eval("(" + response.data + ")")
} catch (ex) {
rt.logger.error("Data parsing failed: " + ex.message, this.handleAjaxResponse);
return
}
rt.event.fire(response.type, data)
}
}
},
getRedirectUrl: function(hook, url, clickedOn) {
var rt = this.$root,
st = rt.settings,
ut = rt.utils,
uto = ut.object,
data = rt.helpers.getHookData(hook.id),
ad = data.ads[hook.currentAdIndex];
if (ad.noClickPrefix) {
return url || ad.redirectURL
}
var now = ut.date.now();
var params = uto.clean(uto.extend({
rid: this.settings.responses.gsd.rid,
bdc: hook.bdc,
midx: hook.midx || hook.currentAdIndex,
rts: now,
vt: ut.timer.poll("adView" + hook.id),
clk_t: clickedOn,
jsv: rt.version,
prod_t: hook.prod || "",
tcln: hook.tcln || "",
pst: hook.pst || "",
cv: hook.viewed ? 1 : 0,
refq: st.impression.params.refq || "",
ifip: st.ifip || ""
}, rt.helpers.getHookSD(hook.id)));
params.rurl = url || ad.redirectURL || "";
var serverClickUrl = ["http://", this.settings.responses.gsd.rs, "/action/clk.htm"].join("");
return serverClickUrl + uto.toQueryString(params, true)
}
}, {
settings: {
responses: {},
errorReportingUrl: "http://cel.infolinks.com/"
},
loadedScripts: {},
pendingRequests: []
}, true);
comm.$create("flash", {
getSwfUrl: function() {
return ["http://", this.$root.settings.hosts.resources, "/flash/ic5.swf"].join("")
},
embed: function() {
var rt = this.$root,
swf = this.getSwfUrl();
rt.utils.timer.start("tmr_fsh");
rt.utils.dom.createDOMFragment({
tag: "div",
parent: document.body,
style: {
display: "block",
position: "absolute",
top: "1px",
left: "1px",
width: "1px",
height: "1px"
},
innerHTML: ['<embed pluginspage="http://www.macromedia.com/go/getflashplayer" src="', swf, '" width="1" height="1" wmode="transparent" name="ilfc" allowScriptAccess="always" type="application/x-shockwave-flash"></embed>'].join("")
})
},
embedIE: function(options) {
var rt = this.$root,
st = rt.settings,
ut = rt.utils,
swf = this.getSwfUrl(),
id = "ilfc" + rt.utils.number.next("flashEmbedConter");
this.requests[options.url] = {
request: ut.object.extend(options, {
open: false,
complete: false
})
};
var flashVars = ut.object.toQueryString({
url: options.url,
method: options.method,
success: options.onSuccess,
error: options.onSuccess
}, true).substr(1);
if (options.params) {
flashVars += ["&", ut.object.toQueryString(options.params, true).substr(1)].join("")
}
window[id + "_DoFSCommand"] = function(command, args) {
var response, func;
try {
func = eval(command);
response = eval(decodeURIComponent(args))
} catch (ex) {
rt.logger.error("Error evaluating response.", this);
return
}
func.call(func.$parent, response)
};
rt.utils.timer.start("tmr_fsh");
ut.dom.createDOMFragment({
tag: "div",
parent: document.body,
style: {
display: "block",
position: "absolute",
top: "1px",
left: "1px",
width: "1px",
height: "1px"
},
innerHTML: ['<object id="', id, '" classid="clsid:D27CDB6E-AE6D-11cf-96B8-444553540000" codebase="http://download.macromedia.com/pub/shockwave/cabs/flash/swflash.cab" width="1" height="1" align="middle">', '<param name="movie" value="', swf, '" />', '<param name="quality" value="high" />', '<param name="allowScriptAccess" value="always" />', '<param name="wmode" value="transparent" />', '<param name="flashvars" value="environment=IE&pcode=', st.impression.pcode, "&", flashVars, '" />', "</object>", "<sc", "ript event=FSCommand(command,args) for=", id, ">\n ", id, "_DoFSCommand(command, args)</sc", "ript>"].join("")
});
this.flashLoadComplete()
},
flashLoadUpdate: function(loaded) {
this.flashLoadAmount = loaded
},
flashLoadComplete: function() {
var rt = this.$root;
this.flashLoadAmount = 10;
this.flashElement = window["ilfc" + rt.utils.number.get("flashEmbedConter")] || document["ilfc"];
rt.utils.timer.stop("tmr_fsh");
while (this.$parent.pendingRequests.length) {
this.$parent.sendRequest.apply(this.$parent, rt.comm.pendingRequests.shift())
}
},
sendURLRequest: function(url, method, params, success, error, contextReferenceKey) {
this.requests[url] = {
request: {
url: url,
method: method,
params: params,
success: success,
error: error,
contextReferenceKey: contextReferenceKey,
open: false,
complete: false
}
};
this.flashElement.sendURLRequest(url, method, params, success, error, contextReferenceKey)
},
requestOpenHandler: function(responseObj) {
this.requests[responseObj.url].request.open = true
},
requestCompleteHandler: function(response) {
var rt = this.$root,
data, request = this.requests[response.url];
if (!request) {
rt.logger.error("Missing Request Object");
return
}
request.request.complete = true;
request.response = response;
if (response.success) {
var event = response.success;
try {
data = eval(response.data.replace(/^data=/, ""))
} catch (e) {
rt.logger.error("Error Evaluating Response.");
return
}
rt.event.fire(event, data)
}
},
requestError: function(response) {
this.requests[response.url].response = response;
if (response.error) {
var event = response.error;
this.$root.event.fire(event, response)
}
},
getFlashVersion: function() {
var flashVer = -1,
swStr = "Shockwave Flash",
np = navigator.plugins,
swp, b = this.$root.browser;
if (np && np.length) {
swp = np[swStr + " 2.0"] || np[swStr];
if (swp) {
flashVer = parseFloat(swp.description.replace(/[a-z ]+([0-9\.]+)[a-z ]+/i, "$1."))
}
}
if (flashVer == -1 && b.IE && b.Windows) {
var axo, vnum = [".9", ".7", ".6", ".3", ".3", ""],
vstr = [null, null, "WIN 6,0,21,0", null, "WIN 3,0,18,0", "WIN 2,0,0,11"];
for (var i = 0, leni = vnum.length; i < leni; i++) {
try {
axo = new ActiveXObject("ShockwaveFlash.ShockwaveFlash" + vnum[i]);
flashVer = vstr[i] ? vstr[i] : axo.GetVariable("$version")
} catch (e) {}
if (flashVer != -1) {
break
}
}
if (flashVer != -1) {
flashVer = parseFloat(flashVer.replace(/^[a-z ]+/i, "").replace(/,/g, "."))
}
}
return flashVer
}
}, {
requests: {}
}, false);
comm.bind({
event: "initComm",
listener: {
init: function() {
var rt = this.$root,
cst = this.settings,
b = rt.browser;
cst.flashVersion = this.flash.getFlashVersion();
if ((b.iPhone || b.iPad) && window.postMessage) {
cst.mode = "formsubmit";
rt.event.dom.bind(window, {
event: "message",
listener: this.receiveMessage
})
} else {
if (this.supportsCORS()) {
cst.mode = "cors"
} else {
if (window.postMessage) {
cst.mode = "messaging";
cst.messagingReady = false;
rt.event.dom.bind(window, {
event: "message",
listener: this.receiveMessage
});
rt.utils.dom.createDOMFragment({
tag: "div",
style: {
display: "none"
},
parent: document.body,
innerHTML: ['<iframe id="iceCommFrame" src="http://', cst.responses.gsd.rs, '/comm2.htm" width="1" height="1" frameborder="0" scrolling="no"></iframe>'].join("")
})
} else {
if (cst.flashVersion >= 9) {
cst.mode = "flash";
if (!rt.browser.IE) {
this.flash.embed()
}
} else {
cst.mode = "unsupported";
rt.logger.error("Unsupported comm mode", this.init)
}
}
}
}
}
}
});
comm.bind({
event: "getAds",
listener: {
getAds: function(event) {
var rt = this.$root,
uto = rt.utils.object,
et = rt.externalTags,
hook = rt.settings.hooksMap[event.data.hookId];
if (et.settings.oldAPI && /s|o/.test(hook.prod)) {
rt.event.fire("sendGetAds", event.data);
return
}
if (et.settings.oldAPI && uto.keys(et.settings.tags).length) {
var emds = uto.keys(et.settings.tags);
var tag = et.settings.tags[emds[0]];
var doExternal = Math.ceil(Math.random() * 100) <= 33;
if (tag.ads[0].prs[hook.prod] && doExternal && !et.settings.didExternal) {
et.settings.didExternal = true;
delete et.settings.tags[emds[0]];
tag.lid = hook.id;
tag.sentence = hook.sentence;
tag.ads[0].template = "external";
hook.externalTag = true;
var imp = this.settings.responses.impression;
hook.bdc = imp.prs[hook.prod] && imp.prs[hook.prod].messages && imp.prs[hook.prod].messages[tag.msg] ? imp.prs[hook.prod].messages[tag.msg].bdc : 0;
rt.event.fire(event.data.callback || "getadsResponse", tag);
return
} else {
et.settings.didExternal = false
}
}
if (uto.keys(et.settings.tags).length) {
hook.externalBidsTimeout = rt.event.fire("sendGetAds", uto.extend({
timeout: true
}, event.data), event.data.bidRequestTimeout || et.settings.bidRequestTimeout);
rt.event.fire("sendBids", event.data)
} else {
rt.event.fire("sendGetAds", event.data)
}
}
}
});
comm.bind({
event: "sendGetAds",
listener: {
sendGetAds: function(event) {
var rt = this.$root,
hookId = event.data.hookId,
st = rt.settings,
ut = rt.utils,
hook = st.hooksMap[hookId],
gsd = rt.comm.settings.responses.gsd;
if (event.data.timeout) {
hook.killBids = true
} else {
clearTimeout(hook.externalBidsTimeout)
}
if (!rt.helpers.getHookData(hookId)) {
rt.helpers.setHookData(hookId, "pending")
}
hook.bdc = ++st.bdc;
var params = ut.object.clean(ut.object.extend({
lid: hookId,
rid: gsd.rid,
jsv: rt.version,
rts: ut.date.now(),
bdc: hook.bdc,
prod_t: hook.prod,
cfv: rt.comm.settings.flashVersion,
ifip: st.ifip,
cb: event.data.callback || "getadsResponse",
tcln: hook.tcln,
pst: hook.pst,
purl: st.customerUrl,
ref: st.impression.params.ref,
refq: st.impression.params.refq
}, event.data.params || {}, rt.helpers.getHookSD(hookId), rt.externalTags.getBidData(hook.externalTag), rt.externalTags.getViewedTagsParam()));
if ("irt".indexOf(hook.prod) == -1) {
if (hook.prod == "s" || hook.prod == "o") {
params.as = "728*90"
}
}
if (rt.what(window["x1"]) != "undefined" && rt.what(window["x2"]) != "undefined") {
params[window["x1"]] = window["x2"]
}
rt.comm.loadScript(gsd.rs + "/action/getads.htm", params)
}
}
});
comm.bind({
event: "sendAdView",
listener: {
sendAdView: function(event) {
var rt = this.$root,
gsd = this.settings.responses.gsd,
uto = rt.utils.object;
var params = uto.extend({
rid: gsd.rid,
midx: 0,
rts: rt.utils.date.now(),
prod_t: "unknown",
jsv: rt.version
}, rt.helpers.getHookSD(event.data.hookId), event.data.params);
this.loadScript([gsd.rs, "/action/adview.htm"].join(""), params, "adViewed", event.data)
}
}
});
comm.bind({
event: "adViewed",
listener: {
adViewed: function(event) {
var rt = this.$root,
hook = rt.settings.hooksMap[event.data.hookId];
hook.viewed = true
}
}
});
comm.bind({
event: "doRedirect",
listener: {
doRedirect: function(event) {
var result = event.data;
var rt = this.$root,
st = rt.settings,
b = rt.browser,
ut = rt.utils,
hook = result.hook,
reuseWindow = rt.helpers.getHookBehavior(hook.id).adsReuseWindow,
winName;
if (st.clickStatus == "complete") {
return
}
if (!result.maxLength) {
result.maxLength = b.IE ? 2048 : 8192
}
var data = rt.helpers.getHookData(hook.id);
var url = result.url || data.ads[hook.currentAdIndex].redirectURL;
rt.event.fire(hook.type + "HookMouseout", {
hookId: hook.id
});
var hookNodeId = hook.node.id;
st.clickStatus = "complete";
if (hook.bubble) {
rt.event.fire("hideBubble", {
hookId: hook.id
})
}
hook = null;
if (url.length < result.maxLength) {
winName = hookNodeId;
try {
winName = st.adWin.name
} catch (ex) {}
if (b.IE && b.getVersion(true) < 9) {
var anchor = rt.utils.dom.createDOMFragment({
tag: "a",
parent: document.body,
attributes: {
href: url
},
style: {
display: "none"
}
});
if (!reuseWindow && st.adWin && winName == hookNodeId) {
anchor.target = winName
}
anchor.click()
} else {
if (!reuseWindow && st.adWin && winName == hookNodeId) {
try {
st.adWin.location = url
} catch (ex) {
window.location = url;
st.adWin.close();
st.adWin = null
}
} else {
window.location = url
}
}
} else {
var action = url,
inputs = null,
urlParamsIndex = url.indexOf("?");
if (urlParamsIndex != -1) {
action = url.substring(0, urlParamsIndex);
var params = ut.string.toObject(url.substring(urlParamsIndex + 1), null, true);
inputs = [];
for (var key in params) {
ut.array.push(inputs, {
tag: "input",
type: "hidden",
value: params[key],
attributes: {
name: key
}
})
}
}
var redirectForm = ut.dom.createDOMFragment({
tag: "form",
parent: document.body,
style: {
display: "none"
},
children: inputs,
attributes: ut.object.extend({
action: action,
method: "post"
}, reuseWindow ? {} : {
target: hookNodeId
})
});
redirectForm.submit()
}
}
}
});
comm.bind({
event: "productClick",
listener: {
productClick: function(event) {
var rt = this.$root,
st = rt.settings,
hookId = event.data.hookId,
hook = st.hooksMap[hookId],
data = rt.helpers.getHookData(hookId),
clickType = event.data.clickType || hook.clickType;
if (st.clickStatus == "complete") {
return
}
if ((clickType == "onLink" || clickType == "onLinkAfterWinOpen") && data && data.ads[hook.currentAdIndex].redirectURL == "") {
st.clickStatus = "none";
if (st.adWin) {
rt.event.fire("hideBubble", {
hookId: hookId
});
st.adWin.close();
st.adWin = null
}
return
}
var url = this.getRedirectUrl(hook, event.data.url || null, clickType);
rt.event.fire("startClick", {
url: url,
hook: hook
})
}
}
});
comm.bind({
event: "startClick",
listener: {
updateClickCookie: function(event) {
var rt = this.$root,
st = rt.settings,
ut = rt.utils,
uto = ut.object,
now = rt.utils.date.now(),
data = event.data,
hook = data.hook;
var params = uto.clean(uto.extend({
rid: this.settings.responses.gsd.rid,
bdc: hook.bdc,
midx: hook.midx || hook.currentAdIndex,
rts: now,
vt: ut.timer.poll("adView" + hook.id),
clk_t: hook.clickType,
jsv: rt.version,
prod_t: hook.prod || "",
tcln: hook.tcln || "",
pst: hook.pst || "",
ifip: st.ifip || ""
}, rt.helpers.getHookSD(hook.id)));
var url = ["http://", this.settings.responses.gsd.rs, "/", now, "/ck.js"].join("");
this.loadScript(url, params, "doRedirect", data)
}
}
});
comm.bind({
event: "commRemoteReady",
listener: {
commRemoteReady: function() {
var rt = this.$root,
uto = rt.utils.object,
st = this.settings,
key, data = [];
st.messagingReady = true;
var gsd = st.responses.gsd;
if (gsd.cks) {
for (key in gsd.cks) {
rt.utils.array.push(data, {
name: key,
value: gsd.cks[key],
expiration: "2y"
})
}
var message = uto.stringify({
action: "setcookie",
data: data
});
this.sendMessage(message)
}
while (this.pendingRequests.length) {
this.sendRequest.apply(this, this.pendingRequests.shift())
}
}
}
});
comm.bind({
event: "sendErrorReport",
listener: {
sendErrorReport: function(event) {
var rt = this.$root,
st = rt.settings,
gsd = rt.comm.settings.responses.gsd,
evt = null,
cbdata = null;
if (event.data.cbdata) {
evt = event.data.cbdata.evt;
cbdata = event.data.cbdata.data;
delete event.data.cbdata
}
this.loadScript(this.settings.errorReportingUrl, rt.utils.object.extend({
pid: st.customerId,
wsid: st.websiteId,
jsv: rt.version,
rid: gsd ? gsd.rid : ""
}, event.data || {}), evt, cbdata)
}
}
});
$root.$create("settings", {}, {
svntest: "yes",
supportedClients: {
IE: 6,
Firefox: 1.5,
Safari: 3,
MobileSafari: 4,
Opera: 10,
Chrome: 1,
AppleWebKit: 533,
ucweb: 7
},
hosts: {
resourcesDefault: "resources.infolinks.com",
scriptDefaultPath: "/js/"
},
productCodes: {
i: "intext",
t: "intag",
s: "insearch",
o: "insearch",
f: "inframe"
},
nodeTypes: {
ELEMENT: 1,
DOCUMENT: 9,
TEXT: 3,
COMMENT: 8
},
baseZIndex: 9999999,
bdc: 0,
behavior: {
def: {
linkColor: "009900",
bubbleShowDelay: 200,
bubbleHideDelay: 1000,
adsReuseWindow: true,
hoverRequestDelay: 20
},
sanitizer: {
linkColor: "color",
linkHoverColor: "color",
linkHoverBgColor: "color",
bubbleShowDelay: "int",
bubbleHideDelay: "int",
adsReuseWindow: "bool",
hoverRequestDelay: "int"
}
},
hooksMap: {},
hooksCount: 0,
baseClass: "IL_BASE",
clickStatus: "none",
defaultLabel: "infolinks",
defaultHomeUrl: "http://www.infolinks.com/?kid=bb&trackerid=101",
defaultHelpUrl: "http://www.infolinks.com/opt-out.html?pid=<%= cid %>&wsid=<%= wsid %>",
yourAdHereUrl: "http://www.infolinks.com/ads",
white_labelLoaded: false,
textLimits: {
def: {
plinks: {
t: 2,
i: 100
},
pimgs: {
t: 2,
i: 100
},
phdrs: {
t: 2,
i: 100
},
pdesc: 1,
page_keyw: 2
}
},
translations: {
advertisement: {
en: "Advertisement",
es: "Aviso Publicitario"
},
yourAdHere: {
en: "Your Ad Here",
es: "Publique Aqu??"
},
clickHere: {
en: "Click here",
es: "Presione Aqu??"
},
searchingFor: {
en: "Searching for",
es: "Buscando"
},
nextSearchResultFor: {
en: "Next search result for",
es: "Nueva b??squeda para"
},
learnMore: {
en: "Learn More",
es: "Saber m??s"
},
adsBy: {
en: "Ads by",
es: "Anuncios"
}
}
});
$root.$create("harvest", {
createInstance: function() {
var o = {};
o.texts = [];
o.nodes = [];
o.stopped = false;
o.harvesting = false;
o.firstNode = null;
o.charCount = 0;
o.insideAllowedNode = null;
o.useAllowSettings = false;
return o
},
setConditionalTags: function() {
var rt = this.$root,
st = rt.settings,
hs = this.settings,
label = (st.white_label || st.defaultLabel).toUpperCase();
hs.tagGenericOff = "INTEXT_OFF";
hs.tagGenericOn = "INTEXT_ON";
hs.tagGenericStop = "INTEXT_STOP";
hs.tagGenericToggle = "INTEXT_TOGGLE";
hs.tagOff = label + "_OFF";
hs.tagOn = label + "_ON";
hs.tagStop = label + "_STOP";
hs.tagToggle = label + "_TOGGLE"
},
setHarvestEnabled: function() {
var hs = this.settings;
var bodyHtml = document.body.innerHTML;
var indexOfCommentTag = function(tag) {
return bodyHtml.indexOf(["<!--", tag, "-->"].join(""))
};
var onIndexGeneric = indexOfCommentTag(hs.tagGenericOn);
var onIndexWL = indexOfCommentTag(hs.tagOn);
var onIndex = (onIndexGeneric == -1 || onIndexWL == -1) ? Math.max(onIndexGeneric, onIndexWL) : Math.min(onIndexGeneric, onIndexWL);
var offIndexGeneric = indexOfCommentTag(hs.tagGenericOff);
var offIndexWL = indexOfCommentTag(hs.tagOff);
var offIndex = (offIndexGeneric == -1 || offIndexWL == -1) ? Math.max(offIndexGeneric, offIndexWL) : Math.min(offIndexGeneric, offIndexWL);
hs.enabled = (onIndex == -1 || (offIndex != -1 && onIndex > offIndex))
},
getHarvestedText: function(container) {
var rt = this.$root,
st = rt.settings,
hs = this.settings,
hp = rt.helpers,
ut = rt.utils,
uta = ut.array,
hd = st.highlightDeny,
ha = st.highlightAllow,
instance = this.createInstance();
hs.instances[hs.instances.length] = instance;
if (hs.instances.length == 1) {
ut.timer.start("tmr_har")
}
if (ha) {
hs.allowedTags = uta.toObject(ha.tags, {}, 1);
hs.allowedIds = uta.toObject(ha.ids, {}, 1);
hs.allowedCls = uta.toObject(ha.cls, {}, 1);
for (var key in hs.allowedTags) {
if (hs.deniedTags[key]) {
delete hs.deniedTags[key]
}
}
if (!ha.min) {
ha.min = 1
}
instance.useAllowSettings = true
}
if (hd) {
hs.deniedTags = uta.toObject(hd.tags, hs.deniedTags, 1);
hs.deniedIds = uta.toObject(hd.ids, hs.deniedIds, 1);
hs.deniedCls = uta.toObject(hd.cls, hs.deniedCls, 1)
}
this.setConditionalTags();
this.setHarvestEnabled();
hs.allowOnclick = hp.getVar("allow_onclick");
this.harvestText(container || document.body);
var text = instance.texts.join("|");
text = hp.normalizeText(text);
var twnum = hp.countWords(text);
if (instance.useAllowSettings && twnum < ha.min) {
instance.useAllowSettings = false;
this.harvestText(container || document.body);
text = instance.texts.join("|");
text = hp.normalizeText(text);
twnum = hp.countWords(text)
}
if (hs.instances.length == 1) {
ut.timer.stop("tmr_har")
}
instance.text = text;
return instance
},
isHarvestableNode: function(node) {
var hs = this.settings,
ut = this.$root.utils;
return !((node.getAttribute("onclick") != null && node != document.body && !hs.allowOnclick) || hs.deniedTags[node.tagName.toLowerCase()] || (node.id && hs.deniedIds[node.id]) || (node.className && ut.object.hasKey(hs.deniedCls, node.className.split(/\s+/))) || (!this.$root.comm.settings.responses.gsd.wd.ht && !ut.dom.element.isVisible(node)))
},
harvestText: function(node) {
var rt = this.$root,
hs = this.settings,
nodeType = null,
ut = rt.utils,
uto = ut.object,
tm = ut.timer,
nt = rt.settings.nodeTypes,
i, leni, text, instanceNum = hs.instances.length - 1,
instance = hs.instances[instanceNum];
if (!instance.harvesting) {
instance.harvesting = true;
instance.stopped = false;
tm.start("harvest" + instanceNum);
instance.nodes = [];
instance.texts = [];
instance.charCount = 0;
instance.firstNode = node;
if (!instance.useAllowSettings) {
instance.insideAllowedNode = node
}
}
if (instance.stopped || hs.timeLimit != -1 && tm.poll("harvest" + instanceNum) >= hs.timeLimit) {
instance.stopped = true
} else {
nodeType = node.nodeType
}
var hasAllowedIds = uto.keys(hs.allowedIds).length > 0,
hasAllowedCls = uto.keys(hs.allowedCls).length > 0;
switch (nodeType) {
case nt.DOCUMENT:
case nt.ELEMENT:
if (this.isHarvestableNode(node)) {
if (instance.useAllowSettings && !instance.insideAllowedNode && !hs.deniedTags[node.tagName.toLowerCase()] && ((!hasAllowedIds && !hasAllowedCls) || (hasAllowedIds && node.id && hs.allowedIds[node.id]) || (hasAllowedCls && node.className && uto.hasKey(hs.allowedCls, node.className.split(/\s+/))))) {
instance.insideAllowedNode = node
}
for (i = 0, leni = node.childNodes.length; i < leni; i++) {
if (instance.stopped) {
break
}
this.harvestText(node.childNodes[i])
}
if (instance.insideAllowedNode == node) {
instance.insideAllowedNode = null
}
}
break;
case nt.TEXT:
if (hs.enabled && instance.insideAllowedNode) {
text = ut.string.trim(node.data).replace(/\s+/g, " ");
if (text.length > 3) {
if (hs.charLimit != -1 && instance.charCount + text.length > hs.charLimit) {
instance.stopped = true;
text = text.substring(0, hs.charLimit - instance.charCount).replace(/\S+$/, "")
}
ut.array.push(instance.nodes, node);
ut.array.push(instance.texts, text);
instance.charCount += text.length
}
}
break;
case nt.COMMENT:
this.checkConditionalTags(ut.string.trim(node.data), hs)
}
if (instance.firstNode == node) {
instance.harvesting = false;
tm.stop("harvest" + instanceNum)
}
},
checkConditionalTags: function(value, st) {
var c = this.settings;
switch (value) {
case c.tagOff:
case c.tagGenericOff:
st.enabled = false;
break;
case c.tagOn:
case c.tagGenericOn:
st.enabled = true;
break;
case c.tagToggle:
case c.tagGenericToggle:
st.enabled = !st.enabled;
break;
case c.tagStop:
case c.tagGenericStop:
st.stopped = true
}
}
}, {
settings: {
allowedCls: null,
allowedIds: null,
charLimit: 8000,
deniedCls: {
footer: 1,
wibiyaToolbar_window: 1
},
deniedIds: {
footer: 1,
wibiyaToolbar: 1,
wibiyaToolbar_window_template: 1
},
deniedTags: {
a: 1,
acronym: 1,
address: 1,
br: 1,
dd: 1,
dl: 1,
dt: 1,
embed: 1,
fieldset: 1,
h1: 1,
h2: 1,
h3: 1,
h4: 1,
h5: 1,
h6: 1,
iframe: 1,
input: 1,
label: 1,
legend: 1,
noscript: 1,
object: 1,
param: 1,
script: 1,
select: 1,
style: 1,
textarea: 1,
th: 1,
title: 1,
m: 1
},
enabled: true,
timeLimit: 1000,
instances: []
}
});
var shared = $root.$create("shared", {}, null, true);
shared.bind({
event: "main",
listener: {
main: function() {
var rt = this.$root,
ut = rt.utils,
st = rt.settings;
st.cconf = ut.string.toObject(ut.cookie.get("$ice-conf")) || {};
if (st.cconf.logto) {
rt.logger.output = st.cconf.logto
}
if (st.cconf.er) {
rt.logger.errorReporting = parseInt(st.cconf.er, 10)
}
rt.utils.timer.start("tmr_wait");
rt.settings.boot = (window["INFOLINKS"] && window["INFOLINKS"]._boot) ? window["INFOLINKS"]._boot : window.$iceboot ? window.$iceboot : null;
var $this = this;
rt.helpers.getVar("white_label", rt.settings);
if (rt.helpers.chanceIntegration()) {
return
}
if (document.readyState && /complete|interactive/i.test(document.readyState)) {
$this.$root.event.fire("domready");
return
}
if (this.$root.what(document.addEventListener) == "function") {
document.addEventListener("DOMContentLoaded", function() {
$this.$root.event.fire("domready")
}, false)
} else {
document.onreadystatechange = function() {
if (/complete|interactive/i.test(document.readyState)) {
document.onreadystatechange = null;
$this.$root.event.fire("domready")
}
}
}
}
}
});
shared.bind({
event: "domready",
listener: {
domready: function() {
var rt = this.$root,
hp = rt.helpers,
msg, i, leni, pluginUrl, src;
rt.utils.timer.stop("tmr_wait");
rt.utils.timer.start("tmr_all");
if (rt.settings._initialized) {
msg = "Trying to re-run an application that has already been initialized."
} else {
if (!hp.isSupportedClient()) {
msg = "Client is not supported: " + rt.browser.toString()
}
}
if (msg) {
rt.logger.error(msg, this.domready);
return
}
rt.settings._initialized = true;
hp.setHosts();
if (rt.demo.isDemo()) {
rt.event.fire("demo");
return
}
rt.event.fire("loadPlugins")
}
}
});
shared.bind({
event: "loadPlugins",
listener: {
loadPlugins: function() {
var rt = this.$root,
st = rt.settings,
hs = st.hosts,
src, i, leni, pluginUrl;
if (rt.settings.white_label && !rt.settings.white_labelLoaded) {
rt.settings.white_labelLoaded = true;
rt.comm.loadScript([hs.resources, hs.scriptDefaultPath, "0/wl/", st.white_label, ".js"].join(""), null, "loadPlugins");
return
}
var plugins = rt.helpers.getVar("plugins");
if (plugins) {
src = rt.settings.hosts.src ? "/src" : "";
if (rt.what(plugins) == "string") {
plugins = [plugins]
}
rt.settings.plugins = {};
for (i = 0, leni = plugins.length; i < leni; i++) {
pluginUrl = (plugins[i].match(/https?:\/\//)) ? plugins[i] : [rt.settings.hosts.resources, "/js", src, "/0/plugins/", plugins[i], ".js"].join("");
rt.settings.plugins[pluginUrl] = false;
rt.comm.loadScript(pluginUrl, null, "pluginLoaded", {
plugin: pluginUrl
})
}
} else {
rt.event.fire("beforeGSD")
}
}
}
});
shared.bind({
event: "pluginLoaded",
listener: {
pluginLoaded: function(event) {
var rt = this.$root,
st = rt.settings,
key;
st.plugins[event.data.plugin] = true;
if (rt.utils.array.indexOf(rt.utils.object.values(st.plugins), false) == -1) {
for (key in rt.plugins) {
if (rt.plugins[key] && rt.what(rt.plugins[key].init) == "function") {
rt.plugins[key].init()
}
}
rt.event.fire("beforeGSD")
}
}
}
});
shared.bind({
event: "beforeGSD",
listener: {
prepareGSD: function() {
var rt = this.$root,
st = rt.settings,
hp = rt.helpers;
hp.getCustomerId();
var docRef = hp.getReferrer();
var params = {
evt: "afterGSD",
pid: st.customerId,
wsid: st.websiteId,
pdom: location.hostname,
purl: st.customerUrl,
jsv: rt.version
};
if (docRef.ref.length) {
params.ref = docRef.ref
}
if (docRef.refq.length) {
params.refq = docRef.refq
}
rt.utils.timer.start("tmr_gsd");
rt.comm.loadScript([st.hosts.router, "/gsd/", rt.utils.date.now(), rt.utils.number.next("nocache")].join(""), params)
}
}
});
shared.bind({
event: "afterGSD",
listener: {
gsdCallback: function(evt) {
var rt = this.$root,
data = evt.data,
tl = rt.settings.textLimits;
rt.utils.timer.stop("tmr_gsd");
data.rs = rt.utils.string.toObject(location.search, "il.rt") || rt.helpers.getVar("runtime_server") || data.rs || null;
var msg = "";
if (!data.rs) {
msg = "GSD Response is missing `rs`."
}
if (!data.prs) {
msg = "GSD Response is missing `prs`."
}
if (msg) {
rt.logger.error(msg, this.gsdCallback, true);
return
}
data.rs = data.rs.toLowerCase();
if (!data.makey) {
data.makey = ""
}
rt.helpers.setDefaultWebsiteDirectives(data);
tl.merged = rt.utils.object.extend(tl.def, data.wd || {});
if (data.prs.indexOf("r") != -1) {
if (data.prs.indexOf("t") == -1) {
data.prs += ",t"
} else {
data.wd.rtm = "b"
}
}
rt.comm.settings.responses.gsd = data;
rt.event.fire("initComm");
if (/i|t/.test(data.prs)) {
rt.event.fire("beforeHarvest")
} else {
rt.event.fire("beforeImpression")
}
}
}
});
shared.bind({
event: "beforeHarvest",
listener: {
prepareHarvest: function() {
var rt = this.$root,
hp = rt.helpers,
st = rt.settings,
hd = null,
gsd = rt.comm.settings.responses.gsd;
hd = hp.getVar("highlight_deny") || gsd.wd.hd || {};
if (rt.what(window["vBulletin"]) != "undefined") {
if (!hd.cls) {
hd.cls = []
}
rt.utils.array.push(hd.cls, "thead", "tcat", "navbar", "tfoot", "alt2")
}
st.$extend({
highlightDeny: hd,
highlightAllow: hp.getVar("highlight_allow") || gsd.wd.ha
});
rt.updater.settings.className = rt.what(window["blogger"]) != "undefined" ? "hentry" : (hp.getVar("updater_class") || hp.getVar("refreshed_container"));
var harvested = rt.harvest.getHarvestedText();
rt.event.fire("beforeImpression", {
ptxt: harvested.text
})
}
}
});
shared.bind({
event: "beforeImpression",
listener: {
prepareImpression: function(event) {
var rt = this.$root,
ut = rt.utils,
hp = rt.helpers,
st = rt.settings,
prs, prods = rt.products,
cm = rt.comm,
gsd = cm.settings.responses.gsd,
tgst = prods.intag.settings,
crt = document.getElementsByName(tgst.relatedTags).length || "",
ctc = document.getElementsByName(tgst.prodId).length || "";
if (!st.impression) {
st.impression = {
params: {}
}
}
var imp = st.impression;
var impp = imp.params;
prs = ut.array.toObject(gsd.prs.split(","), {}, true);
if (event.data && event.data.updater) {
prs = {
i: true
}
}
impp.ptxt = event.data && gsd.prs != "s" ? event.data.ptxt : "";
impp.twnum = hp.countWords(impp.ptxt);
if (prs["i"] && impp.twnum < gsd.wd.qmin) {
delete prs["i"]
}
if (prs["t"] && gsd.wd.rtm == "m" && !crt && !ctc) {
delete prs["t"]
}
if (rt.helpers.getVar("inframe_disable") === true) {
delete prs["f"]
}
if (prs["f"]) {
var gpmp = prods.inframe.buildImpPageMarginsParam();
if (gpmp) {
impp.ifs = gpmp
} else {
delete prs["f"]
}
}
impp.prs = ut.object.keys(prs).join(",");
if (impp.prs == "") {
impp.prs = ".";
impp.ptxt = ""
}
if (!event.data || !event.data.updater) {
impp.pid = st.customerId;
impp.wsid = st.websiteId;
impp.makey = gsd.makey;
impp.anow = hp.getVar("anow") || "";
impp.rid = gsd.rid || "";
impp.purl = st.customerUrl;
impp.jsv = rt.version;
impp.ms = gsd.ms || "";
impp.gid = gsd.wd.gid || "";
impp.rh = hp.getVar("require_highlight") || "";
impp.by = "u";
impp.crt = crt;
impp.ctc = ctc;
impp.cfv = cm.settings.flashVersion;
st.ifip = hp.getVar("ifip") || "";
st.blankURL = ["http://", st.hosts.resources, "/static/blank.html"].join("");
impp.ifip = st.ifip;
impp.pf = hp.getPlatform();
impp.ptitle = hp.normalizeText(document.title);
impp.ref = st.ref;
impp.refq = st.refq;
impp.csilv = hp.getSilverlightVersion();
if (impp.prs.match(/[^so,\.]/) != null) {
impp.plinks = hp.getTagTexts("a", "text", "plinks");
impp.pimgs = hp.getTagTexts("img", "alt", "pimgs");
impp.phdrs = hp.getTagTexts(ut.string.qw("h1 h2 h3 h4 h5 h6"), "text", "phdrs");
impp.pdesc = hp.getMetaContent("description", st.textLimits.merged.pdesc);
impp.page_keyw = hp.getMetaContent("keywords", st.textLimits.merged.page_keyw)
}
imp.pcode = (hp.getVar("encoding") || document.characterSet || document.charset || "").toLowerCase();
imp.url = ["http://", gsd.rs, "/action/doq.htm", "?pcode=", imp.pcode, "&r=", ut.date.now(), ut.number.next("nocache")].join("");
if (rt.browser.IE && cm.settings.mode == "cors") {
imp.url += "&oct=1"
}
imp.method = "POST";
imp.onSuccess = "afterImpression"
}
ut.object.extend(impp, gsd.cks || {});
impp.rts = ut.date.now();
imp.params = ut.object.clean(impp);
cm.sendRequest(imp, function(sendBy) {
imp.params.by = sendBy;
if (!ut.timer.poll("tmr_imp")) {
ut.timer.start("tmr_imp")
}
})
}
}
});
shared.bind({
event: "afterImpression",
listener: {
handleImpressionResponse: function(event) {
var rt = this.$root,
utt = rt.utils.timer,
response, prs;
if (!utt.delta("tmr_imp")) {
utt.stop("tmr_imp")
}
response = rt.helpers.processImpressionResponse(event.data);
if (rt.what(response) != "object") {
rt.logger.error("Bad Impression response.", true);
return
}
prs = response.prs;
if (prs.r) {
if (prs.t) {
prs.t.sentences = rt.utils.array.uniq(rt.utils.array.concat(prs.t.sentences, prs.r.sentences));
rt.utils.object.extend(prs.t.behavior, prs.r.behavior)
} else {
prs.t = prs.r;
delete prs.r
}
}
rt.comm.settings.responses.impression = response;
rt.externalTags.init();
rt.event.fire("preRenderProducts")
}
}
});
shared.bind({
event: "preRenderProducts",
listener: {
preRenderProducts: function() {
var rt = this.$root,
hp = rt.helpers,
st = rt.settings,
bh = st.behavior,
ut = rt.utils;
bh.customer = hp.getCustomerBehavior("link_color link_hover_color link_hover_bg_color ads_reuse_window bubble_direction bubble_logo_url bubble_logo_url_downgrade bubble_logo_width bubble_logo_height bubble_logo_link bubble_help_link");
bh.impression = hp.renameBehaviorProperties(rt.comm.settings.responses.impression.behavior_imp || {});
hp.createBaseClasses();
st.homeUrl = bh.customer.bubbleLogoLink || st.defaultHomeUrl;
st.helpUrl = rt.utils.VeST(bh.customer.bubbleHelpLink || bh.customer.bubbleLogoLink || st.defaultHelpUrl, {
cid: st.customerId,
wsid: st.websiteId
});
st.productRenderStatus = ut.array.toObject(ut.object.keys(st.productCodes), {}, "before");
this.$root.event.fire("renderProduct")
}
}
});
shared.bind({
event: "productRenderStatus",
listener: {
productRenderStatus: function(event) {
var rt = this.$root,
st = rt.settings,
ut = rt.utils,
ps = st.productRenderStatus,
data = event.data;
ps[data.prod] = data.status;
if (data.status == "failed") {
rt.logger.error([st.productCodes[data.prod], " failed. reason: ", data.reason].join(""), this.productRenderStatus)
}
if (!/before|during/.test(ut.object.values(ps).join(","))) {
this.$root.event.fire("afterRenderProducts")
}
}
}
});
shared.bind({
event: "afterRenderProducts",
listener: {
productsRendedred: function() {
var rt = this.$root,
st = rt.settings,
gsd = rt.comm.settings.responses.gsd,
i, len, cb, src = st.hosts.src ? "/src" : "";
if (/i|r|t/.test(gsd.prs)) {
rt.helpers.mapUnhoverableAreas()
}
if (rt.what(gsd.incs) != "undefined") {
for (i = 0, len = gsd.incs.length; i < len; ++i) {
var func = function(name, params) {
return function() {
if (rt.plugins[name] && rt.what(rt.plugins[name].init) == "function") {
rt.plugins[name].init(params)
}
}
};
cb = func(gsd.incs[i].s, gsd.incs[i].p);
rt.comm.loadScript([st.hosts.resources, "/js", src, "/0/plugins/", gsd.incs[i].s, ".js"].join(""), null, cb)
}
}
if (rt.updater.settings.className) {
rt.event.fire("initUpdater")
}
rt.utils.timer.stop("tmr_all");
rt.event.fire("sendImpressionLog")
}
}
});
shared.bind({
event: "sendImpressionLog",
listener: {
sendImpressionLog: function() {
var rt = this.$root,
st = rt.settings,
ut = rt.utils,
uta = ut.array,
tmr = ut.timer,
res = rt.comm.settings.responses,
gsd = res.gsd;
st.sendClientLog = rt.helpers.getVar("send_client_log") || gsd.scl || false;
if (!st.sendClientLog) {
return
}
var prods = rt.products,
ist = prods.intext.settings,
tst = prods.intag.settings,
sentence, i, leni, hook, intxt_sen = [];
var params = {
rid: gsd.rid,
makey: gsd.makey,
tmr_scr: st.boot && st.boot.tmr_scr ? ut.date.now() - st.boot.tmr_scr : -1,
tmr_wait: tmr.delta("tmr_wait") || -1,
tmr_gsd: tmr.delta("tmr_gsd") || -1,
tmr_har: tmr.delta("tmr_har") || -1,
tmr_imp: tmr.delta("tmr_imp") || -1,
tmr_dwq: tmr.delta("tmr_imp") || -1,
tmr_hi: tmr.delta("tmr_hi") || -1,
tmr_fsh: tmr.delta("tmr_fsh") || -1,
tmr_all: tmr.delta("tmr_all") || -1
};
if (gsd.prs.indexOf(ist.prodCode) != -1) {
params.intxt_num = [ist.rendered, ut.object.keys(ist.sentences).length].join("*");
for (sentence in ist.sentences) {
for (i = 0, leni = ist.sentences[sentence].hooks.length; i < leni; i++) {
hook = ist.sentences[sentence].hooks[i];
uta.push(intxt_sen, [sentence, hook.visible ? 1 : 0, hook.pos.left, hook.pos.top].join("_"))
}
}
params.intxt_sen = intxt_sen.join("*")
}
if (gsd.prs.indexOf(tst.prodCode) != -1) {
var tCldSent = (res.impression.prs[tst.prodCode] || {
sentences: []
}).sentences.length;
params.tCld_num = [uta.sum(uta.map(tst.instances, function(instance) {
return instance.hooksCount
})), tCldSent].join("*");
if (tst.instances.length) {
params.tCld_pos = [tst.instances[0].pos.left, tst.instances[0].pos.top].join("*")
}
}
rt.comm.loadScript(gsd.rs + "/action/dcil.htm", params)
}
}
});
$root.event.dom.bind(document, {
event: "keyup",
listener: {
keyboardShortcuts: function(event) {
var evt = event.domEvent,
rt = event.$root,
logger = rt.logger;
if (evt.keyCode == 76 && evt.ctrlKey && evt.altKey) {
logger.output = logger.output == "console" ? "none" : "console";
if (rt.what(window.console) != "undefined") {
console.info("Logging to console turned " + (logger.output == "console" ? "on." : "off."))
}
} else {
if (evt.keyCode == 67 && evt.ctrlKey && evt.altKey) {
if (rt.what(window.console) != "undefined") {
console.clear()
}
}
}
}
}
});
var products = $root.$create("products", {}, null, true);
var intext = products.$create("intext", {
createCandidate: function(node, parentNode, sentence) {
var rt = this.$root,
ut = rt.utils,
dm = ut.dom,
o = {};
o.sentence = sentence;
o.node = node;
o.parentNode = parentNode;
o.rendered = false;
o.type = "intext";
o.prod = "i";
o.bubble = ut.object.clone(rt.bubble.settings.base);
o.fontSize = (node.nodeType == 1 ? parseInt(dm.element.getStyle(node, "lineHeight"), 10) : parseInt(dm.element.getStyle(parentNode, "fontSize"), 10)) || 0;
o.visible = dm.element.isVisible(parentNode);
o.onViewPort = dm.element.isOnViewport(parentNode);
o.wordCount = (parentNode.innerText || parentNode.textContent).replace(/\s+/g, " ").length;
o.importance = parentNode.offsetWidth / dm.viewport.getWidth();
return o
},
estimateCandidatesFontSizeIE: function(candidates) {
var rt = this.$root,
b = rt.browser,
c;
if (!b.IE || b.getVersion(true) >= 9) {
return
}
for (var i = 0, leni = candidates.length; i < leni; i++) {
c = candidates[i];
c.fontSize = c.node.firstChild.offsetHeight || 0
}
},
scoreFactorsCalc: {
fontSize: function(v) {
return !v || v > 16 || v < 10 ? 0 : 1
},
wordCount: function(v) {
return v < 10 ? 0 : v < 20 ? 0.3 : v < 30 ? 0.6 : 1
},
importance: function(v) {
return v > 0.4 ? 1 : v > 0.2 ? 0.5 : v
}
},
scoreCandidates: function(candidates) {
var sf = this.settings.scoreFactors,
calc = this.scoreFactorsCalc,
c, i, leni;
for (i = 0, leni = candidates.length; i < leni; i++) {
c = candidates[i];
c.score = calc.fontSize(c.fontSize) * sf.fontSize + (c.visible ? 1 : 0) * sf.visible + (c.onViewPort ? 1 : 0) * sf.onViewPort + calc.wordCount(c.wordCount) * sf.wordCount + calc.importance(c.importance) * sf.importance
}
},
createStyleSheet: function() {
var rt = this.$root,
ist = this.settings,
bh = ist.behavior.merged,
b = rt.browser,
dm = rt.utils.dom,
dmst = dm.style;
var cs = dm.element.getStyle(document.body);
if (cs && cs.position == "relative" && cs.width && parseInt(cs.width, 10) < dm.document.getWidth()) {
document.body.style.position = "static"
}
var underline = dmst.buildHookUnderlineCSS(bh.underline, bh.linkColor, true);
dmst.addRule("." + ist.hookClass, [underline, "color:", bh.linkColor, " !important; background:transparent none repeat scroll 0% !important;cursor:pointer !important;position:static;display:inline !important;padding:0 0 1px 0 !important;float:none !important;"].join(""));
if (bh.linkHoverColor) {
dmst.addRule("." + ist.hookClass + "_HOVER", ["color:", bh.linkHoverColor, " !important;border-bottom-color:", bh.linkHoverColor, " !important;"].join(""))
}
if (bh.simanitIcon) {
if (b.IE && b.getVersion(true) <= 7) {
dmst.addRule("." + ist.hookClass + "_ICON", ["display:inline-block !important; position:static !important;cursor:pointer !important;margin:0 !important;padding:0 !important;background:transparent url(", bh.simanitIcon, ") no-repeat scroll ", bh.simanitPosition, " center; width:", bh.simanitWidth, "px !important;float:none !important;"].join(""))
} else {
dmst.addRule("." + ist.hookClass + "_ICON", ["display:inline !important;position:static !important;cursor:pointer !important;margin:0 !important;padding:0 !important;background:transparent url(", bh.simanitIcon, ") no-repeat scroll ", bh.simanitPosition, " center;padding-", bh.simanitPosition, ":", bh.simanitWidth, "px !important; float:none !important;", b.IE ? "height:1%;" : ""].join(""))
}
if (bh.simanitOver) {
dmst.addRule("." + ist.hookClass + "_ICON_OVER", ["background-image:url(", bh.simanitOver, ");"].join(""))
}
}
},
createHook: function(hook, textNode, updater) {
var rt = this.$root,
ist = this.settings,
st = rt.settings,
bh = ist.behavior.merged,
b = rt.browser,
node;
node = hook.node = document.createElement("span");
hook.id = ++st.hooksCount;
ist.hooksCount++;
node.id = ist.hookClass + hook.id;
if (updater) {
hook.updater = updater
}
st.hooksMap[hook.id] = hook;
node.className = ist.hookClass;
var text = textNode.data || textNode.innerHTML.replace(/<\/?span>/ig, "");
if (bh.simanitIcon) {
var simanitTag = ['<span class="', ist.hookClass, '_ICON"></span>'].join("");
node.innerHTML = bh.simanitPosition == "left" ? simanitTag + text : text + simanitTag
} else {
node.innerHTML = text
}
var ps = rt.utils.dom.element.getStyle(hook.parentNode),
css = [],
push = rt.utils.array.push;
if (ps["fontFamily"]) {
push(css, "font-family:", ps["fontFamily"], " !important;")
}
if (ps["fontWeight"]) {
push(css, "font-weight:", ps["fontWeight"], " !important;")
}
if (ps["fontStyle"]) {
push(css, "font-style:", ps["fontStyle"], " !important;")
}
if ((!b.IE || (b.getVersion(true) > 8)) && !b.Opera && ps["fontSize"] && ps["fontSize"].match(/px$/) != null) {
push(css, "font-size:", ps["fontSize"], " !important;")
}
if (textNode.nodeType == 1 || b.IE) {
push(css, this.fixIEAdNodeStyle(textNode))
}
rt.utils.dom.style.addRule("#" + node.id, css.join(""));
hook.currentAdIndex = 0;
rt.helpers.bindHookEvents(hook);
return node
},
fixIEAdNodeStyle: function(node) {
var rt = this.$root,
bh = this.settings.behavior.merged,
b = rt.browser,
ut = rt.utils,
dmel = ut.dom.element,
push = ut.array.push,
css = [];
if (node.nodeType != 1) {
node = node.parentNode
}
if (b.getVersion() >= 7 && bh.underline == "double") {
push(css, "border:1px solid transparent; border-bottom:1px solid ", bh.linkColor, ";")
}
if (bh.underline != "single" && bh.underline != "none") {
push(css, "padding-bottom:2px;")
}
var parent = node.offsetParent,
nodePos = dmel.offset(node);
if (parent && parent.tagName.toLowerCase().match(/^(?:li|td)$/) != null) {
if (nodePos.top + node.offsetHeight >= dmel.offset(parent).top + parent.offsetHeight) {
dmel.setStyle(parent, {
paddingBottom: "3px"
})
}
}
if (nodePos.top + node.offsetHeight > document.body.clientHeight) {
dmel.setStyle(document.body, {
paddingBottom: "3px"
})
}
parent = node.parentNode;
if (bh.underline == "double" && dmel.getStyle(parent, "styleFloat") && parseInt(dmel.getStyle(parent, "paddingBottom")) < 2 && parent.offsetHeight < 18) {
dmel.setStyle(parent, {
paddingBottom: "2px"
})
}
return css.join("")
},
revertCandidateNodesIE: function(updater) {
var rt = this.$root,
candidates, sentence, i, leni, textNode, node, parentNode;
var sentenceObjects;
if (!rt.browser.IE) {
return
}
if (updater) {
sentenceObjects = updater.impression.sentences
} else {
sentenceObjects = rt.comm.settings.responses.impression.sentences
}
for (sentence in sentenceObjects) {
candidates = sentenceObjects[sentence].candidates;
if (!candidates) {
continue
}
for (i = 0, leni = candidates.length; i < leni; i++) {
node = candidates[i].node;
textNode = document.createTextNode(node.innerText);
parentNode = node.parentNode;
parentNode.insertBefore(textNode, node);
parentNode.removeChild(node);
candidates[i].node = textNode
}
}
}
}, {
settings: {
prodCode: "i",
prodName: "intext",
behavior: {
def: {
skin: "brand",
theme: "def",
highlightCount: 1,
underline: "double",
favicon: false,
simanitIcon: null,
simanitOver: null,
simanitWidth: 16,
simanitPosition: "right"
},
sanitizer: {
highlightCount: "int",
underline: ["double", "single", "dotted", "dashed", "none"],
favicon: "bool",
simanitIcon: "str",
simanitOver: "str",
simanitWidth: "int",
simanitPosition: ["right", "left"]
}
},
themes: {
color: {
def: "#003366",
lightBlue: "#1b8ede",
green: "#67b045",
orange: "#f3933b",
red: "#dd3c42",
pink: "#d84189",
purple: "#5939aa"
}
},
hookClass: "IL_AD",
hooksCount: 0,
maxCandidates: 50,
scoreFactors: {
fontSize: 10,
visible: 10,
onViewPort: 50,
wordCount: 30,
importance: 0
},
rendered: 0
}
}, true);
intext.bind({
event: "renderProduct",
listener: {
renderIntext: function() {
var rt = this.$root,
prod = "i";
if (!rt.comm.settings.responses.impression.prs[prod]) {
rt.event.fire("productRenderStatus", {
prod: prod,
status: "none"
});
return
}
rt.event.fire("productRenderStatus", {
prod: prod,
status: "during"
});
rt.utils.timer.start("tmr_hi");
rt.event.fire("initIntext")
}
}
});
intext.bind({
event: "initIntext",
listener: {
init: function(event) {
var rt = this.$root,
st = rt.settings,
bh = st.behavior,
bhi = this.settings.behavior,
prod = "i",
imp = rt.comm.settings.responses.impression,
prodImp = imp.prs[prod],
uto = rt.utils.object;
function convertDoubleUnderline() {
for (var i = 0; i < arguments.length; i++) {
if (rt.what(arguments[i].underline) == "undefined" && rt.what(arguments[i].doubleUnderline) != "undefined") {
arguments[i].underline = arguments[i].doubleUnderline.toString() == "false" ? "dotted" : "double"
}
}
}
bhi.customer = rt.helpers.getCustomerBehavior("link_color highlight_count underline simanit_icon simanit_over simanit_width simanit_position");
bhi.impression = rt.helpers.renameBehaviorProperties(prodImp.behavior || {});
convertDoubleUnderline(bh.impression, bhi.impression, bhi.customer);
bhi.merged = rt.utils.object.extend({}, bh.def, bhi.def, bh.impression, bhi.impression, bh.customer, bhi.customer);
rt.helpers.sanitize(bhi.merged, uto.extend({}, bh.sanitizer, bhi.sanitizer));
if (!rt.bubble.initialized) {
rt.event.fire("initBubble", this.settings.prodName)
}
rt.event.fire("setIntextMarkers", event.data)
}
}
});
intext.bind({
event: "setIntextMarkers",
listener: {
setCandidates: function(event) {
var rt = this.$root,
hs = rt.harvest.settings,
ist = this.settings,
updater = event.data && event.data.updater ? event.data.updater : null,
nodes, context, sentencesKeys, sentenceIndexes, sentences, sentenceObjects, sentence, normalizedSentence, re, k, lenk, i, leni, node, text, sentenceObj, match, newNode, parentNode, harvested = hs.instances[hs.instances.length - 1],
matchText, textNode, candidateNode, hadMatches, textFollowingMatch, allCandidates = [];
if (updater) {
context = updater;
sentenceObjects = context.sentences = {}
} else {
context = rt.comm.settings.responses;
sentenceObjects = ist.sentences = {}
}
nodes = harvested.nodes;
sentences = context.impression.sentences;
sentenceIndexes = context.impression.prs.i.sentences || [];
sentencesKeys = rt.utils.object.keys(sentences);
for (k = 0, lenk = sentenceIndexes.length; k < lenk; k++) {
sentence = sentencesKeys[sentenceIndexes[k]];
normalizedSentence = sentence.replace(/([\+\.\?\(\)\[\]\*])/g, "\\$1").replace(/(\w+)/g, "\\b$1\\b").replace(/\s+/g, "\\s+");
re = new RegExp(normalizedSentence, "i");
sentenceObj = sentenceObjects[sentence] = {
candidates: [],
hooks: [],
rendered: 0
};
for (i = 0, leni = nodes.length; i < leni; i++) {
if (sentenceObj.candidates.length >= ist.maxCandidates) {
break
}
node = nodes[i];
if (!node.parentNode || rt.what(node.data) == "undefined" || rt.utils.array.indexOf(allCandidates, node) != -1) {
continue
}
text = node.data;
match = re.exec(text);
if (!match || node.parentNode.className == ist.hookClass) {
continue
}
textFollowingMatch = text.substr(match.index + match[0].length);
if (textFollowingMatch.match(/^[\u2019']s/) != null) {
continue
}
hadMatches = false;
newNode = document.createDocumentFragment();
parentNode = node.parentNode;
nodes.splice(i, 1);
while (match && sentenceObj.candidates.length < ist.maxCandidates) {
matchText = match[0];
if ((match.index == 0 || text.charAt(match.index - 1).match(/\w/) == null) && (text.length <= match.index + matchText.length || text.charAt(match.index + matchText.length).match(/\w/) == null)) {
hadMatches = true;
if (match.index > 0) {
textNode = document.createTextNode(text.substr(0, match.index));
newNode.appendChild(textNode);
nodes.splice(i++, 0, textNode)
}
if (rt.browser.IE && rt.browser.getVersion(true) < 9) {
candidateNode = document.createElement("span");
candidateNode.innerHTML = ["<span>", matchText.charAt(0), "</span>", matchText.substring(1)].join("")
} else {
candidateNode = document.createTextNode(matchText)
}
rt.utils.array.push(allCandidates, candidateNode);
candidateNode = newNode.appendChild(candidateNode);
rt.utils.array.push(sentenceObj.candidates, this.createCandidate(candidateNode, parentNode, sentence))
}
text = text.substr(match.index + matchText.length);
match = re.exec(text)
}
if (!hadMatches) {
continue
}
if (text != "") {
textNode = document.createTextNode(text);
newNode.appendChild(textNode);
nodes.splice(i, 0, textNode)
}
parentNode.insertBefore(newNode, node);
parentNode.removeChild(node);
node.data = "";
leni = nodes.length
}
this.estimateCandidatesFontSizeIE(sentenceObj.candidates);
this.scoreCandidates(sentenceObj.candidates);
rt.utils.array.insertionSort(sentenceObj.candidates, "score", false);
for (i = ist.behavior.merged.highlightCount, leni = sentenceObj.candidates.length; i < leni; i++) {
rt.utils.array.push(nodes, sentenceObj.candidates[i].node)
}
}
rt.event.fire("createIntextHooks", {
updater: updater
})
}
}
});
intext.bind({
event: "createIntextHooks",
listener: {
createIntextHooks: function(event) {
var rt = this.$root,
ist = this.settings,
bh = ist.behavior.merged,
updater = event.data && event.data.updater ? event.data.updater : null,
context, sentences, sentenceIndexes, sentencesKeys, sentenceObjects, sentence, sentenceObj, candidate, textNode, parentNode, hook, k, lenk;
if (updater) {
context = updater;
sentenceObjects = context.sentences
} else {
context = rt.comm.settings.responses;
sentenceObjects = ist.sentences;
this.createStyleSheet()
}
sentences = context.impression.sentences;
sentenceIndexes = context.impression.prs.i.sentences;
sentencesKeys = rt.utils.object.keys(sentences);
for (k = 0, lenk = sentenceIndexes.length; k < lenk; k++) {
sentence = sentencesKeys[sentenceIndexes[k]];
sentenceObj = sentenceObjects[sentence];
while (sentenceObj.candidates.length && sentenceObj.rendered < bh.highlightCount) {
candidate = sentenceObj.candidates[0];
textNode = candidate.node;
parentNode = textNode.parentNode || candidate.parentNode;
if (!parentNode) {
continue
}
hook = this.createHook(candidate, textNode, updater);
parentNode.insertBefore(hook, textNode);
parentNode.removeChild(textNode);
candidate.rendered = true;
sentenceObj.rendered++;
if (sentenceObj.hooks.length == 0 && !updater) {
ist.rendered++
}
rt.utils.array.push(sentenceObj.hooks, sentenceObj.candidates.shift());
candidate.pos = rt.utils.dom.element.offset(hook)
}
}
this.revertCandidateNodesIE(updater);
rt.utils.timer.stop("tmr_hi");
if (!updater) {
rt.event.fire("productRenderStatus", {
prod: "i",
status: "after"
})
}
}
}
});
intext.bind({
event: "intextHookMouseover",
listener: {
intextHookMouseover: function(event) {
var rt = this.$root,
st = rt.settings,
bh = this.settings.behavior.merged,
hook = st.hooksMap[event.data.hookId];
if (st.clickStatus != "none") {
return
}
var cls = this.settings.hookClass;
if (bh.linkHoverColor) {
hook.node.className = [cls, " ", cls, "_HOVER"].join("")
}
if (bh.simanitIcon && bh.simanitOver) {
var iconSpan = hook.node.getElementsByTagName("span");
if (iconSpan.length) {
iconSpan[0].className = [cls, "_ICON ", cls, "_ICON_OVER"].join("")
}
}
}
}
});
intext.bind({
event: "intextHookMouseout",
listener: {
hookMouseout: function(event) {
var rt = this.$root,
st = rt.settings,
ist = this.settings,
bh = ist.behavior.merged,
hook = st.hooksMap[event.data.hookId],
cls = this.settings.hookClass;
if (bh.linkHoverColor) {
hook.node.className = cls
}
if (bh.simanitIcon && bh.simanitOver) {
var iconSpan = hook.node.getElementsByTagName("span");
if (iconSpan.length) {
iconSpan[0].className = cls + "_ICON "
}
}
}
}
});
var autoPlacement = $root.$create("autoPlacement", {
createMarker: function(prodId, val) {
var rt = this.$root,
apst = this.settings,
dmel = rt.utils.dom.element,
resNodeHeight, node, result;
if (rt.what(prodId) == "array") {
prodId = prodId[0]
}
node = rt.utils.dom.createDOMFragment({
tag: "input",
type: "hidden",
attributes: {
name: prodId,
value: val
}
});
if (apst.result) {
result = apst.result
} else {
apst.result = result = this.findPlacement()
}
if (result.placement != "before" && (resNodeHeight = dmel.getStyle(result.node, "height"))) {
if (resNodeHeight.indexOf("px") != -1) {
dmel.setStyle(result.node, {
minHeight: parseInt(resNodeHeight, 10) + 45 + "px"
})
}
}
if (result.placement == "append") {
result.node.appendChild(node)
} else {
if (result.placement == "prepend") {
result.node.insertBefore(node, result.node.firstChild)
} else {
result.node.parentNode.insertBefore(node, result.node)
}
}
return [node]
},
findPlacement: function() {
var rt = this.$root,
ut = rt.utils,
dmel = ut.dom.element,
el, i, leni;
var ids = ut.string.qw("pageContent content_body contentBody contentWrapper main_content_section main-content bodyarea content-wrap Blog1 content");
var commentsId = ut.string.qw("commentlist comments respond commentpost commentform disqus_thread idc-container-parent");
for (i = 0, leni = commentsId.length; i < leni; i++) {
if (el = dmel.$(commentsId[i])) {
if (dmel.isVisible(el)) {
return {
node: el,
placement: (/respond|commentform|disqus_thread/.test(commentsId[i])) ? "before" : "prepend"
}
}
}
}
for (i = 0, leni = ids.length; i < leni; i++) {
if (el = dmel.$(ids[i])) {
if (dmel.isVisible(el)) {
return {
node: el,
placement: "append"
}
}
}
}
return {
node: this.findBestContainer(),
placement: "append"
}
},
findBestContainer: function() {
var rt = this.$root,
hs = this.settings,
ut = rt.utils,
i, leni, candidate, winner = null,
maxScore = -1000,
score, node, dm = ut.dom,
dmel = dm.element,
docHeight, docWidth, iceapw;
var forbiddenTags = ut.array.toObject(ut.string.qw("body tbody table tr ul dl ol p span embed marquee"), {}, 1);
var wrapper = dm.findWidestNode();
if (wrapper.node == document.body) {
docWidth = dm.document.getWidth();
docHeight = dm.document.getHeight()
} else {
docWidth = wrapper.width;
docHeight = wrapper.height
}
this.harvest(document.body);
for (i = 0, leni = hs.candidates.length; i < leni; i++) {
candidate = hs.candidates[i];
node = candidate.node;
if (forbiddenTags[node.tagName.toLowerCase()]) {
continue
}
candidate.wordsCount = parseInt(dmel.getData(node, "iceapw"), 10) || 0;
candidate.childrenCount = parseInt(dmel.getData(node, "iceapc"), 10) || 0;
if (!candidate.wordsCount || !candidate.childrenCount) {
continue
}
score = candidate.score = (candidate.width / (docWidth || 1) + candidate.height / (docHeight || 1)) / 4 + candidate.wordsCount / (hs.totalWordsCount || 1) - candidate.childrenCount / (hs.totalValidNodes || 1);
if (rt.what(score) == "number" && score > maxScore) {
maxScore = score;
winner = candidate
}
}
if (winner) {
for (i = 0, leni = hs.candidates.length; i < leni; i++) {
candidate = hs.candidates[i];
if (candidate.wordsCount == winner.wordsCount && candidate.node != winner.node && dmel.inHierarchy(candidate.node, winner.node)) {
winner = candidate
}
}
}
hs.winner = winner;
return winner ? winner.node : document.body
},
harvest: function(node) {
var rt = this.$root,
hs = this.settings,
nodeType, ut = rt.utils,
dmel = ut.dom.element,
tm = ut.timer,
nt = rt.settings.nodeTypes,
i, leni, wordsCount, text, parent, iceapw, iceapc;
if (!hs.harvesting) {
hs.harvesting = true;
hs.stopped = false;
tm.start("apHarvest");
hs.candidates = [];
hs.firstNode = node;
hs.enabled = true;
hs.timeLimit = 1000;
hs.totalWordsCount = 0;
hs.totalValidNodes = 0
}
if (hs.stopped || hs.timeLimit != -1 && tm.poll("apHarvest") >= hs.timeLimit) {
hs.stopped = true
} else {
nodeType = node.nodeType
}
switch (nodeType) {
case nt.DOCUMENT:
case nt.ELEMENT:
if (node.className.indexOf(rt.settings.baseClass) == -1 && node.className.indexOf(rt.products.intext.settings.hookClass) == -1 && dmel.isVisible(node) && rt.harvest.isHarvestableNode(node)) {
for (i = 0, leni = node.childNodes.length; i < leni; i++) {
if (hs.stopped) {
break
}
this.harvest(node.childNodes[i])
}
hs.totalValidNodes++;
parent = node.parentNode;
while (parent && parent != document && parent.tagName.toLowerCase() != "html") {
iceapc = (parseInt(dmel.getData(parent, "iceapc"), 10) || 0) + 1;
dmel.setData(parent, "iceapc", iceapc);
parent = parent.parentNode
}
ut.array.push(hs.candidates, {
node: node,
parent: node.parentNode,
width: dmel.getActualWidth(node),
height: dmel.getActualHeight(node)
})
}
break;
case nt.TEXT:
if (hs.enabled) {
text = ut.string.trim(node.data).replace(/\s+/g, " ");
if (text.match(/\S/)) {
wordsCount = text.split(/\s+/).length;
hs.totalWordsCount += wordsCount;
parent = node.parentNode;
while (parent && parent != document && parent.tagName.toLowerCase() != "html") {
iceapw = (parseInt(dmel.getData(parent, "iceapw"), 10) || 0) + wordsCount;
dmel.setData(parent, "iceapw", iceapw);
parent = parent.parentNode
}
}
}
break;
case nt.COMMENT:
rt.harvest.checkConditionalTags(ut.string.trim(node.data), hs)
}
if (hs.firstNode == node) {
hs.harvesting = false;
tm.stop("apHarvest")
}
}
}, {
settings: {}
}, false);
var intag = products.$create("intag", {
locateMarkers: function(prodId, lines) {
var rt = this.$root,
b = rt.browser,
i, leni, markers, autoMarker = [];
if (rt.what(prodId) != "array") {
prodId = [prodId]
}
for (i = 0, leni = prodId.length; i < leni; i++) {
markers = document.getElementsByName(prodId[i]);
if (markers.length) {
break
}
}
if ((rt.comm.settings.responses.gsd.wd.rtm == "b" || !markers.length) && (!b.IE || b.getVersion(true) > 6)) {
autoMarker = rt.autoPlacement.createMarker(prodId, lines);
if (autoMarker.length) {
this.settings.autoPlacement = true
}
}
return rt.utils.array.concat([], markers, autoMarker)
},
renderUnit: function(instanceIndex) {
var rt = this.$root,
st = rt.settings,
stit = this.settings,
instance = stit.instances[instanceIndex],
i, leni, html = "";
for (i = 0, leni = instance.lines; i < leni; i++) {
html += this.renderUnitLine(instanceIndex, i, i == leni - 1)
}
return rt.utils.dom.createDOMFragment({
tag: "div",
parent: instance.container,
after: instance.marker,
cls: st.baseClass,
style: {
margin: "0 auto",
padding: "10px 0",
width: instance.width + "px"
},
innerHTML: html
})
},
renderUnitLine: function(instanceIndex, line, withLogo) {
var rt = this.$root,
st = rt.settings,
stit = this.settings,
b = rt.browser,
instance = stit.instances[instanceIndex],
bh = stit.behavior.merged,
skinPath = this.getSkinPath();
var tpl = '<% if (withLogo){ %><div id="<%= prodId %>_LOGO_<%= instanceIndex %>" class="<%= baseCls %>" style="float:right; margin-right:15px; margin-top:8px; width:53px; height:12px; cursor:pointer; font-size:1px; <% if (oldIE || oldFF){ %>background:url(<%= skinPath %>logo<%= bh.darkBg ? \'-gray\' : \'\' %>.png) no-repeat scroll 0 0 transparent;<% } %>"> <% if (!(oldIE || oldFF)){ %> <svg version="1.1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" x="0px" y="0px" width="53px" height="12px" viewBox="0 0 636 144" enable-background="new 0 0 636 144" xml:space="preserve"> <g> <%-- dot (first) --%> <path id="<%= prodId %>_LOGO_<%= instanceIndex %>_DOT1" fill="<%= bh.theme == \'def\' ? \'#208CE5\' : themeColor %>" d="M16.918,24.865c5.848,0,10.57-4.735,10.57-10.583s-4.722-10.57-10.57-10.57 S6.334,8.434,6.334,14.282S11.07,24.865,16.918,24.865"/> <%-- in --%> <path fill="<%= logoColor %>" d="M88.085,43.784H77.024c-17.149,0-31.181,14.031-31.181,31.182v34.796 c0,0.218,0.016,0.415,0.027,0.618v5.185c0,5.71-4.672,10.382-10.382,10.382h-0.467c-5.71,0-10.382-4.672-10.382-10.382V92.608 h0.015V45.889v-0.025c0-1.124-0.885-2.033-2.01-2.08h-11.49c-1.09,0.047-1.949,0.907-1.986,1.996v46.828h0.04 c-0.015,0.355-0.04,0.707-0.04,1.066v22.246c0,14.031,11.479,25.512,25.511,25.512h1.151c14.031,0,25.511-11.48,25.511-25.512 v-5.466v-4.62v-28.89c0.082-9.872,8.159-17.948,18.031-17.948h6.366c9.871,0,17.948,8.076,18.042,17.948v28.89v4.62v28.873 c0.013,0.023,0.013,0.034,0.013,0.048c0,1.111,0.883,2.008,1.983,2.057h11.505c1.077-0.036,1.936-0.887,1.985-1.973v-27.966v-5.659 V74.966C119.267,57.815,105.234,43.784,88.085,43.784"/> <%-- f (part) --%> <path fill="<%= logoColor %>" d="M155.069,56.972v82.643c-0.072,0.992-0.886,1.78-1.903,1.818h-11.014 c-1.062-0.038-1.912-0.897-1.912-1.962c0-0.024,0-0.048-0.023-0.073V34.456c0.716-17.064,14.923-30.744,32.179-30.744h8.536 c0.025,0,0.038,0.011,0.06,0.011c1.053,0,1.915,0.849,1.974,1.901v11.037c-0.035,1.016-0.85,1.844-1.878,1.889h-8.692 c-9.509,0-17.327,7.75-17.327,17.268v6.301V56.972z"/> <%-- f (part) --%> <path fill="<%= logoColor %>" d="M151.99,59.104h28.873c0.023-0.012,0.034-0.012,0.047-0.012 c1.111,0,2.008-0.884,2.057-1.984V45.604c-0.036-1.078-0.887-1.938-1.973-1.986h-27.965"/> <%-- o --%> <path fill="<%= logoColor %>" d="M276.24,107.925h0.158V76.608c-0.37-18.164-15.248-32.825-33.494-32.825 h-16.756v0.022c-17.875,0.431-32.322,14.924-32.679,32.803h-0.026v31.316c0,18.213,14.601,33.064,32.705,33.496v0.012h16.589h0.021 h0.146C261.304,141.349,276.24,126.354,276.24,107.925 M208.93,107.925L208.93,107.925V77.289c0-9.914,8.096-18.02,18.021-18.02 h15.953c9.946,0,18.02,8.106,18.02,18.02v30.636h-0.167c0,9.949-8.074,18.021-17.999,18.021h-15.807 C217.026,125.946,208.93,117.874,208.93,107.925"/> <%-- l --%> <path fill="<%= logoColor %>" d="M312.844,139.376L312.844,139.376c0,1.064-0.798,1.938-1.829,2.045h-11.816 c-1.027-0.107-1.837-0.98-1.837-2.045h-0.013V5.769h0.013c0-1.135,0.908-2.033,2.031-2.057h11.432 c1.124,0.024,2.019,0.922,2.019,2.057V139.376z"/> <%-- dot (second) --%> <path id="<%= prodId %>_LOGO_<%= instanceIndex %>_DOT2" fill="<%= bh.theme == \'def\' ? \'#208CE5\' : themeColor %>" d="M341.662,24.865c5.848,0,10.57-4.735,10.57-10.583s-4.723-10.57-10.57-10.57 s-10.584,4.722-10.584,10.57S335.814,24.865,341.662,24.865"/> <%-- in (second) --%> <path fill="<%= logoColor %>" d="M412.829,43.784h-11.061c-17.149,0-31.181,14.031-31.181,31.182v34.796 c0,0.218,0.016,0.415,0.026,0.618v5.185c0,5.71-4.672,10.382-10.382,10.382h-0.468c-5.71,0-10.382-4.672-10.382-10.382V92.608 h0.016V45.723v-0.025c0-1.123-0.885-2.033-2.01-2.08h-11.49c-1.091,0.047-1.949,0.908-1.986,1.996v46.994h0.04 c-0.015,0.355-0.04,0.707-0.04,1.066v22.246c0,14.031,11.479,25.512,25.512,25.512h1.15c14.031,0,25.512-11.48,25.512-25.512 v-5.466v-4.62v-28.89c0.082-9.872,8.158-17.948,18.029-17.948h6.367c9.871,0,17.947,8.076,18.041,17.948v28.89v4.62v28.873 c0.014,0.023,0.014,0.034,0.014,0.048c0,1.111,0.883,2.008,1.982,2.057h11.506c1.076-0.036,1.936-0.887,1.984-1.973v-27.966v-5.659 V74.966C444.01,57.815,429.979,43.784,412.829,43.784"/> <%-- k --%> <path fill="<%= logoColor %>" d="M480.277,139.376L480.277,139.376V91.735h0.146h9.255l40.656,48.766 c0.599,0.549,1.15,0.906,1.841,0.932h16.073c0.882-0.025,2.869-0.322,1.794-2.056l-0.013-0.024l-47.58-56.777l44.599-36.815 c0.015-0.049,0.015-0.049,0.036-0.073c1.066-1.734-0.886-2.032-1.78-2.069H527.08c-0.621,0.024-1.15,0.324-1.666,0.791 l-36.812,31.075h-8.325V5.769c0-1.135-0.896-2.033-2.02-2.057h-11.422c-1.124,0.024-2.033,0.922-2.033,2.057v133.607 c0,1.064,0.803,1.938,1.844,2.045h11.802C479.476,141.313,480.277,140.44,480.277,139.376"/> <%-- s --%> <path fill="<%= logoColor %>" d="M603.208,84.782H577.99c-6.91-0.114-12.508-5.785-12.508-12.783 c0-6.996,5.598-12.895,12.508-12.895h39.271c1.146,0,2.08-0.959,2.08-2.111v0.191V45.752v-0.037c0-1.164-0.935-2.097-2.08-2.097 H577.99c-15.451,0-28.008,12.73-28.008,28.381c0,15.651,12.557,28.381,28.008,28.27h24.252c6.911,0.111,12.508,5.812,12.508,12.795 c0,6.996-5.597,12.896-12.508,12.896H591.56l0.001-0.014h-28.874c-0.022,0.014-0.034,0.014-0.047,0.014 c-1.11,0-2.007,0.896-2.056,2.01v11.449c0.035,1.092,0.886,1.963,1.973,2.014h0.225h27.74h12.224 c15.209-0.279,27.491-12.9,27.491-28.369C630.236,97.737,618.191,85.202,603.208,84.782"/> </g> </svg> <% } %> </div><% } %> <ul id="<%= prodId %>_LIST_<%= instanceIndex %>_<%= line %>" class="<%= baseCls %>" style="display:block; width:<%= instance.width - bh.logoWidth -30 %>px; height:<%= bh.tagHeight %>px; text-align:center; padding:0; margin:6px 0 0 0; font-size:0; overflow:hidden;"></ul>';
return rt.utils.VeST(tpl, {
prodId: stit.prodId,
baseCls: st.baseClass,
st: st,
bh: bh,
themeColor: stit.themes.color[bh.theme],
instance: instance,
instanceIndex: instanceIndex,
oldIE: stit.oldIE,
oldFF: b.Firefox && b.getVersion(true) < 4,
skinPath: skinPath,
line: line,
withLogo: withLogo,
logoColor: bh.darkBg ? "#888888" : "#003366"
})
},
getSkinPath: function() {
var stit = this.settings;
return ["http:/", this.$root.settings.hosts.resources, "static", "skins", stit.behavior.merged.skin, stit.prodName, stit.rv, ""].join("/")
},
hookMouseStateChange: function(event) {
var el = event.element,
key;
for (key in event.data) {
el.style[key] = event.data[key]
}
}
}, {
settings: {
prodId: "IL_IN_TAG",
tagCloud: "IL_TAG_CLOUD",
relatedTags: "IL_RELATED_TAGS",
prodCode: "t",
prodName: "intag",
rv: 1,
instances: [],
containerMinWidth: 200,
sentences: {},
oldIE: (function() {
var b = $root.browser;
return (b.IE && (document.compatMode == "BackCompat" || b.getVersion(true) < 9))
}()),
behavior: {
def: {
skin: "brand",
theme: "def",
fontFamily: "Arial,sans-serif",
fontWeight: "normal",
fontSize: 13,
underline: "single",
logoHeight: 11,
logoWidth: 48,
height: 60,
hookMargin: 15,
lines: 1,
darkBg: false
},
sanitizer: {
fontFamily: "str",
fontWeight: ["normal", "bold"],
fontSize: "int",
underline: ["double", "single", "dotted", "dashed", "none"],
logoHeight: "int",
logoWidth: "int",
height: "int",
hookMargin: "int",
lines: "int",
darkBg: "bool"
}
},
themes: {
color: {
def: "#003366",
lightBlue: "#1b8ede",
green: "#67b045",
orange: "#f3933b",
red: "#dd3c42",
pink: "#d84189",
purple: "#5939aa"
}
}
}
}, true);
intag.bind({
event: "renderProduct",
listener: {
renderIntag: function() {
var rt = this.$root,
prod = this.settings.prodCode;
if (!rt.comm.settings.responses.impression.prs[prod]) {
rt.event.fire("productRenderStatus", {
prod: prod,
status: "none"
});
return
}
rt.event.fire("productRenderStatus", {
prod: prod,
status: "during"
});
rt.event.fire("initIntag")
}
}
});
intag.bind({
event: "initIntag",
listener: {
init: function() {
var rt = this.$root,
st = rt.settings,
bh = st.behavior,
stit = this.settings,
prod = stit.prodCode,
uto = rt.utils.object,
prodImp = rt.comm.settings.responses.impression.prs[prod],
bhr = stit.behavior,
i, leni;
var cbh = rt.helpers.getVar("related_tags") || {};
bhr.impression = rt.helpers.renameBehaviorProperties(prodImp.behavior || {});
bhr.merged = uto.extend({}, bh.def, bhr.def, bh.impression, bhr.impression, bh.customer, cbh);
bhr.merged.tagHeight = Math.max(Math.ceil(bhr.merged.fontSize * 1.3) + 2, 17);
rt.helpers.sanitize(bhr.merged, uto.extend({}, bh.sanitizer, bhr.sanitizer));
if (!stit.themes.color[bhr.merged.theme]) {
bhr.merged.theme = "def"
}
if (!rt.bubble.initialized) {
rt.event.fire("initBubble", stit.prodName)
}
var markers = this.locateMarkers([stit.prodId, stit.relatedTags], bhr.merged.lines);
if (markers.length) {
for (i = 0, leni = markers.length; i < leni; i++) {
var o = {
marker: markers[i],
container: markers[i].parentNode,
lines: parseInt(markers[i].value, 10) || 1,
hooksCount: 0
};
o.width = rt.utils.dom.element.getActualWidth(o.container);
if (o.width < stit.containerMinWidth) {
rt.logger.warn("Warning: In-Tag instance does not have minimum required width.", this.init);
continue
}
rt.utils.array.push(stit.instances, o)
}
}
rt.event.fire("createIntagUnits")
}
}
});
intag.bind({
event: "createIntagUnits",
listener: {
createIntagUnits: function() {
var rt = this.$root,
st = rt.settings,
stit = this.settings,
bh = stit.behavior.merged,
ut = rt.utils,
dm = ut.dom,
dmel = dm.element,
i, leni, k, lenk, instance, sentence, liNode, hook, baseCls = st.baseClass,
hookId, j, lenj, lines, currentLine, logo, adNode, ps, b = rt.browser;
var underline = dm.style.buildHookUnderlineCSS(bh.underline, bh.linkColor, true);
dm.style.addRule("." + stit.prodId + "_AD", [underline, "display:inline; color:", bh.linkColor, " !important; cursor:pointer !important; font-family:", bh.fontFamily, "; font-weight:", bh.fontWeight, "; font-size:", bh.fontSize, "px !important; white-space:nowrap !important; float:none !important;"].join(""));
var liStyle = {
display: "inline",
margin: 0,
padding: 0,
background: "none"
};
var currentSentenceIndex = 0,
imp = rt.comm.settings.responses.impression,
sentenceIndexes = imp.prs[stit.prodCode].sentences,
el, ul, computedWidth, availWidth, sentenceLoopCount, sentencesKeys = ut.object.keys(imp.sentences);
for (i = 0, leni = stit.instances.length; i < leni; i++) {
instance = stit.instances[i];
currentLine = 0;
el = instance.node = this.renderUnit(i);
ps = el.previousSibling;
while (ps) {
if (ps.nodeType == st.nodeTypes.ELEMENT && ps.tagName.toLowerCase() != "input") {
if (/left|right/.test(dmel.getStyle(ps, b.IE ? "styleFloat" : "cssFloat"))) {
dmel.setStyle(el, {
clear: "left"
})
}
break
}
ps = ps.previousSibling
}
instance.pos = dmel.offset(el);
lines = [];
for (j = 0, lenj = instance.lines; j < lenj; j++) {
ul = dmel.$([stit.prodId, "LIST", i, j].join("_"));
if (ul) {
ut.array.push(lines, ul)
}
}
if (!lines.length) {
rt.logger.warn("Error: In-Tag UL element not found.", this.createIntagUnits);
rt.event.fire("productRenderStatus", {
prod: stit.prodCode,
status: "none"
});
return
}
logo = dmel.$([stit.prodId, "LOGO", i].join("_"));
if (logo) {
rt.event.dom.bind(logo, {
event: "click",
listener: function(event) {
rt.utils.dom.event.stop(event.domEvent);
if (st.homeUrl) {
window.open(st.homeUrl, "_blank")
}
}
})
}
computedWidth = 0;
availWidth = instance.width - bh.logoWidth - 30;
sentenceLoopCount = 0;
for (k = currentSentenceIndex, lenk = sentenceIndexes.length; k < lenk; k++) {
sentence = sentencesKeys[sentenceIndexes[k]];
hookId = ++st.hooksCount;
liNode = dm.createDOMFragment({
tag: "li",
parent: lines[currentLine],
cls: baseCls,
style: liStyle,
children: {
tag: "span",
cls: [baseCls, " ", stit.prodId, "_AD"].join(""),
style: {
padding: ["0 ", bh.hookMargin, "px"].join(""),
fontWeight: "normal"
},
id: [stit.prodId, "_AD", hookId].join(""),
innerHTML: ut.string.capitalize(sentence)
}
});
adNode = liNode.getElementsByTagName("span")[0];
rt.event.dom.bind(adNode, {
event: "mouseover",
data: {
fontWeight: "bold",
padding: ["0 ", bh.hookMargin - 2, "px"].join("")
},
listener: this.hookMouseStateChange
});
rt.event.dom.bind(adNode, {
event: "mouseout",
data: {
fontWeight: "normal",
padding: ["0 ", bh.hookMargin, "px"].join("")
},
listener: this.hookMouseStateChange
});
computedWidth += liNode.offsetWidth;
if ((computedWidth > availWidth) || (sentenceLoopCount >= 3 && currentLine >= lines.length - 1)) {
if (currentLine < lines.length - 1) {
lines[++currentLine].appendChild(liNode);
computedWidth = bh.hookMargin * 2 + liNode.offsetWidth
} else {
lines[currentLine].removeChild(liNode);
currentSentenceIndex = k;
st.hooksCount--;
break
}
}
instance.hooksCount++;
hook = rt.helpers.createHook(hookId, sentence, liNode.firstChild, bh.fontSize, this, stit.prodCode, stit.prodName, true, instance);
if (stit.autoPlacement) {
hook.pst = "auto"
}
dm.createDOMFragment({
isTextNode: true,
value: "\n",
parent: lines[currentLine]
});
if (k == lenk - 1) {
k = -1;
++sentenceLoopCount
}
}
}
this.$root.event.fire("productRenderStatus", {
prod: stit.prodCode,
status: "after"
})
}
}
});
var insearch = products.$create("insearch", {
renderUnit: function(hookId) {
var rt = this.$root,
b = rt.browser,
ut = rt.utils,
dm = ut.dom,
dms = dm.style,
st = rt.settings,
stsr = this.settings,
data = rt.helpers.getHookData(hookId),
instance = stsr.instance,
hdrCls = "IL_SR_BG",
srPos = "",
srIEStyle = {},
hdrCss, btnCss, skinPath = this.getSkinPath(),
sentence, content, tpl, html, nodeStyle, so = window.orientation,
ibh = instance.behavior,
hook = st.hooksMap[hookId],
themeColor;
var ad = data.ads[0];
rt.helpers.setActualTemplate(ad);
if (ad.template == "text") {
var textLength = (ad.thumbURL && ad.thumbURL != "no-image") ? 145 : 180;
var pos = ad.displayedURL.indexOf("/");
if (pos != -1) {
ad.displayedURL = ad.displayedURL.substr(0, pos)
}
ad.title = ut.string.truncateToChar(ad.title, 52, " ", "...");
ad.text = ut.string.truncateToChar(ad.text, textLength, " ", "...");
ad.thumbURL = (ad.thumbURL != "no-image") ? ad.thumbURL : false
}
if (ad.contentUrl) {
content = rt.bubble.templates.external(hook, 0)
} else {
content = rt.helpers.parseTokens(hook)
}
if (b.IE && b.getVersion(true) < 8) {
hdrCss = skinPath + "hdr-btns.png";
btnCss = skinPath + "btn.png"
} else {
hdrCss = "data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAB4AAAAeCAYAAAA7MK6iAAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAAB+hJREFUeNrEV3tMm9cVP7Y/29gY/MBvg3klgFJGAnFeBUpok03NOhJeaVcSdVvGEu2fbdqmNm23bkmqRk1bbVm0PiKtTaVtSkLTh9SQlLY0CWSDpkugy8MmCY+AwRiwzbDBYJudc+FzP0e0+W+70pG/ex733Hvuub9zLPr9/gPAj/n5edDr9TA2NmbG6fJF9i3kuZEHIpEorvvbZ59hv7y9WCyGWCwGJpMJPB5PBrKykWJITp1O652Y8DE9fg0OEscGpIOl999fbjQaUEMEXq8Xbjid7ch/Guk8fPP4DtKBB8rLHXp9Gm5knjYRc7qcnyD/KaR/8YpCx3vWrllzZN26tRIJ7p4fmfYMKCkuLv380qXWf3Z0/AxZR77G6TMPlJftL161SiSMTFamXby6pGRz+8WLFZevXPkRsv4qdFyBix9ZuXKlZGYmzBh+v5+FXqvVsnlhYaE4Eo0cvnTpCydOW+5yWrdhw/oD+fkFEJqeWXJXDodDFolE/vLvq1ev08m55ORkkMvkLxcUFEimF40+bvkYOjo62HdJSQk8vOVh9p2fly/q6+v/QzAYvE+wpsRisbycnZUDZD/q8YA8SQ5qtYYJMdSQtDgvLPyWrH9g4EWplNtEMc2z2qyrZ2dnIRyewcTyQmdnJzz51K9h794nobu7G0ZGRpgsHA6D1WpdgTZFvFeZTFaabrPZF+Qz4Ha74bXXXofhYTc4nTfg6BtHYXJykskikTmyfxDNzFw0EimkU/Mhlkg42LZtKwSD00CbofuibOXlqmQV8Urws3vBsdQhtF+etxzm5ubg2Ftvo6MI7NjRwE7Ly1FX1NMTyOPkSUkKUiAn/DAYjeByuqC19VNYsWIFyOXyuBzvGRQKhSoeZwknj0SicTn9yBVJbJ6UlASRWJRFih9R1MWDiLg0ne5OIDAJKSkpCckQDE1BUVERONY4YCb8VcIEAgFIVipd/BxP0OsP+EEqk7I5hfps81loaHic8ABOHj8J1TXVkJK6sH4Aw45ZPinChy1veueUJzc3Vy10HJ5ZcIYRSdjQzVs3p6q3VlkMBsMUzZ0ul+n8hbaB3JxcGXM8NIQRM4AMo8ThtY16RhAOxOx1zKP89q2b7sYf78qg5Aqr1al/HB4exjBG4xSbj7GwCnkjuAjqvoo2U4K9eJRKxTEvno50bOnpIEaHc3MRmMbNa7Q6JC2TDQ4OEjK+RIgmordKBzt+sukTVC4lyFxqjI+PI6bGOhoe/34lTqd5/sxCZNRo34a5UKjRaJe0p2elUinP1lZXf5eumnfMEvZ085lXh9zuBsw3kVKpBAKgUCjEFjebTccf2bJlN12TcMFFx5Tp+rMftbzpGR19hGwVCiUCUAxfRwgTLRyzZ6Qf/fbmzT8nk7shk8K389H6ukNd3d31Pp+/gJho4EIYbDp34cLle+D0GNL36mtr1l3p6qqZnPxPLpaOWG5O1tXiVcXH29rbbgiVhSf+nw4x/J8Gt+/A8wn1eHEzhEz5FBF6MUhfUCbyNZfGc795NqEecxzHkIowBWkt0jJKIqRrSF20/DfV49qUlNRDaWm6bEoQGqHQNExMjPcj3u7F6d/vcZBdGo1mn1arsyoQvegcWFDI3jk1NfULlDcvVY9/l5WV9ZzRaEpYSaVKAaPRmInF4299fX1UHPYu4ZCO8edly5bv0el0CQJCRLPZnI848eGdOwO/QtYrwjveSk7NZgtrYYgI7sa8Y/E5bSg7O5u6iMeWcLwbkW8PYQCvfzfZbDaR3W4n8KhkJ0bAB6lU9qLVaouvcrG9HaFulBmkYQtTWlbG+LSx8fGJF/x+34nFfoqBT1qafr9eb2ATQkCZVMbsaAwhWimxehFkpqdniHw+30EspevoxEWIu3lSTA6iWawkg3cG4Qc/fAJ27twBHqzFM9Mh4OXYi2WhoYPfJKJVhclk1PPyZKUCmk+fhglEut7bt+H8ufNYSpOZTCaVgj5NT4mXyeHl5KtTU+PVRSvTwqOP1cMs1lRKDCpvKrwnXq7B2orO6K47aS6VSldiQsXlVpsNtm+vgxMnmjDTJdDYuCseGnbnWKX6B/qzOKwiHMd2I4sL1WotuFwuONN8BjZteghSMMF4oCFddBxXxrlEykkT7Cd8fqzTEpZz3rFxwNYIBPpMJraYzX2hUJAVeyHRm9y4cSOsdjiovYnzg6ir0aivfZW1KmdQYN/X18t6tp/sboR6PPmpd06xGs7LQxhF7GbHCDIlb751bKi0tNQkbEspuQgszBZzAsBgm+rbVlVl0Wo1rK3o7x/QII67N6xfr6B5b28vqFPVoEvTMbCg+sxhRKhGx6IxaP9H+217hj2XkiuKz+BgT08PKLDo84QlDFiVEfBoUa1Gc4hquODa/Cg7TLWWdKhVstms7DsJT5iTkwP2TDubX8fmz2K27KeejC8S4nffe78J25hqbEsS/qrwJ73cdYV67Q/qampqFqFQOOQnTjY149+XysLC+/BmE+0pch2fd0I0Gn0b8+GJu6sT99m5c/uwk/glprwMn8hCAR8dBe+odxb/kvzpwcpK+hsz+zVwqfyopeUlfyDQaDaZOYNBzxyOYAMwMT4xjfX8+fKyshf49y+ETEL4p+traw9fvXatyu0ezqONWSzmm5UVFe9/2trqvgdOh5B+ur2u7mD3l19WDQ25cygyGRnp1x+qrPzgQlvbmFD5vwIMAAZsT2nNzBrxAAAAAElFTkSuQmCC";
btnCss = "data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAF0AAABICAYAAACUavnrAAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAAA4JJREFUeNrsnL9u01AUxs+xbxOS1LQVBQkGJBgQMPUNGCshMiB1zgqoOwMViBfoxMYGqjqwMIBgYqC8AQsStAyVaAmllDZN4j+xL/fGdsgD9J4I8X1SFDvZfv70+dxzj60eP3119vXGx9V6rXLzdP2U0gSdtNh8umEct/ePXn7ebt9nutZ6dvHyhdZsUKcsA3JX8n2mvV/HtLN38ET5Qb1prgJ1+xHIuHS7sXuSZvagqcy5l//IIOMYOudB4ivSpG2seGDuVgZ4kd5a2TOtNSHO3d9MM51DHlYrWZYRjC5gdp3l0K3t7QWA0SWgF06nwumQ80inEvMwXlINn0soG3e6xl1UyO3j8QKnyzrdhvsgRaaLBfsoXuB0UXlAAOiADgE6oEOA/s9B94FBVL6p03mLmBfAQmqBpDcVZ/EKJ701s0CaAxHHseJxW081HilD/c1sw1vu9JMl4/qGbREAz8nzZtKdoF5Z/51kGyqhynxXBYtXrp+7MV2rKrQETl52U7obJtGX7fbPOI7e2UxfNb+3dvcO0YNxCt5uiOq75iBR7FEzihMKowRkBBxvZOde2GNDHmMvAtDNJ6XUloykAVy2aFTlFYDkpP6GPCSSLyV0DzN1MrlScFcMp8tSHzkd0OWYs4XOebxgWSRBvRjBGMaLgc6gLpQubOOFTbyYxRG2MwSMXk54FfGCWBdLlzxefEOcUTYKOt3Gi4/ei6jT82hntALkynRMA0xCgA7o/w90zL3Iylea9JapFxfQCnCr4WPq8cAebqo0Dh909neeK6XmCRvTTqn3++Gu1pWHitL47XHv6B771dvmn4Aw9+IoxvWhTsMXVJ35oGiqMR/MnLl19dL5xelaBe97cWJytm8ZiT993e12euF7uzhaNaBb334c5I/cgbob8Pk98445ipU5afbjhHphDDIC4M3SP597sQ0v7aMR4Bw62bkXKude0HsRlMYIhiTt4luVhTskFzFw+gSsnm9MI9FFrZ47Hb1GWadb8ogXWeqj7TpILl+KWUagkBRKxslA5+Gd1EOjSyDRxzLdQwUzieoFETOBTEf9Ig+dMEAqCr18/AXQ3cc5jznd57wBg4hxuiQa7fj7SmvaYs/OvaB8cQ3dzr2YsnFTZYNopXfwfc1An8OutFtFcdJmXbXve0nfVDlZPu4NlgxyvO/FjTyPdSeoVdbTRG/8EWAAta8y0OqpUAcAAAAASUVORK5CYII="
}
dms.addRule("." + hdrCls, ['background-image : url("', hdrCss, '")'].join(""));
dms.addRule("#IL_SR_BTN", ['background-image : url("', btnCss, '")'].join(""));
instance.height = ibh.heightClose;
if (ad.template == "text") {
instance.fullWidth = 722
} else {
instance.fullWidth = data.width > 0 ? data.width : 722;
ibh.heightOpen = (data.height > 0 ? data.height : 90) + 55
}
instance.left = Math.ceil((dm.viewport.getWidth() - instance.fullWidth) / 2);
if (stsr.prodCode == "o") {
sentence = data.sentence
} else {
sentence = st.impression.params.refq
}
sentence = ut.string.truncateToChar(sentence, 38, " ", "...").replace(/</g, "<");
if (stsr.oldIE) {
srPos = "absolute";
srIEStyle = {
top: (dm.viewport.getHeight() + dm.document.getScrollTop() - ibh.heightClose) + "px"
}
} else {
srPos = "fixed"
}
themeColor = stsr.themes.color[ibh.theme];
tpl = '<% if (oldIE || oldFF){ %> <img src="<%= skinPath %>in-search-shadow.png" alt="" width="<%= instance.fullWidth+20 %>" height="<%= ibh.heightOpen+10 %>" style="position:absolute; top:-10px; left:-10px; width:<%= instance.fullWidth+20 %>px; height=<%= ibh.heightOpen+10 %>px; overflow:hidden;" /> <% } %> <%-- Header --%> <div class="<%= baseCls %>" style="position:absolute; top:0; left:0; width:<%= instance.fullWidth %>px; <%= titleBase %>; cursor: pointer;"> <% if (ibh.favicon){ %><div class="<%= baseCls %>" style="position:absolute; left:15px; width:16px; height:16px; top:12px; background:url(<%= ibh.favicon %>) no-repeat scroll 0 0 transparent;"></div><% } %> <div class="<%= baseCls %>" style="position:absolute; width:<%= instance.fullWidth - 181 %>px; height:24px; left:<%= ibh.favicon ? 35 : 15 %>px; top:10px; color:<%= ibh.titlePrefixColor %>; font-family: Trebuchet MS,Arial,sans-serif; font-size:15pt; font-weight:normal; font-style:normal;"><%= titlePrefix %> <span class="<%= baseCls %>" style="color:<%= ibh.titleTermColor %>; font-weight: bold; font-size:15pt;"><%= sentence %></span>?</div> <div id="IL_SR_LOGO" class="<%= baseCls %>" style="position:absolute; top:10px; right:47px; width:48px; height:11px; cursor:pointer; font-size:1px; <% if (oldIE || oldFF){ %>background:url(<%= skinPath %>logo11.png) no-repeat scroll 0 0 transparent;<% } %>"> <% if (!(oldIE || oldFF)){ %> <svg version="1.1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" x="0px" y="0px" width="48px" height="11px" viewBox="0 0 636 144" enable-background="new 0 0 636 144" xml:space="preserve"> <g> <%-- dot (first) --%> <path id="IL_SR_LOGO_DOT1" fill="<%= ibh.theme == \'def\' ? \'#208CE5\' : themeColor %>" d="M16.918,24.865c5.848,0,10.57-4.735,10.57-10.583s-4.722-10.57-10.57-10.57 S6.334,8.434,6.334,14.282S11.07,24.865,16.918,24.865"/> <%-- in --%> <path fill="#003366" d="M88.085,43.784H77.024c-17.149,0-31.181,14.031-31.181,31.182v34.796 c0,0.218,0.016,0.415,0.027,0.618v5.185c0,5.71-4.672,10.382-10.382,10.382h-0.467c-5.71,0-10.382-4.672-10.382-10.382V92.608 h0.015V45.889v-0.025c0-1.124-0.885-2.033-2.01-2.08h-11.49c-1.09,0.047-1.949,0.907-1.986,1.996v46.828h0.04 c-0.015,0.355-0.04,0.707-0.04,1.066v22.246c0,14.031,11.479,25.512,25.511,25.512h1.151c14.031,0,25.511-11.48,25.511-25.512 v-5.466v-4.62v-28.89c0.082-9.872,8.159-17.948,18.031-17.948h6.366c9.871,0,17.948,8.076,18.042,17.948v28.89v4.62v28.873 c0.013,0.023,0.013,0.034,0.013,0.048c0,1.111,0.883,2.008,1.983,2.057h11.505c1.077-0.036,1.936-0.887,1.985-1.973v-27.966v-5.659 V74.966C119.267,57.815,105.234,43.784,88.085,43.784"/> <%-- f (part) --%> <path fill="#003366" d="M155.069,56.972v82.643c-0.072,0.992-0.886,1.78-1.903,1.818h-11.014 c-1.062-0.038-1.912-0.897-1.912-1.962c0-0.024,0-0.048-0.023-0.073V34.456c0.716-17.064,14.923-30.744,32.179-30.744h8.536 c0.025,0,0.038,0.011,0.06,0.011c1.053,0,1.915,0.849,1.974,1.901v11.037c-0.035,1.016-0.85,1.844-1.878,1.889h-8.692 c-9.509,0-17.327,7.75-17.327,17.268v6.301V56.972z"/> <%-- f (part) --%> <path fill="#003366" d="M151.99,59.104h28.873c0.023-0.012,0.034-0.012,0.047-0.012 c1.111,0,2.008-0.884,2.057-1.984V45.604c-0.036-1.078-0.887-1.938-1.973-1.986h-27.965"/> <%-- o --%> <path fill="#003366" d="M276.24,107.925h0.158V76.608c-0.37-18.164-15.248-32.825-33.494-32.825 h-16.756v0.022c-17.875,0.431-32.322,14.924-32.679,32.803h-0.026v31.316c0,18.213,14.601,33.064,32.705,33.496v0.012h16.589h0.021 h0.146C261.304,141.349,276.24,126.354,276.24,107.925 M208.93,107.925L208.93,107.925V77.289c0-9.914,8.096-18.02,18.021-18.02 h15.953c9.946,0,18.02,8.106,18.02,18.02v30.636h-0.167c0,9.949-8.074,18.021-17.999,18.021h-15.807 C217.026,125.946,208.93,117.874,208.93,107.925"/> <%-- l --%> <path fill="#003366" d="M312.844,139.376L312.844,139.376c0,1.064-0.798,1.938-1.829,2.045h-11.816 c-1.027-0.107-1.837-0.98-1.837-2.045h-0.013V5.769h0.013c0-1.135,0.908-2.033,2.031-2.057h11.432 c1.124,0.024,2.019,0.922,2.019,2.057V139.376z"/> <%-- dot (second) --%> <path id="IL_SR_LOGO_DOT2" fill="<%= ibh.theme == \'def\' ? \'#208CE5\' : themeColor %>" d="M341.662,24.865c5.848,0,10.57-4.735,10.57-10.583s-4.723-10.57-10.57-10.57 s-10.584,4.722-10.584,10.57S335.814,24.865,341.662,24.865"/> <%-- in (second) --%> <path fill="#003366" d="M412.829,43.784h-11.061c-17.149,0-31.181,14.031-31.181,31.182v34.796 c0,0.218,0.016,0.415,0.026,0.618v5.185c0,5.71-4.672,10.382-10.382,10.382h-0.468c-5.71,0-10.382-4.672-10.382-10.382V92.608 h0.016V45.723v-0.025c0-1.123-0.885-2.033-2.01-2.08h-11.49c-1.091,0.047-1.949,0.908-1.986,1.996v46.994h0.04 c-0.015,0.355-0.04,0.707-0.04,1.066v22.246c0,14.031,11.479,25.512,25.512,25.512h1.15c14.031,0,25.512-11.48,25.512-25.512 v-5.466v-4.62v-28.89c0.082-9.872,8.158-17.948,18.029-17.948h6.367c9.871,0,17.947,8.076,18.041,17.948v28.89v4.62v28.873 c0.014,0.023,0.014,0.034,0.014,0.048c0,1.111,0.883,2.008,1.982,2.057h11.506c1.076-0.036,1.936-0.887,1.984-1.973v-27.966v-5.659 V74.966C444.01,57.815,429.979,43.784,412.829,43.784"/> <%-- k --%> <path fill="#003366" d="M480.277,139.376L480.277,139.376V91.735h0.146h9.255l40.656,48.766 c0.599,0.549,1.15,0.906,1.841,0.932h16.073c0.882-0.025,2.869-0.322,1.794-2.056l-0.013-0.024l-47.58-56.777l44.599-36.815 c0.015-0.049,0.015-0.049,0.036-0.073c1.066-1.734-0.886-2.032-1.78-2.069H527.08c-0.621,0.024-1.15,0.324-1.666,0.791 l-36.812,31.075h-8.325V5.769c0-1.135-0.896-2.033-2.02-2.057h-11.422c-1.124,0.024-2.033,0.922-2.033,2.057v133.607 c0,1.064,0.803,1.938,1.844,2.045h11.802C479.476,141.313,480.277,140.44,480.277,139.376"/> <%-- s --%> <path fill="#003366" d="M603.208,84.782H577.99c-6.91-0.114-12.508-5.785-12.508-12.783 c0-6.996,5.598-12.895,12.508-12.895h39.271c1.146,0,2.08-0.959,2.08-2.111v0.191V45.752v-0.037c0-1.164-0.935-2.097-2.08-2.097 H577.99c-15.451,0-28.008,12.73-28.008,28.381c0,15.651,12.557,28.381,28.008,28.27h24.252c6.911,0.111,12.508,5.812,12.508,12.795 c0,6.996-5.597,12.896-12.508,12.896H591.56l0.001-0.014h-28.874c-0.022,0.014-0.034,0.014-0.047,0.014 c-1.11,0-2.007,0.896-2.056,2.01v11.449c0.035,1.092,0.886,1.963,1.973,2.014h0.225h27.74h12.224 c15.209-0.279,27.491-12.9,27.491-28.369C630.236,97.737,618.191,85.202,603.208,84.782"/> </g> </svg> <% } %> </div> <div class="<%= baseCls %> <%= hdrCls %>" id="IL_SR_HELP" style="position:absolute; right:26px; top:9px; width:15px; height:15px; background-position:0 0; cursor:pointer; font-size:1px;"></div> <div class="<%= baseCls %> <%= hdrCls %>" id="IL_SR_X" style="position:absolute; right:10px; top:9px; width:15px; height:15px; background-position:-15px 0; cursor:pointer; font-size:1px;"></div> </div> <%-- Body --%> <div id="IL_SR_AD_AREA" class="<%= baseCls %>" style="position:absolute; top:55px; left:0; width:<%= instance.fullWidth %>px; height:<%= ad.template == \'text\' ? 125 : data.height %>px; background-color:#ffffff; cursor: pointer;"> <% if (ad.template == \'text\'){ %> <% if (ibh.thumb && ad.thumbURL){ %> <div class="<%= baseCls %>" style="margin-left:15px; float:left; width:110px; background-color:#e8e8e8; -moz-box-shadow:2px 2px 5px #888; -webkit-box-shadow:2px 2px 5px #888; box-shadow:2px 2px 5px #888;"> <img class="<%= baseCls %>" src="<%= ad.thumbURL %>" width="110" height="82"> </div> <% } %> <div class="<%= baseCls %>" style="width:<%= instance.fullWidth - (ibh.thumb && ad.thumbURL ? 307 : 182) %>px; float:left; margin-left:30px;"> <div class="<%= baseCls %>" style="color:#1122CC; font-family:Trebuchet MS,Arial,sans-serif; font-size:12pt; font-weight:normal; text-decoration:none;"><%= ad.title %></div> <div class="<%= baseCls %>" style="color:#222222; font-family:Trebuchet MS,Arial,sans-serif; font-size:10pt; font-weight:normal; padding-top:4px;"><%= ad.text %></div> <div class="<%= baseCls %>" style="color:#009933; font-family:Trebuchet MS,Arial,sans-serif; font-size:10pt; font-weight:normal; padding-top:4px; overflow:hidden;"><%= ad.displayedURL %></div> </div> <div id="IL_SR_BTN" class="<%= baseCls %>" style="position:absolute; right:24px; font-family:Trebuchet MS,Arial,sans-serif; font-size:10pt; font-weight:bold; cursor:pointer; text-align:center; width:93px; height:24px; top:59px; line-height:24px; color:#ffffff;"><%= btnText %></div> <% } else { %> <% if (ad.actualTemplate == "iframe"){ %> <iframe name="IL_SR_FRAME" class="<%= baseCls %>" src="<%= st.blankURL %>" width="<%= data.width %>" height="<%= data.height %>" frameborder="0" scrolling="no"></iframe> <%= rt.helpers.getEchoForm(content, "IL_SR_FRAME", "IL_SR_FORM") %> <% } else { %> <%= content %> <% } %> <% } %> </div>';
html = ut.VeST(tpl, {
rt: rt,
st: st,
baseCls: st.baseClass,
hdrCls: hdrCls,
ibh: ibh,
instance: instance,
data: data,
ad: ad,
content: content,
sentence: sentence,
skinPath: skinPath,
oldIE: stsr.oldIE,
oldFF: b.Firefox && b.getVersion(true) < 4,
themeColor: themeColor,
titleBase: stsr.themes.tb[ibh.tb],
titlePrefix: rt.helpers.translate(data.tp || ibh.tp),
btnText: rt.helpers.translate(data.bt || ibh.bt)
});
var boxShadow = "0 2px 6px 2px rgba(0, 0, 0, 0.5)";
nodeStyle = ut.object.extend({
position: srPos,
bottom: 0,
zIndex: st.baseZIndex,
width: instance.fullWidth + "px",
height: instance.height + "px",
left: instance.left + "px",
borderTop: "2px solid " + themeColor,
borderLeft: "1px solid #a7a9ab",
borderRight: "1px solid #a7a9ab",
boxShadow: boxShadow,
MozBoxShadow: boxShadow,
WebkitBoxShadow: boxShadow,
oBoxShadow: boxShadow,
msBoxShadow: boxShadow
}, (stsr.oldIE || (b.Firefox && b.getVersion(true) < 4)) ? {} : {
overflow: "hidden"
}, srIEStyle);
dm.element.setStyle(hook.node, nodeStyle);
hook.node.innerHTML = html;
if (ad.actualTemplate == "iframe") {
var form = dm.element.$("IL_SR_FORM");
if (form) {
form.submit()
}
}
},
getSkinPath: function() {
var stsr = this.settings;
return ["http:/", this.$root.settings.hosts.resources, "static", "skins", stsr.skin, stsr.prodName, stsr.rv, ""].join("/")
},
setEventHandlers: function(hook) {
var rt = this.$root,
b = rt.browser,
st = rt.settings,
ut = rt.utils,
node = hook.node,
stsr = this.settings,
dm = ut.dom,
dmel = dm.element,
evdm = rt.event.dom,
sr = this,
ns = "IL_SR_",
xBtn = dmel.$(ns + "X"),
helpBtn = dmel.$(ns + "HELP"),
clickBtn = dmel.$(ns + "BTN"),
srLogo = dmel.$(ns + "LOGO"),
adArea = dmel.$("AD_AREA"),
data = rt.helpers.getHookData(hook.id),
ad = data.ads[0];
if (b.IE) {
stsr.initialBannerShowTime = 20
}
this.closeBanner(stsr.initialBannerShowTime);
evdm.bind(window, {
event: "resize",
listener: function() {
var left = Math.ceil((dm.viewport.getWidth() / 2) - (parseInt(node.style.width) / 2));
stsr.instance.left = left;
node.style.left = left + "px"
}
});
if (stsr.oldIE) {
evdm.bind(window, {
event: "scroll",
listener: this.updateTopPosition
});
evdm.bind(window, {
event: "resize",
listener: this.updateTopPosition
})
}
evdm.bind(window, {
event: "scroll",
listener: this.scrollHandler
});
if (xBtn) {
evdm.bind(xBtn, {
event: "click",
listener: function(event) {
rt.utils.dom.event.stop(event.domEvent);
rt.event.stop("SRAnimateUp");
rt.event.disable("SRAnimateUp");
rt.event.stop("SRAnimateDown");
rt.event.disable("SRAnimateDown");
rt.event.dom.unbind(window, "scroll", sr.scrollHandler);
node.parentNode.removeChild(node)
}
});
evdm.bind(xBtn, {
event: "mouseover",
data: {
el: xBtn,
pos: "-15px -15px"
},
listener: this.setBackgroundPosition
});
evdm.bind(xBtn, {
event: "mouseout",
data: {
el: xBtn,
pos: "-15px 0"
},
listener: this.setBackgroundPosition
})
}
if (srLogo) {
evdm.bind(srLogo, {
event: "click",
listener: function(event) {
rt.utils.dom.event.stop(event.domEvent);
if (st.homeUrl) {
window.open(st.homeUrl, "_blank")
}
}
})
}
if (clickBtn) {
evdm.bind(clickBtn, {
event: "mouseover",
data: {
el: clickBtn
},
listener: function(event) {
event.data.el.style.backgroundPosition = "0 -24px"
}
});
evdm.bind(clickBtn, {
event: "mouseout",
data: {
el: clickBtn
},
listener: function(event) {
event.data.el.style.backgroundPosition = "0 0"
}
})
}
if (helpBtn) {
evdm.bind(helpBtn, {
event: "click",
listener: function(event) {
rt.utils.dom.event.stop(event.domEvent);
if (st.helpUrl) {
window.open(st.helpUrl, "_blank")
}
}
});
evdm.bind(helpBtn, {
event: "mouseover",
data: {
el: helpBtn,
pos: "0 -15px"
},
listener: this.setBackgroundPosition
});
evdm.bind(helpBtn, {
event: "mouseout",
data: {
el: helpBtn,
pos: "0 0"
},
listener: this.setBackgroundPosition
})
}
evdm.bind(node, {
event: "click",
listener: function(event) {
if (ad.template != "text" && adArea && dmel.inHierarchy(event.element, adArea) && ad.content && ad.content.match(/<object |<embed /i) && ad.content.match(/clicktag/i)) {
return
}
if (ad.template == "external") {
return
}
rt.event.stop("SRAnimateUp");
rt.event.disable("SRAnimateUp");
rt.event.stop("SRAnimateDown");
rt.event.disable("SRAnimateDown");
rt.event.dom.unbind(window, "scroll", sr.scrollHandler);
var cx = event.domEvent.layerX || event.domEvent.offsetX;
var cy = event.domEvent.layerY || event.domEvent.offsetY;
var target = event.domEvent.target || event.domEvent.srcElement;
if (target != event.element) {
var offset = rt.utils.dom.element.offset(target, event.element);
cx += offset.left;
cy += offset.top
}
rt.event.fire("sendErrorReport", {
ua: rt.browser.getValue(),
rt: rt.comm.settings.responses.gsd.rs,
cx: cx,
cy: cy,
an: stsr.animating.up,
tm: rt.utils.timer.delta("inSearchAnimateUp"),
cbdata: {
evt: "insearchClick",
data: hook.id
}
});
var parent = node.parentNode;
parent.removeChild(node)
}
});
evdm.bind(node, {
event: "mouseenter",
listener: function() {
stsr.animating.mouseover = true;
stsr.animating.mouseout = false;
if (!stsr.animating.up) {
rt.event.repeat("SRAnimateUp", stsr.animationInterval)
}
}
});
evdm.bind(node, {
event: "mouseleave",
listener: function() {
stsr.animating.mouseover = false;
stsr.animating.mouseout = true;
sr.closeBanner(stsr.oldIE ? 5 : 2)
}
})
},
setBackgroundPosition: function(event) {
event.data.el.style.backgroundPosition = event.data.pos
},
updateTopPosition: function() {
var rt = window[appNamespace],
dm = rt.utils.dom,
stsr = rt.products.insearch.settings,
node = stsr.instance.hook.node;
var currentHeight = parseInt(rt.utils.dom.element.getStyle(node, "height"));
node.style.top = (dm.viewport.getHeight() + dm.document.getScrollTop() - currentHeight) + "px"
},
scrollHandler: function() {
var rt = this.$root,
dm = rt.utils.dom,
docHeight = dm.document.getHeight(),
currentScroll = dm.document.getScrollTop() + dm.viewport.getHeight(),
stsr = this.settings;
if (currentScroll == 0) {
currentScroll = window.pageYOffset || (document.body.parentElement ? document.body.parentElement.scrollTop : 0)
}
if (docHeight <= currentScroll) {
if (stsr.state == "open") {
return
}
this.closeBanner(stsr.oldIE ? 5 : 4);
if (!stsr.animating.up) {
rt.event.repeat("SRAnimateUp", stsr.animationInterval)
}
}
},
closeBanner: function(delay) {
this.$root.event.repeat("SRAnimateDown", this.settings.animationInterval, null, delay * 1000)
}
}, {
settings: {
prodId: "IL_INSEARCH",
prodCode: "s",
prodName: "insearch",
instance: null,
sentences: {},
oldIE: (function() {
var b = $root.browser;
return (b.IE && (document.compatMode == "BackCompat" || b.getVersion(true) < 9))
}()),
animationInterval: $root.browser.IE ? 7 : 10,
initialBannerShowTime: 15,
skin: "brand",
theme: "def",
rv: "1",
bannerTimeoutClose: null,
state: "closed",
animating: {
down: false,
up: false,
mouseover: false,
mouseout: false
},
behavior: {
def: {
heightOpen: 155,
heightClose: 55,
tb: "white",
theme: "def",
tp: "searchingFor",
bt: "clickHere",
thumb: false,
favicon: false,
titlePrefixColor: "#4E4E4E",
titleTermColor: "#4E4E4E"
}
},
themes: {
color: {
def: "#003366",
lightBlue: "#1b8ede",
green: "#67b045",
orange: "#f3933b",
red: "#dd3c42",
pink: "#d84189",
purple: "#5939aa"
},
tb: {
gray: "height:55px; background-color:#F1F1F2;",
white: "height:55px; background-color:#FFFFFF;",
grayLine: "height:53px; border-bottom:2px solid #F1F1F2; background-color:#FFFFFF;"
}
}
}
}, true);
insearch.bind({
event: "renderProduct",
listener: {
renderInsearch: function() {
var rt = this.$root,
imp = rt.comm.settings.responses.impression,
srst = this.settings,
prodCode;
if (imp.prs["s"]) {
delete imp.prs["o"];
delete rt.settings.productRenderStatus["o"];
prodCode = srst.prodCode
} else {
if (imp.prs["o"]) {
prodCode = srst.prodCode = "o";
delete rt.settings.productRenderStatus["s"]
}
}
var prod = imp.prs[prodCode];
if (!prod || !prod.sentences || !prod.sentences.length) {
rt.event.fire("productRenderStatus", {
prod: "s",
status: "none"
});
rt.event.fire("productRenderStatus", {
prod: "o",
status: "none"
});
return
}
rt.event.fire("productRenderStatus", {
prod: prodCode,
status: "during"
});
rt.event.fire("initInsearch")
}
}
});
insearch.bind({
event: "initInsearch",
listener: {
init: function() {
var rt = this.$root,
ut = rt.utils,
stsr = this.settings,
instance, resImp = rt.comm.settings.responses.impression,
bh = rt.settings.behavior,
senteceIndex = resImp.prs[stsr.prodCode].sentences[0],
bhsr = stsr.behavior,
getadsDelay = 0;
bhsr.impression = rt.helpers.renameBehaviorProperties(resImp.prs[stsr.prodCode].behavior || {});
instance = stsr.instance = {
behavior: rt.helpers.sanitize(ut.object.extend({}, bh.def, bhsr.def, bh.impression, bhsr.impression, bh.customer), bh.sanitizer),
sentence: ut.object.keys(resImp.sentences)[senteceIndex],
node: ut.dom.createDOMFragment({
tag: "div",
id: stsr.prodId,
cls: rt.settings.baseClass,
parent: document.body
})
};
var hook = instance.hook = rt.helpers.createHook(stsr.prodId, instance.sentence, instance.node, 0, this, stsr.prodCode, stsr.prodName, false, instance);
rt.event.fire("getAds", {
hookId: hook.id,
callback: "getadsResponseInsearch"
}, getadsDelay)
}
}
});
insearch.bind({
event: "getadsResponseInsearch",
listener: {
setAdData: function(event) {
var rt = this.$root,
st = rt.settings,
data = event.data,
hookId = data.lid,
hook = st.hooksMap[hookId],
ad;
if (!hook) {
rt.logger.error("Error: Misssing hook.", this.setAdData);
return false
}
ad = data.ads[hook.currentAdIndex];
if (ad && ad.template == "external") {
data = rt.externalTags.setExternalTagData(hook, data)
}
if (data.ads.length) {
ad = data.ads[0];
rt.helpers.setAdThumbnail(ad);
if (ad.trackerURL) {
rt.helpers.hitTrackerURL(ad.trackerURL)
}
}
rt.helpers.setHookData(hookId, data);
if (hook.externalTag) {
rt.externalTags.updateViewedTags(hook.id)
}
rt.event.fire("createInsearchUnit", {
hookId: hookId
})
}
}
});
insearch.bind({
event: "createInsearchUnit",
listener: {
createInsearchUnit: function(event) {
var rt = this.$root,
st = rt.settings,
hookId = event.data.hookId,
hook = st.hooksMap[hookId],
msg = "",
stsr = this.settings,
data = rt.helpers.getHookData(hookId);
if (!data.ads.length) {
msg = "received no ad."
}
if (msg) {
rt.event.fire("productRenderStatus", {
prod: stsr.prodCode,
status: "failed",
reason: msg
});
return
}
this.renderUnit(hookId);
this.setEventHandlers(hook);
rt.event.repeat("SRAnimateUp", stsr.animationInterval);
rt.event.fire("productRenderStatus", {
prod: stsr.prodCode,
status: "after"
})
}
}
});
insearch.bind({
event: "insearchClick",
listener: {
insearchClick: function(event) {
var rt = this.$root,
hookId = event.data;
rt.utils.timer.stop("adView" + hookId);
var reuseWindow = rt.helpers.getHookBehavior(hookId).adsReuseWindow;
if (!reuseWindow) {
try {
rt.settings.adWin = window.open("", hookId)
} catch (ex) {
rt.settings.adWin = null;
rt.logger.error("insearch click: Unable to open new window", this.insearchClick)
}
}
rt.event.fire("productClick", {
hookId: hookId,
clickType: "onWin"
})
}
}
});
insearch.bind({
event: "SRAnimateUp",
listener: {
animateUp: function() {
var rt = this.$root,
stsr = this.settings,
ut = rt.utils,
dmel = ut.dom.element,
hook = stsr.instance.hook,
node = hook.node,
anim = stsr.animating,
b = rt.browser;
var heightOpen = stsr.instance.behavior.heightOpen;
if (stsr.state == "open") {
rt.event.stop("SRAnimateUp");
return
}
var currentHeight = parseInt(dmel.getStyle(node, "height"));
if (currentHeight >= heightOpen) {
rt.event.stop("SRAnimateUp");
rt.utils.timer.stop("inSearchAnimateUp");
rt.utils.timer.start("adView" + hook.id);
stsr.state = "open";
anim.up = false;
rt.utils.cookie.remove("refc");
if (stsr.oldIE) {
this.updateTopPosition()
}
var data = rt.helpers.getHookData(hook.id);
rt.event.fire("sendAdView", {
hookId: hook.id,
params: {
bdc: hook.bdc,
prod_t: hook.prod,
emd: data.ads[hook.currentAdIndex].emd || ""
}
});
return
}
if (!anim.up) {
anim.up = true;
stsr.state = "animating";
rt.utils.timer.start("inSearchAnimateUp")
}
var newHeight, newTop, step, utd = ut.dom.document,
vpHeight = ut.dom.viewport.getHeight(),
docScroll = utd.getScrollTop();
newTop = vpHeight + docScroll - currentHeight;
if (b.IE && b.getVersion(true) > 6) {
step = 3;
if (b.getVersion() >= 9) {
newTop = false
}
} else {
if (stsr.oldIE) {
step = null;
newHeight = heightOpen;
newTop = vpHeight + docScroll - heightOpen
} else {
step = 2;
newTop = false
}
}
if (step) {
newHeight = Math.min(currentHeight + step, heightOpen)
}
if (newTop) {
dmel.setStyle(node, {
top: newTop + "px"
})
}
dmel.setStyle(node, {
height: newHeight + "px"
})
}
}
});
insearch.bind({
event: "SRAnimateDown",
listener: {
animateDown: function() {
var rt = this.$root,
dmel = rt.utils.dom.element,
stsr = this.settings,
hook = stsr.instance.hook,
node = hook.node,
anim = stsr.animating,
b = rt.browser;
var heightClose = stsr.instance.behavior.heightClose;
if (stsr.state == "closed") {
rt.event.stop("SRAnimateDown");
return
}
var currentHeight = parseInt(dmel.getStyle(node, "height"));
if (currentHeight <= heightClose || anim.up || anim.mouseover) {
anim.down = false;
rt.event.stop("SRAnimateDown");
stsr.state = currentHeight <= heightClose ? "closed" : "animating";
rt.utils.timer.clear("adView" + hook.id);
return
}
if (!anim.down) {
anim.down = true;
stsr.state = "animating"
}
var dm = rt.utils.dom,
vpHeight = dm.viewport.getHeight(),
docScroll = dm.document.getScrollTop(),
newHeight, currentTop = parseInt(dmel.getStyle(node, "top")),
step = 1,
newTop;
if (!stsr.oldIE) {
newTop = false
} else {
if (b.IE && b.getVersion(true) > 6 && b.getVersion(true) < 9) {
step = 2;
newTop = currentTop + step
} else {
if (stsr.oldIE) {
step = false;
newHeight = heightClose;
newTop = vpHeight + docScroll - heightClose
}
}
}
if (step) {
newHeight = Math.max(currentHeight - step, heightClose)
}
dmel.setStyle(node, {
height: newHeight + "px"
});
if (newTop) {
dmel.setStyle(node, {
top: newTop + "px"
})
}
}
}
});
var inframe = products.$create("inframe", {
getPageMargins: function() {
var rt = this.$root,
stif = this.settings,
dm = rt.utils.dom,
wrapper = dm.findWidestNode(),
result = {
left: 0,
right: 0
};
if (wrapper && wrapper.node != document.body) {
var offset = dm.element.offset(wrapper.node);
var width = dm.element.getActualWidth(wrapper.node);
var docWidth = dm.document.getWidth();
result = {
left: offset.left - stif.buffer,
right: docWidth - width - offset.left - 2 * stif.buffer
}
}
return result
},
buildImpPageMarginsParam: function() {
var stif = this.settings,
stifw = stif.width,
margins = stif.margins = this.getPageMargins();
return [margins.left > stifw.thin ? margins.left > stifw.wide ? "w" : "t" : "", margins.right > stifw.thin ? margins.right > stifw.wide ? "w" : "t" : ""].join("*").replace(/^\*$/, "")
},
buildGetadsPageMarginsParam: function(bs) {
var uta = this.$root.utils.array,
stif = this.settings,
instance = stif.instance,
arr = [];
if (/THIN|AUTO/.test(bs)) {
uta.push(arr, stif.width.thin, "*", stif.height)
}
if ((instance.left || instance.right).width >= stif.width.wide && /WIDE|AUTO/.test(bs)) {
uta.push(arr, arr.length ? "~" : "", stif.width.wide, "*", stif.height)
}
return arr.join("")
},
renderUnit: function(side) {
var rt = this.$root,
ut = rt.utils,
dm = ut.dom,
dms = dm.style,
dmel = dm.element,
st = rt.settings,
stif = this.settings,
b = rt.browser,
instance = stif.instance,
html, bh = stif.behavior.merged,
skinPath = this.getSkinPath(),
bgCss, bgCls = "IL_IF_BG",
hook = instance[side].hook,
hookId = hook.id,
data = rt.helpers.getHookData(hookId),
ad, content, node = dmel.$("IL_IF_" + side.toUpperCase());
ad = data.ads[hook.currentAdIndex];
rt.helpers.setActualTemplate(ad);
if (ad.contentUrl) {
content = rt.bubble.templates.external(hook, hook.currentAdIndex)
} else {
content = rt.helpers.parseTokens(hook)
}
if (b.IE && b.getVersion(true) < 8) {
bgCss = skinPath + "hdr-btns.png"
} else {
bgCss = "data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAB4AAAAeCAYAAAA7MK6iAAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAAB+hJREFUeNrEV3tMm9cVP7Y/29gY/MBvg3klgFJGAnFeBUpok03NOhJeaVcSdVvGEu2fbdqmNm23bkmqRk1bbVm0PiKtTaVtSkLTh9SQlLY0CWSDpkugy8MmCY+AwRiwzbDBYJudc+FzP0e0+W+70pG/ex733Hvuub9zLPr9/gPAj/n5edDr9TA2NmbG6fJF9i3kuZEHIpEorvvbZ59hv7y9WCyGWCwGJpMJPB5PBrKykWJITp1O652Y8DE9fg0OEscGpIOl999fbjQaUEMEXq8Xbjid7ch/Guk8fPP4DtKBB8rLHXp9Gm5knjYRc7qcnyD/KaR/8YpCx3vWrllzZN26tRIJ7p4fmfYMKCkuLv380qXWf3Z0/AxZR77G6TMPlJftL161SiSMTFamXby6pGRz+8WLFZevXPkRsv4qdFyBix9ZuXKlZGYmzBh+v5+FXqvVsnlhYaE4Eo0cvnTpCydOW+5yWrdhw/oD+fkFEJqeWXJXDodDFolE/vLvq1ev08m55ORkkMvkLxcUFEimF40+bvkYOjo62HdJSQk8vOVh9p2fly/q6+v/QzAYvE+wpsRisbycnZUDZD/q8YA8SQ5qtYYJMdSQtDgvLPyWrH9g4EWplNtEMc2z2qyrZ2dnIRyewcTyQmdnJzz51K9h794nobu7G0ZGRpgsHA6D1WpdgTZFvFeZTFaabrPZF+Qz4Ha74bXXXofhYTc4nTfg6BtHYXJykskikTmyfxDNzFw0EimkU/Mhlkg42LZtKwSD00CbofuibOXlqmQV8Urws3vBsdQhtF+etxzm5ubg2Ftvo6MI7NjRwE7Ly1FX1NMTyOPkSUkKUiAn/DAYjeByuqC19VNYsWIFyOXyuBzvGRQKhSoeZwknj0SicTn9yBVJbJ6UlASRWJRFih9R1MWDiLg0ne5OIDAJKSkpCckQDE1BUVERONY4YCb8VcIEAgFIVipd/BxP0OsP+EEqk7I5hfps81loaHic8ABOHj8J1TXVkJK6sH4Aw45ZPinChy1veueUJzc3Vy10HJ5ZcIYRSdjQzVs3p6q3VlkMBsMUzZ0ul+n8hbaB3JxcGXM8NIQRM4AMo8ThtY16RhAOxOx1zKP89q2b7sYf78qg5Aqr1al/HB4exjBG4xSbj7GwCnkjuAjqvoo2U4K9eJRKxTEvno50bOnpIEaHc3MRmMbNa7Q6JC2TDQ4OEjK+RIgmordKBzt+sukTVC4lyFxqjI+PI6bGOhoe/34lTqd5/sxCZNRo34a5UKjRaJe0p2elUinP1lZXf5eumnfMEvZ085lXh9zuBsw3kVKpBAKgUCjEFjebTccf2bJlN12TcMFFx5Tp+rMftbzpGR19hGwVCiUCUAxfRwgTLRyzZ6Qf/fbmzT8nk7shk8K389H6ukNd3d31Pp+/gJho4EIYbDp34cLle+D0GNL36mtr1l3p6qqZnPxPLpaOWG5O1tXiVcXH29rbbgiVhSf+nw4x/J8Gt+/A8wn1eHEzhEz5FBF6MUhfUCbyNZfGc795NqEecxzHkIowBWkt0jJKIqRrSF20/DfV49qUlNRDaWm6bEoQGqHQNExMjPcj3u7F6d/vcZBdGo1mn1arsyoQvegcWFDI3jk1NfULlDcvVY9/l5WV9ZzRaEpYSaVKAaPRmInF4299fX1UHPYu4ZCO8edly5bv0el0CQJCRLPZnI848eGdOwO/QtYrwjveSk7NZgtrYYgI7sa8Y/E5bSg7O5u6iMeWcLwbkW8PYQCvfzfZbDaR3W4n8KhkJ0bAB6lU9qLVaouvcrG9HaFulBmkYQtTWlbG+LSx8fGJF/x+34nFfoqBT1qafr9eb2ATQkCZVMbsaAwhWimxehFkpqdniHw+30EspevoxEWIu3lSTA6iWawkg3cG4Qc/fAJ27twBHqzFM9Mh4OXYi2WhoYPfJKJVhclk1PPyZKUCmk+fhglEut7bt+H8ufNYSpOZTCaVgj5NT4mXyeHl5KtTU+PVRSvTwqOP1cMs1lRKDCpvKrwnXq7B2orO6K47aS6VSldiQsXlVpsNtm+vgxMnmjDTJdDYuCseGnbnWKX6B/qzOKwiHMd2I4sL1WotuFwuONN8BjZteghSMMF4oCFddBxXxrlEykkT7Cd8fqzTEpZz3rFxwNYIBPpMJraYzX2hUJAVeyHRm9y4cSOsdjiovYnzg6ir0aivfZW1KmdQYN/X18t6tp/sboR6PPmpd06xGs7LQxhF7GbHCDIlb751bKi0tNQkbEspuQgszBZzAsBgm+rbVlVl0Wo1rK3o7x/QII67N6xfr6B5b28vqFPVoEvTMbCg+sxhRKhGx6IxaP9H+217hj2XkiuKz+BgT08PKLDo84QlDFiVEfBoUa1Gc4hquODa/Cg7TLWWdKhVstms7DsJT5iTkwP2TDubX8fmz2K27KeejC8S4nffe78J25hqbEsS/qrwJ73cdYV67Q/qampqFqFQOOQnTjY149+XysLC+/BmE+0pch2fd0I0Gn0b8+GJu6sT99m5c/uwk/glprwMn8hCAR8dBe+odxb/kvzpwcpK+hsz+zVwqfyopeUlfyDQaDaZOYNBzxyOYAMwMT4xjfX8+fKyshf49y+ETEL4p+traw9fvXatyu0ezqONWSzmm5UVFe9/2trqvgdOh5B+ur2u7mD3l19WDQ25cygyGRnp1x+qrPzgQlvbmFD5vwIMAAZsT2nNzBrxAAAAAElFTkSuQmCC"
}
dms.addRule("." + bgCls, ['background-image : url("', bgCss, '")'].join(""));
var otherSide = (side == "left") ? "right" : "left";
var themeColor = stif.themes.color[bh.theme];
var tpl = '<div class="<%= baseCls %>" style="position:absolute; top:0; <%= otherSide %>: 0; width:<%= width %>; height:632px; border-bottom: 2px solid <%= themeColor %>;"> <%-- unit --%> <div class="<%= baseCls %> IL_IF_AD_AREA" style="position:absolute; top:0; left:0; width:<%= width %>; height:600px; text-align:center;"> <% if (ad.actualTemplate == "iframe"){ %> <iframe name="IL_IF_FRAME_<%= sideUpper %>" class="<%= baseCls %>" src="<%= st.blankURL %>" width="<%= width %>" height="<%= height %>" frameborder="0" scrolling="no"></iframe> <%= rt.helpers.getEchoForm(content, "IL_IF_FRAME_" + sideUpper, "IL_IF_FORM_" + sideUpper) %> <% } else { %> <%= content %> <% } %> </div> <%-- footer --%> <div class="<%= baseCls %> IL_IF_FOOTER" style="position:absolute; bottom:0; left:0; width:<%= width %>; height:32px; cursor: pointer; background-color:#f1f1f2;"> <div id="IL_IF_LOGO_<%= sideUpper %>" class="<%= baseCls %>" style="position:absolute; width:53px; height:12px; top:9px; <%= side %>:10px; cursor:pointer; font-size:1px; <% if (oldIE || oldFF){ %>background:url(<%= skinPath %>logo.png) no-repeat scroll 0 0 transparent;<% } %>"> <% if (!oldIE && !oldFF){ %> <svg version="1.1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" x="0px" y="0px" width="53px" height="12px" viewBox="0 0 636 144" enable-background="new 0 0 636 144" xml:space="preserve"> <g> <!-- dot (first) --> <path id="IL_IF_LOGO_<%= sideUpper %>_LOGO_DOT_1" fill="<%= bh.theme == \'def\' ? \'#208CE5\' : themeColor %>" d="M16.918,24.865c5.848,0,10.57-4.735,10.57-10.583s-4.722-10.57-10.57-10.57 S6.334,8.434,6.334,14.282S11.07,24.865,16.918,24.865"/> <!-- in --> <path fill="#003366" d="M88.085,43.784H77.024c-17.149,0-31.181,14.031-31.181,31.182v34.796 c0,0.218,0.016,0.415,0.027,0.618v5.185c0,5.71-4.672,10.382-10.382,10.382h-0.467c-5.71,0-10.382-4.672-10.382-10.382V92.608 h0.015V45.889v-0.025c0-1.124-0.885-2.033-2.01-2.08h-11.49c-1.09,0.047-1.949,0.907-1.986,1.996v46.828h0.04 c-0.015,0.355-0.04,0.707-0.04,1.066v22.246c0,14.031,11.479,25.512,25.511,25.512h1.151c14.031,0,25.511-11.48,25.511-25.512 v-5.466v-4.62v-28.89c0.082-9.872,8.159-17.948,18.031-17.948h6.366c9.871,0,17.948,8.076,18.042,17.948v28.89v4.62v28.873 c0.013,0.023,0.013,0.034,0.013,0.048c0,1.111,0.883,2.008,1.983,2.057h11.505c1.077-0.036,1.936-0.887,1.985-1.973v-27.966v-5.659 V74.966C119.267,57.815,105.234,43.784,88.085,43.784"/> <!-- f (part) --> <path fill="#003366" d="M155.069,56.972v82.643c-0.072,0.992-0.886,1.78-1.903,1.818h-11.014 c-1.062-0.038-1.912-0.897-1.912-1.962c0-0.024,0-0.048-0.023-0.073V34.456c0.716-17.064,14.923-30.744,32.179-30.744h8.536 c0.025,0,0.038,0.011,0.06,0.011c1.053,0,1.915,0.849,1.974,1.901v11.037c-0.035,1.016-0.85,1.844-1.878,1.889h-8.692 c-9.509,0-17.327,7.75-17.327,17.268v6.301V56.972z"/> <!-- f (part) --> <path fill="#003366" d="M151.99,59.104h28.873c0.023-0.012,0.034-0.012,0.047-0.012 c1.111,0,2.008-0.884,2.057-1.984V45.604c-0.036-1.078-0.887-1.938-1.973-1.986h-27.965"/> <!-- o --> <path fill="#003366" d="M276.24,107.925h0.158V76.608c-0.37-18.164-15.248-32.825-33.494-32.825 h-16.756v0.022c-17.875,0.431-32.322,14.924-32.679,32.803h-0.026v31.316c0,18.213,14.601,33.064,32.705,33.496v0.012h16.589h0.021 h0.146C261.304,141.349,276.24,126.354,276.24,107.925 M208.93,107.925L208.93,107.925V77.289c0-9.914,8.096-18.02,18.021-18.02 h15.953c9.946,0,18.02,8.106,18.02,18.02v30.636h-0.167c0,9.949-8.074,18.021-17.999,18.021h-15.807 C217.026,125.946,208.93,117.874,208.93,107.925"/> <!-- l --> <path fill="#003366" d="M312.844,139.376L312.844,139.376c0,1.064-0.798,1.938-1.829,2.045h-11.816 c-1.027-0.107-1.837-0.98-1.837-2.045h-0.013V5.769h0.013c0-1.135,0.908-2.033,2.031-2.057h11.432 c1.124,0.024,2.019,0.922,2.019,2.057V139.376z"/> <!-- dot (second) --> <path id="IL_IF_LOGO_<%= sideUpper %>_LOGO_DOT_2" fill="<%= bh.theme == \'def\' ? \'#208CE5\' : themeColor %>" d="M341.662,24.865c5.848,0,10.57-4.735,10.57-10.583s-4.723-10.57-10.57-10.57 s-10.584,4.722-10.584,10.57S335.814,24.865,341.662,24.865"/> <!-- in (second) --> <path fill="#003366" d="M412.829,43.784h-11.061c-17.149,0-31.181,14.031-31.181,31.182v34.796 c0,0.218,0.016,0.415,0.026,0.618v5.185c0,5.71-4.672,10.382-10.382,10.382h-0.468c-5.71,0-10.382-4.672-10.382-10.382V92.608 h0.016V45.723v-0.025c0-1.123-0.885-2.033-2.01-2.08h-11.49c-1.091,0.047-1.949,0.908-1.986,1.996v46.994h0.04 c-0.015,0.355-0.04,0.707-0.04,1.066v22.246c0,14.031,11.479,25.512,25.512,25.512h1.15c14.031,0,25.512-11.48,25.512-25.512 v-5.466v-4.62v-28.89c0.082-9.872,8.158-17.948,18.029-17.948h6.367c9.871,0,17.947,8.076,18.041,17.948v28.89v4.62v28.873 c0.014,0.023,0.014,0.034,0.014,0.048c0,1.111,0.883,2.008,1.982,2.057h11.506c1.076-0.036,1.936-0.887,1.984-1.973v-27.966v-5.659 V74.966C444.01,57.815,429.979,43.784,412.829,43.784"/> <!-- k --> <path fill="#003366" d="M480.277,139.376L480.277,139.376V91.735h0.146h9.255l40.656,48.766 c0.599,0.549,1.15,0.906,1.841,0.932h16.073c0.882-0.025,2.869-0.322,1.794-2.056l-0.013-0.024l-47.58-56.777l44.599-36.815 c0.015-0.049,0.015-0.049,0.036-0.073c1.066-1.734-0.886-2.032-1.78-2.069H527.08c-0.621,0.024-1.15,0.324-1.666,0.791 l-36.812,31.075h-8.325V5.769c0-1.135-0.896-2.033-2.02-2.057h-11.422c-1.124,0.024-2.033,0.922-2.033,2.057v133.607 c0,1.064,0.803,1.938,1.844,2.045h11.802C479.476,141.313,480.277,140.44,480.277,139.376"/> <!-- s --> <path fill="#003366" d="M603.208,84.782H577.99c-6.91-0.114-12.508-5.785-12.508-12.783 c0-6.996,5.598-12.895,12.508-12.895h39.271c1.146,0,2.08-0.959,2.08-2.111v0.191V45.752v-0.037c0-1.164-0.935-2.097-2.08-2.097 H577.99c-15.451,0-28.008,12.73-28.008,28.381c0,15.651,12.557,28.381,28.008,28.27h24.252c6.911,0.111,12.508,5.812,12.508,12.795 c0,6.996-5.597,12.896-12.508,12.896H591.56l0.001-0.014h-28.874c-0.022,0.014-0.034,0.014-0.047,0.014 c-1.11,0-2.007,0.896-2.056,2.01v11.449c0.035,1.092,0.886,1.963,1.973,2.014h0.225h27.74h12.224 c15.209-0.279,27.491-12.9,27.491-28.369C630.236,97.737,618.191,85.202,603.208,84.782"/> </g> </svg> <% } %> </div> <div id="IL_IF_HELP_<%= sideUpper %>" class="<%= baseCls %> <%= cls %>" style="width:15px; height:15px; position:absolute; top:9px; <%= otherSide %>:27px; background-position:0 0; cursor:pointer; font-size:1px;"></div> <div id="IL_IF_X_<%= sideUpper %>" class="<%= baseCls %> <%= cls %>" style="width:15px; height:15px; position:absolute; top:9px; <%= otherSide %>:9px; background-position:-15px 0; cursor:pointer; font-size:1px;"></div> </div> </div>';
html = ut.VeST(tpl, {
side: side,
sideUpper: side.toUpperCase(),
rt: rt,
st: st,
bh: bh,
baseCls: st.baseClass,
cls: bgCls,
otherSide: otherSide,
width: instance[side].width + "px",
height: stif.height,
ad: ad,
content: content,
themeColor: themeColor,
oldIE: stif.oldIE,
oldFF: b.Firefox && b.getVersion(true) < 4,
skinPath: skinPath
});
var nodeStyle = {
position: stif.oldIE ? "absolute" : "fixed",
top: stif.oldIE ? dm.document.getScrollTop() : 0,
width: 0,
height: stif.height + 34 + "px",
overflow: "hidden",
display: (stif.margins[side] < instance[side].width) ? "none" : "block",
cursor: "pointer"
};
nodeStyle[side] = 0;
dmel.setStyle(node, nodeStyle);
node.innerHTML = html;
if (ad.actualTemplate == "iframe") {
var form = dm.element.$("IL_IF_FORM_" + side.toUpperCase());
if (form) {
form.submit()
}
}
this.setUnitEventHandlers(side)
},
getSkinPath: function() {
var stif = this.settings;
return ["http:/", this.$root.settings.hosts.resources, "static", "skins", stif.skin, stif.prodName, stif.rv, ""].join("/")
},
setGeneralEventHandlers: function() {
var evdm = this.$root.event.dom;
evdm.bind(window, {
event: "scroll",
listener: this.scrollHandler
});
evdm.bind(window, {
event: "resize",
listener: this.resizeHandler
})
},
setUnitEventHandlers: function(side) {
var rt = this.$root,
st = rt.settings,
ut = rt.utils,
stif = this.settings,
dm = ut.dom,
dmel = dm.element,
evdm = rt.event.dom,
node = stif.instance[side].hook.node;
var xBtn = dmel.$(stif.prodId + "_X_" + side.toUpperCase());
if (xBtn) {
evdm.bind(xBtn, {
event: "click",
data: {
side: side
},
listener: function(event) {
rt.event.repeat("effectSlideClose", stif.animationInterval, event.data)
}
});
evdm.bind(xBtn, {
event: "mouseover",
data: {
el: xBtn,
pos: "-15px -15px"
},
listener: this.setBackgroundPosition
});
evdm.bind(xBtn, {
event: "mouseout",
data: {
el: xBtn,
pos: "-15px 0"
},
listener: this.setBackgroundPosition
})
}
var ifLogo = dmel.$(stif.prodId + "_LOGO_" + side.toUpperCase());
if (ifLogo) {
evdm.bind(ifLogo, {
event: "click",
listener: function(event) {
rt.utils.dom.event.stop(event.domEvent);
if (st.homeUrl) {
window.open(st.homeUrl, "_blank")
}
}
})
}
var helpBtn = dmel.$(stif.prodId + "_HELP_" + side.toUpperCase());
if (helpBtn) {
evdm.bind(helpBtn, {
event: "click",
listener: function(event) {
rt.utils.dom.event.stop(event.domEvent);
if (st.helpUrl) {
window.open(st.helpUrl, "_blank")
}
}
});
evdm.bind(helpBtn, {
event: "mouseover",
data: {
el: helpBtn,
pos: "0 -15px"
},
listener: this.setBackgroundPosition
});
evdm.bind(helpBtn, {
event: "mouseout",
data: {
el: helpBtn,
pos: "0 0"
},
listener: this.setBackgroundPosition
})
}
var adArea = ut.dom.filterByClass("IL_IF_AD_AREA", null, node);
evdm.bind(adArea.length ? adArea[0] : node, {
event: "click",
data: {
hookId: stif.instance[side].hook.id
},
listener: function(event) {
rt.event.stop("effectSlideOpen");
rt.event.disable("effectSlideOpen");
rt.event.stop("effectSlideClose");
rt.event.disable("effectSlideClose");
rt.event.dom.unbind(window, "scroll", this.scrollHandler);
rt.event.dom.unbind(window, "resize", this.resizeHandler);
var parent, side, node;
for (side in stif.instance) {
node = stif.instance[side].hook.node;
parent = node.parentNode;
parent.removeChild(node)
}
var hookId = event.data.hookId,
hook = st.hooksMap[hookId],
data = rt.helpers.getHookData(hookId),
ad = data.ads[hook.currentAdIndex];
if (ad.template != "text" && ad.content.match(/<object |<embed /i) && ad.content.match(/clicktag/i)) {
return
}
event.$root.products.inframe.bannerClick(hookId)
}
})
},
scrollHandler: function() {
var stif = this.settings,
dm = this.$root.utils.dom,
side, node;
var viewport = dm.viewport.getHeight();
var height = stif.height + 34;
var scroll = dm.document.getScrollTop();
for (side in stif.instance) {
node = stif.instance[side].hook.node;
if (viewport > height) {
if (stif.oldIE) {
node.style.position = "absolute";
node.style.top = scroll + "px"
} else {
node.style.position = "fixed";
node.style.top = 0
}
} else {
node.style.position = "absolute";
if (scroll == 0) {
node.style.top = "0"
} else {
if (scroll >= height - viewport) {
node.style.top = (scroll - height + viewport) + "px"
}
}
}
}
},
resizeHandler: function() {
var side, margins = this.getPageMargins(),
instance = this.settings.instance;
for (side in instance) {
instance[side].hook.node.style.display = margins[side] > instance[side].width ? "block" : "none"
}
},
setBackgroundPosition: function(event) {
event.data.el.style.backgroundPosition = event.data.pos
},
bannerClick: function(hookId) {
var rt = this.$root;
rt.utils.timer.stop("adView" + hookId);
var reuseWindow = rt.helpers.getHookBehavior(hookId).adsReuseWindow;
if (!reuseWindow) {
try {
rt.settings.adWin = window.open("", hookId)
} catch (ex) {
rt.settings.adWin = null
}
}
rt.event.fire("productClick", {
hookId: hookId,
clickType: "onWin"
})
}
}, {
settings: {
prodId: "IL_IF",
prodCode: "f",
prodName: "inframe",
width: {
thin: 120,
wide: 160
},
height: 600,
effect: "slide",
buffer: 15,
instance: {},
behavior: {
def: {
ifp: "DOUBLE",
bs: "AUTO",
theme: "def"
}
},
themes: {
color: {
def: "#003366",
lightBlue: "#1b8ede",
green: "#67b045",
orange: "#f3933b",
red: "#dd3c42",
pink: "#d84189",
purple: "#5939aa"
}
},
sentences: {},
oldIE: (function() {
var b = $root.browser;
return (b.IE && (document.compatMode == "BackCompat" || b.getVersion(true) < 9))
}()),
skin: "brand",
rv: "1",
animationInterval: $root.browser.IE ? 7 : 10,
bidRequestTimeout: 750
}
}, true);
inframe.bind({
event: "renderProduct",
listener: {
renderInframe: function() {
var rt = this.$root,
st = rt.settings,
imp = rt.comm.settings.responses.impression,
stif = this.settings,
stifw = stif.width,
bh = stif.behavior,
instance = stif.instance,
prodCode = stif.prodCode,
prod = imp.prs[prodCode];
if (!prod || !prod.sentences || !prod.sentences.length) {
rt.event.fire("productRenderStatus", {
prod: prodCode,
status: "none"
});
return
}
var margins = stif.margins,
side, result = {
left: 0,
right: 0
},
bhm = bh.merged = rt.utils.object.extend({}, st.behavior.def, bh.def, st.behavior.impression, imp.prs[prodCode].behavior, st.behavior.customer, {
adsReuseWindow: true
});
for (side in result) {
if ((new RegExp(side.toUpperCase() + "|DOUBLE")).test(bhm.ifp)) {
result[side] = /WIDE|AUTO/.test(bhm.bs) && margins[side] >= stifw.wide ? stifw.wide : /THIN|AUTO/.test(bhm.bs) && margins[side] >= stifw.thin ? stifw.thin : 0
}
}
if (bhm.ifp == "SINGLE") {
var sizes = {
thin: 1,
wide: 1
},
size;
for (size in sizes) {
if ((new RegExp(size.toUpperCase() + "|AUTO")).test(bhm.bs)) {
side = margins.left >= stifw[size] && margins.right >= stifw[size] ? ["left", "right"][Math.floor(Math.random() * 2)] : margins.left > stifw[size] ? "left" : margins.right > stifw[size] ? "right" : null;
if (side) {
result[side] = stifw[size]
}
}
}
if (result.left && result.right) {
if (result.left < result.right) {
result.left = 0
} else {
result.right = 0
}
}
}
if (Math.min(result.left, result.right) > 0 && result.left != result.right) {
result.left = result.right = Math.min(result.left, result.right)
}
for (side in result) {
if (result[side]) {
instance[side] = {
width: result[side]
}
}
}
if (!(instance.left || instance.right)) {
rt.event.fire("productRenderStatus", {
prod: prodCode,
status: "none"
})
} else {
rt.event.fire("productRenderStatus", {
prod: prodCode,
status: "during"
});
rt.event.fire("initInframe")
}
}
}
});
inframe.bind({
event: "initInframe",
listener: {
init: function() {
var rt = this.$root,
ut = rt.utils,
stif = this.settings,
resImp = rt.comm.settings.responses.impression,
sentenceIndex = resImp.prs[stif.prodCode].sentences[0],
instance = stif.instance,
side, node, id;
stif.sentence = ut.object.keys(resImp.sentences)[sentenceIndex];
for (side in instance) {
id = [stif.prodId, side.toUpperCase()].join("_");
node = ut.dom.createDOMFragment({
tag: "div",
id: id,
cls: [rt.settings.baseClass, stif.prodId].join(" "),
parent: document.body
});
instance[side].hook = rt.helpers.createHook(id, stif.sentence, node, 0, this, stif.prodCode, stif.prodName, false, instance[side])
}
rt.event.fire("getAds", {
hookId: (instance.left || instance.right).hook.id,
params: {
as: this.buildGetadsPageMarginsParam(stif.behavior.merged.bs),
nm: (instance.left && instance.right) ? 2 : 1
},
bidRequestTimeout: stif.bidRequestTimeout,
callback: "getadsResponseInframe"
})
}
}
});
inframe.bind({
event: "getadsResponseInframe",
listener: {
setAdData: function(event) {
var rt = this.$root,
response = event.data,
data = {},
hook, ad, stif = this.settings,
instance = stif.instance,
side, i, leni;
if (!response.ads.length) {
rt.event.fire("productRenderStatus", {
prod: stif.prodCode,
status: "failed",
reason: "received no ads."
});
return false
} else {
for (i = 0, leni = response.ads.length; i < leni; i++) {
ad = response.ads[i];
if (ad.trackerURL) {
rt.helpers.hitTrackerURL(ad.trackerURL)
}
}
}
if (instance.left && instance.right) {
if (response.ads.length == 1) {
var selected = Math.floor(Math.random() * 2),
sides = ["left", "right"];
delete instance[sides[selected ^ 1]];
data[sides[selected]] = response
} else {
instance.right.hook.bdc = instance.left.hook.bdc;
instance.left.hook.midx = 0;
instance.right.hook.midx = 1;
if (instance.left.hook.externalTag) {
instance.right.hook.externalTag = instance.left.hook.externalTag
}
data.left = response;
data.right = rt.utils.object.clone(response, true);
data.left.ads = [data.left.ads[0]];
data.right.ads = [data.right.ads[1]]
}
} else {
for (side in instance) {
data[side] = response
}
}
for (side in instance) {
hook = instance[side].hook;
ad = data[side].ads[hook.currentAdIndex];
if (ad && ad.template == "external") {
data[side] = rt.externalTags.setExternalTagData(hook, data[side])
}
rt.helpers.setHookData(hook.id, data[side]);
if (hook.externalTag) {
rt.externalTags.updateViewedTags(hook.id)
}
}
rt.event.fire("createInframe")
}
}
});
inframe.bind({
event: "createInframe",
listener: {
createInframe: function() {
var rt = this.$root,
stif = this.settings,
side;
for (side in stif.instance) {
this.renderUnit(side)
}
this.setGeneralEventHandlers();
rt.event.repeat("effectSlideOpen", stif.animationInterval);
rt.event.fire("productRenderStatus", {
prod: stif.prodCode,
status: "after"
})
}
}
});
inframe.bind({
event: "effectSlideOpen",
listener: {
effectSlideOpen: function() {
var rt = this.$root,
stif = this.settings,
ut = rt.utils,
dmel = ut.dom.element,
b = rt.browser,
instance = stif.instance,
newWidth, side, hook;
var currentWidth = parseInt(dmel.getStyle((instance.left || instance.right).hook.node, "width"));
var endWidth = (instance.left || instance.right).width;
if (currentWidth >= endWidth) {
rt.event.stop("effectSlideOpen");
for (side in instance) {
hook = instance[side].hook;
rt.utils.timer.start("adView" + hook.id);
var data = rt.helpers.getHookData(hook.id);
rt.event.fire("sendAdView", {
hookId: hook.id,
params: {
bdc: hook.bdc,
midx: hook.midx || 0,
prod_t: hook.prod,
emd: data.ads[hook.currentAdIndex].emd || ""
}
})
}
return
}
newWidth = b.IE && b.getVersion(true) < 7 ? endWidth : Math.min(currentWidth + 2, endWidth);
for (side in instance) {
dmel.setStyle(instance[side].hook.node, {
width: newWidth + "px"
})
}
}
}
});
inframe.bind({
event: "effectSlideClose",
listener: {
effectSlideClose: function(event) {
var rt = this.$root,
stif = this.settings,
dmel = rt.utils.dom.element,
b = rt.browser,
side = event.data.side,
node = stif.instance[side].hook.node;
var current = parseInt(dmel.getStyle(node, "width"));
if (current <= 0) {
rt.event.stop("effectSlideClose");
node.parentNode.removeChild(node);
delete stif.instance[side];
return
}
var width = b.IE && b.getVersion(true) < 7 ? 0 : Math.max(current - 2, 0);
dmel.setStyle(node, {
width: width + "px"
})
}
}
});
var externalTags = $root.$create("externalTags", {
init: function() {
var rt = this.$root,
imp = rt.comm.settings.responses.impression,
i, leni, ut = rt.utils,
uta = ut.array,
uto = ut.object,
ad, etst = this.settings;
if (!imp.messages) {
return
}
if (rt.browser.isMobile()) {
delete imp.messages;
return
}
etst.bidCallbackVar = (rt.settings.white_label || "infolinks") + "_etag";
etst.oldAPI = uta.indexOf(uta.map(uto.values(imp.prs), function(item) {
return !!item.messages
}), true) > -1;
for (i = 0, leni = imp.messages.length; i < leni; i++) {
ad = imp.messages[i].ads[0];
ad.prs = uta.toObject(ad.prs ? ad.prs.split(",") : uta.discard(uta.discard(uto.keys(imp.prs), "s"), "o"), {}, true);
imp.messages[i].msg = i;
if (ad.emd) {
etst.tags[ad.emd] = imp.messages[i]
}
}
},
getProductAdSizes: function(prod, hook) {
switch (prod) {
case "i":
return [{
w: 300,
h: 250
}];
case "r":
return [{
w: 300,
h: 250
}];
case "t":
return [{
w: 300,
h: 250
}];
case "s":
return [{
w: 728,
h: 90
}];
case "o":
return [{
w: 728,
h: 90
}];
case "f":
return [{
w: hook.instance.width || 160,
h: 600
}]
}
},
setExternalTagData: function(hook, data) {
var uto = this.$root.utils.object,
ad = data.ads[0];
if (ad.content) {
ad.content = this.$root.utils.base64.decodeBase64(ad.content);
hook.externalTag = true
} else {
if (ad.url || ad.contentUrl) {
if (ad.url) {
ad.contentUrl = ad.url
}
hook.externalTag = true
} else {
var bidInvocation = hook.externalTag,
etst = this.settings,
emd = data.ads[0].emd,
tag = etst.tags[emd],
i, leni, responses = etst.bidResponses[bidInvocation];
for (i = 0, leni = responses.length; i < leni; i++) {
if (responses[i].emd == emd) {
data.width = responses[i].size.w;
data.height = responses[i].size.h;
data.ads[0].contentUrl = responses[i].result[tag.ads[0].jat];
uto.extend(data.ads[0], tag.ads[0])
}
}
}
}
data.cacheOverride = true;
return data
},
getBidData: function(bidInvocation) {
var rt = this.$root,
etst = this.settings;
if (rt.what(bidInvocation) != "number") {
return {}
}
var bids = etst.bidResponses[bidInvocation];
var emd = rt.utils.array.map(bids, function(bid) {
return bid.emd || ""
});
var nj = rt.utils.array.map(bids, function(bid) {
var p = bid.result[etst.tags[bid.emd].ads[0].jpt];
return rt.utils.base64.encodeBase64((rt.what(p) == "number" ? p : -1).toString()).split("").reverse().join("") || ""
});
var jsd = rt.utils.array.map(bids, function(bid) {
return [bid.size.w, bid.size.h].join("*") || ""
});
return {
emd: emd.join("~"),
nj: nj.join("~"),
jsd: jsd.join("~")
}
},
updateViewedTags: function(hookId) {
var rt = this.$root,
hook = rt.settings.hooksMap[hookId],
data = rt.helpers.getHookData(hookId);
var emd = data.ads[hook.currentAdIndex].emd,
etst = rt.externalTags.settings;
if (emd) {
if (!etst.uemd[emd]) {
etst.uemd[emd] = {}
}
if (!etst.uemd[emd][hook.prod]) {
etst.uemd[emd][hook.prod] = 0
}
etst.uemd[emd][hook.prod]++
}
},
getViewedTagsParam: function() {
var rt = this.$root,
etst = this.settings,
uto = rt.utils.object,
emd, val = [],
prod;
if (!uto.keys(etst.uemd).length) {
return {}
}
for (emd in etst.uemd) {
for (prod in etst.uemd[emd]) {
rt.utils.array.push(val, [emd, prod, etst.uemd[emd][prod]].join("!"))
}
}
return {
uemd: val.join("~")
}
}
}, {
settings: {
bidInvocation: 0,
bidResponses: {},
bidCount: 0,
tags: {},
bidRequestTimeout: 300,
uemd: {}
}
}, true);
externalTags.bind({
event: "sendBids",
listener: {
sendBids: function(event) {
var rt = this.$root,
etst = this.settings,
emd, tag, ad, jsonUrl, i, leni, hook = rt.settings.hooksMap[event.data.hookId],
sizes = this.getProductAdSizes(hook.prod, hook);
rt.utils.timer.start("externalBid" + (++etst.bidInvocation));
etst.bidResponses[etst.bidInvocation] = [];
etst.bidResponses[etst.bidInvocation].bids = 0;
etst.bidResponses[etst.bidInvocation].responses = 0;
for (emd in etst.tags) {
tag = etst.tags[emd];
ad = tag.ads[0];
if (ad.prs && !ad.prs[hook.prod]) {
continue
}
if (!ad.jsonUrl) {
continue
}
if (!ad.jat) {
ad.jat = "ad"
}
if (!ad.jat) {
ad.jpt = "cpm"
}
for (i = 0, leni = sizes.length; i < leni; i++) {
jsonUrl = ad.jsonUrl.replace(/\{WIDTH\}/g, sizes[i].w).replace(/\{HEIGHT\}/g, sizes[i].h);
etst.bidCount++;
etst.bidResponses[etst.bidInvocation].bids++;
rt.comm.loadScript([jsonUrl, "&callback=", etst.bidCallbackVar, etst.bidCount].join(""), null, "setExternalBidResponse", rt.utils.object.extend({
emd: emd,
bidInvocation: etst.bidInvocation,
bidCount: etst.bidCount,
hookId: hook.id,
size: sizes[i]
}, event.data))
}
}
}
}
});
externalTags.bind({
event: "setExternalBidResponse",
listener: {
setExternalBidResponse: function(event) {
var rt = this.$root,
etst = this.settings,
bidCount = event.data.bidCount,
bidInvocation = event.data.bidInvocation,
tag = etst.tags[event.data.emd],
ad = tag.ads[0],
jct, response = window[etst.bidCallbackVar + bidCount],
hook = rt.settings.hooksMap[event.data.hookId],
bidResponses = etst.bidResponses[bidInvocation];
response.emd = event.data.emd;
response.size = event.data.size;
if (ad.jct) {
jct = new RegExp(ad.jct.replace(/([\[\]])/g, "\\$1"), "g");
response.result[ad.jat] = response.result[ad.jat].replace(jct, "@encode@@start@@end@@encode@")
}
rt.utils.array.push(bidResponses, response);
bidResponses.responses++;
if (bidResponses.responses >= bidResponses.bids) {
if (hook.killBids) {
delete hook.killBids
} else {
hook.externalTag = bidInvocation;
rt.event.fire("sendGetAds", event.data)
}
}
}
}
});
var updater = $root.$create("updater", {
handleUpdaterImpression: function(event) {
var rt = this.$root,
response, ust = this.settings,
instance = ust.instances[ust.instances.length - 1];
instance.complete = true;
response = rt.helpers.processImpressionResponse(event.data);
if (rt.what(response) != "object") {
rt.logger.error("Bad Impression response.", true);
return
}
instance.impression = response;
if (!instance.impression.prs[rt.products.intext.settings.prodCode]) {
return
}
rt.event.fire("initIntext", {
updater: instance
})
}
}, {
settings: {
def: {
interval: 10,
container: null,
tag: null
},
counter: 0,
instances: []
}
}, true);
updater.bind({
event: "initUpdater",
listener: {
init: function() {
var rt = this.$root,
ust = this.settings,
hp = rt.helpers,
cont = hp.getVar("updater_container");
ust.interval = hp.getVar("updater_interval") || ust.def.interval;
ust.container = cont ? rt.utils.dom.element.$(cont) : ust.def.container;
ust.tag = hp.getVar("updater_tag") || ust.def.tag;
rt.event.repeat("updaterContentChange", ust.interval * 1000)
}
}
});
updater.bind({
event: "updaterContentChange",
listener: {
updaterContentChange: function() {
var rt = this.$root,
ut = rt.utils,
ust = this.settings,
harvested, instance, i, leni, text = [],
nodes = [];
if (ust.instances.length && !ust.instances[ust.counter - 1].complete) {
return
}
var containers = rt.utils.dom.filterByClass(ust.className, ust.tag, ust.container);
for (i = 0, leni = containers.length; i < leni; i++) {
if (containers[i].getAttribute("iceupdated") == "true") {
continue
}
rt.harvest.settings.enabled = true;
harvested = rt.harvest.getHarvestedText(containers[i]);
if (harvested.text.length > 0) {
containers[i].setAttribute("iceupdated", "true");
ut.array.push(text, harvested.text);
nodes = ut.array.concat(nodes, harvested.nodes)
}
}
if (!text.length) {
return
}
instance = ust.instances[ust.counter++] = {
nodes: nodes,
text: text.join("P"),
complete: false
};
rt.event.unbind("afterImpression");
rt.event.bind({
event: "afterImpression",
listener: this.handleUpdaterImpression
});
rt.event.fire("beforeImpression", {
ptxt: instance.text,
updater: ust.counter
})
}
}
});
var demo = $root.$create("demo", {
isDemo: function() {
var rt = this.$root,
hp = rt.helpers,
std = this.settings;
std.demo = hp.getVar("demo");
std.custom = hp.getVar("custom");
return (std.demo || std.custom)
},
convertCustom: function(custom) {
var rt = this.$root,
uto = rt.utils.object,
prods = ["intext", "tagcloud"],
prod, i, leni, prs = {},
prodCode;
if (custom.related) {
if (!custom.tagcloud) {
custom.tagcloud = custom.related
}
delete custom.related
}
for (i = 0, leni = prods.length; i < leni; i++) {
prod = prods[i];
if (custom[prod]) {
prodCode = prod.charAt(0);
if (custom[prod] === true) {
prs[prodCode] = {
behavior: {},
sentences: ["ALL"]
}
} else {
if ((custom[prod].sentences && custom[prod].sentences.length) || custom[prod].marker) {
prs[prodCode] = uto.extend({}, custom[prod])
}
}
}
}
var data = {
containers: custom.hooks && custom.hooks.containers ? custom.hooks.containers : null,
responses: {
gsd: uto.extend(custom.verification ? custom.verification.response : {}, {
prs: uto.keys(prs).join(",")
}),
impression: {
rauth: {
rsd: "1",
rsk: "1",
rcs: "1"
},
sentences: custom.hooks && custom.hooks.sentences ? rt.utils.array.toObject(custom.hooks.sentences, {}, "1") : null,
prs: prs
},
getads: {
catchall: rt.what(custom.hover.response) == "array" ? custom.hover.response[0] : custom.hover.response[rt.utils.object.keys(custom.hover.response)[0]]
}
}
};
rt.event.fire("setDemoData", data)
},
reRouteEvents: function() {
var rt = this.$root,
ev = rt.event;
ev.unbind("beforeGSD");
ev.bind({
event: "beforeGSD",
listener: this.beforeGSD
});
ev.unbind("afterGSD");
ev.bind({
event: "afterGSD",
listener: this.afterGSD
});
ev.unbind("beforeImpression");
ev.bind({
event: "beforeImpression",
listener: this.beforeImpression
});
ev.unbind("afterImpression");
ev.unbind("getAds");
ev.bind({
event: "getAds",
listener: this.getAds
});
ev.unbind("sendAdView");
ev.unbind("sendImpressionLog");
ev.unbind("startClick");
ev.bind({
event: "startClick",
listener: rt.comm.doRedirect
})
},
beforeGSD: function() {
this.$root.event.fire("afterGSD")
},
afterGSD: function() {
var rt = this.$root;
if (/i|r|t/.test(rt.comm.settings.responses.gsd.prs)) {
rt.event.fire("beforeHarvest")
} else {
rt.event.fire("beforeImpression")
}
},
beforeImpression: function() {
var rt = this.$root,
prs = rt.utils.array.toObject(rt.comm.settings.responses.gsd.prs.split(","), {}, true);
if (rt.helpers.getVar("inframe_disable") === true) {
delete prs["f"]
}
if (prs["f"]) {
var gpmp = rt.products.inframe.buildImpPageMarginsParam();
if (!gpmp) {
delete prs["f"]
}
}
rt.event.fire("preRenderProducts")
},
getAds: function(event) {
var rt = this.$root,
hookId = event.data.hookId,
st = rt.settings,
hook = st.hooksMap[hookId],
getads = rt.comm.settings.responses.getads,
s2cm = this.settings.sentences2ContainersMap,
i, j, ad, cb;
var data = rt.helpers.getHookData(hookId);
if (!data) {
if (getads.sentences && getads.sentences[hook.sentence]) {
data = getads.sentences[hook.sentence]
} else {
if (getads.containers && getads.containers[s2cm[hook.sentence]]) {
data = getads.containers[s2cm[hook.sentence]]
} else {
if (getads.catchall) {
data = getads.catchall
}
}
}
}
data = data ? rt.utils.object.clone(data, true) : "pending";
data.lid = hook.id;
data.sentence = hook.sentence;
var props = ["redirectUrl", "title", "text"];
for (i = 0; i < data.ads.length; i++) {
ad = data.ads[0];
for (j = 0; j < props.length; j++) {
if (ad[props[j]]) {
ad[props[j]] = ad[props[j]].replace("@sentence@", hook.sentence)
}
}
}
hook.bdc = ++st.bdc;
switch (hook.prod) {
case "s":
cb = "getadsResponseInsearch";
break;
case "f":
cb = "getadsResponseInframe";
break;
default:
cb = "getadsResponse"
}
rt.event.fire(cb, data)
}
}, {
settings: {
custom: false,
demo: false,
sentences2ContainersMap: {}
}
}, true);
demo.bind({
event: "demo",
listener: {
init: function() {
var rt = this.$root,
std = this.settings;
this.reRouteEvents();
if (std.custom) {
this.convertCustom(std.custom)
} else {
if (std.demo) {
rt.comm.loadScript(std.demo)
}
}
}
}
});
demo.bind({
event: "setDemoData",
listener: {
setDemoData: function(event) {
var rt = this.$root,
st = rt.settings,
data = event.data,
imp, i, leni, dmel = rt.utils.dom.element,
el, sentence, dst = this.settings,
hp = rt.helpers;
rt.helpers.getCustomerId();
dst.data = data;
imp = st.impression = {
params: {}
};
if (data.ref) {
st.ref = imp.params.ref = data.ref
}
if (data.refq) {
st.refq = imp.params.refq = data.refq
}
hp.setDefaultWebsiteDirectives(data.responses.gsd);
if (!data.responses.impression.sentences) {
data.responses.impression.sentences = {}
}
if (data.containers) {
for (i = 0, leni = data.containers.length; i < leni; i++) {
el = dmel.$(data.containers[i]);
if (!el || !el.firstChild || el.firstChild.nodeType != st.nodeTypes.TEXT) {
continue
}
sentence = rt.utils.string.trim(el.firstChild.nodeValue.toLowerCase().replace(/\s+/g, ""));
data.responses.impression.sentences[sentence] = "1";
dst.sentences2ContainersMap[sentence] = data.containers[i]
}
}
hp.normalizeSentenceLists(data.responses.impression);
rt.comm.settings.responses = data.responses;
rt.event.fire("loadPlugins")
}
}
});
var bubble = $root.$create("bubble", {
hookDblClick: function(event) {
this.$root.utils.dom.event.stop(event.domEvent)
},
hookClick: function(event) {
var rt = this.$root,
st = rt.settings,
domEvt = event.domEvent,
sender = domEvt.target || domEvt.srcElement,
ut = rt.utils,
hookId = event.data.hookId,
hook = st.hooksMap[hookId],
bst = this.settings,
ad;
ut.dom.event.stop(domEvt);
if (st.clickStatus == "complete") {
return
}
if (hook.externalTag) {
st.clickStatus = "complete";
return
}
hook.clickType = (sender.className.indexOf(bst.cls + "_simlink") != -1 || ut.dom.element.inHierarchy(sender, hook.node)) ? hook.bubble.status == "open" ? "onLinkAfterWinOpen" : "onLink" : "onWin";
st.clickStatus = "pending";
ut.timer.stop("adView" + hookId);
var reuseWindow = rt.helpers.getHookBehavior(hookId).adsReuseWindow;
var data = rt.helpers.getHookData(hookId);
if (hook.bubble.status != "open" && (bst.dcbbs || (data && data.dcbbs))) {
st.clickStatus = "none";
delete hook.clickType;
return
}
if (rt.what(data) == "object") {
ad = data.ads[hook.currentAdIndex];
if (hook.clickType == "onWin" && ad.template == "html" && ad.content.match(/<object |<embed /i) && ad.content.match(/clicktag/i)) {
st.clickStatus = "complete";
return
}
if ((hook.clickType == "onLink" || hook.clickType == "onLinkAfterWinOpen") && ad.redirectURL == "") {
st.clickStatus = "none";
delete hook.clickType
} else {
if (hook.bubble.status == "open" || hook.clickType == "onWin" || !data.dcbbs) {
if (!reuseWindow) {
st.adWin = window.open("", hook.node.id)
}
rt.event.fire("productClick", {
hookId: hookId
})
}
}
} else {
if (!reuseWindow) {
st.adWin = window.open("", hook.node.id)
}
}
},
getSkinPath: function(skin) {
var rt = this.$root,
sk = this.skins,
rv = skin && sk[skin] && sk[skin].settings.rv ? sk[skin].settings.rv + "/" : "";
return ["http://", rt.settings.hosts.resources, "/static/skins/", skin ? skin + "/intext/" : "", rv].join("")
},
preloadImages: function(path, images) {
var loaderPath = this.getSkinPath(false);
var loaderImages = ["loader.gif", "loader-bg.png"];
for (i = 0, leni = loaderImages.length; i < leni; i++) {
img = new Image();
img.src = loaderPath + loaderImages[i]
}
if (!images) {
return
}
var rt = this.$root,
b = rt.browser,
img, i, leni;
images = rt.utils.string.qw(images);
for (i = 0, leni = images.length; i < leni; i++) {
img = new Image();
img.src = [path, images[i], ".png"].join("")
}
},
adjustBubblePosition: function(hook, dimensions) {
var rt = this.$root,
st = rt.settings,
ut = rt.utils,
dm = ut.dom,
dmel = dm.element,
b = rt.browser,
pos = hook.pos;
var node = hook.node;
var nodeHeight = node.offsetHeight;
hook.isMultiline = (hook.fontSize * 2 < nodeHeight);
var right, left, top, bottom, scrollTop = dm.document.getScrollTop(),
scrollLeft = dm.document.getScrollLeft();
var width = dimensions.width,
height = dimensions.height;
var bbldir = rt.helpers.getHookBehavior(hook.id).bubbleDirection;
if (hook.isMultiline) {
var linesCount = Math.floor(nodeHeight / (parseInt(dmel.getStyle(node, "lineHeight"), 10) || hook.fontSize + 2));
if (linesCount < 2) {
linesCount = 2
}
var lineHeight = Math.floor(nodeHeight / linesCount);
var mouseX = hook.domEvent.pageX || hook.domEvent.clientX + scrollLeft;
var mouseY = hook.domEvent.pageY || hook.domEvent.clientY + scrollTop;
right = mouseX > (pos.left + pos.left + node.offsetWidth) / 2 ? pos.left + node.offsetWidth - 20 : pos.left;
left = right + 20 - width;
top = pos.top - height;
if (mouseY - pos.top > lineHeight) {
top += lineHeight
}
bottom = top + lineHeight + height
} else {
right = pos.left;
left = pos.left - width + ((!b.IE || !node.offsetWidth) ? 20 : node.offsetWidth);
top = pos.top - height;
bottom = pos.top + (node.offsetHeight || 18)
}
var allpos = {
TR: {
rect: [right, top, right + width, top + height],
clear: true,
inBounds: true
},
TL: {
rect: [left, top, left + width, top + height],
clear: true,
inBounds: true
},
BR: {
rect: [right, bottom, right + width, bottom + height],
clear: true,
inBounds: true
},
BL: {
rect: [left, bottom, left + width, bottom + height],
clear: true,
inBounds: true
}
};
if ((right + width > dm.document.getWidth() + scrollLeft) || (bbldir && bbldir.indexOf("L") != -1)) {
allpos.TR.inBounds = allpos.BR.inBounds = false
}
if (left < 0 || (bbldir && bbldir.indexOf("R") != -1)) {
allpos.TL.inBounds = allpos.BL.inBounds = false
}
if ((bottom + height > dm.document.getHeight() + scrollTop) || (bbldir && bbldir.indexOf("T") != -1)) {
allpos.BR.inBounds = allpos.BL.inBounds = false
}
if (top < scrollTop || (bbldir && bbldir.indexOf("B") != -1)) {
allpos.TR.inBounds = allpos.TL.inBounds = false
}
if (st.unhoverableAreas) {
for (var key in allpos) {
if (!allpos[key].inBounds) {
continue
}
for (var i = 0, leni = st.unhoverableAreas.length; i < leni; i++) {
if (ut.doRectsOverlap(allpos[key].rect, st.unhoverableAreas[i])) {
allpos[key].clear = false;
break
}
}
}
}
for (key in allpos) {
if (!allpos[key].inBounds) {
continue
}
if (allpos[key].clear) {
hook.orientationY = key.charAt(0);
hook.orientationX = key.charAt(1);
return {
left: allpos[key].rect[0],
top: allpos[key].rect[1]
}
}
}
for (key in allpos) {
if (allpos[key].inBounds) {
hook.orientationY = key.charAt(0);
hook.orientationX = key.charAt(1);
return {
left: allpos[key].rect[0],
top: allpos[key].rect[1]
}
}
}
hook.orientationY = "T";
hook.orientationX = "R";
if (bbldir) {
if (bbldir.length == 2) {
hook.orientationY = bbldir.charAt(0);
hook.orientationX = bbldir.charAt(1)
} else {
if (bbldir == "T" || bbldir == "B") {
hook.orientationY = bbldir
}
if (bbldir == "R" || bbldir == "L") {
hook.orientationX = bbldir
}
}
}
return {
left: allpos[hook.orientationY + hook.orientationX].rect[0],
top: allpos[hook.orientationY + hook.orientationX].rect[1]
}
},
getPreloaderPosition: function(hook, dimensions) {
var pos = this.adjustBubblePosition(hook, dimensions);
if (hook.orientationY == "T") {
pos.top = pos.top + dimensions.height - 31
}
if (hook.orientationX == "L") {
pos.left = pos.left + dimensions.width - 31
}
return pos
},
renderAdsContent: function(hook, data) {
var rt = this.$root,
adsHTML = "",
ad;
for (var i = 0, leni = data.ads.length; i < leni; i++) {
ad = data.ads[i];
rt.helpers.setActualTemplate(ad);
adsHTML += this.templates[ad.actualTemplate](hook, i)
}
return adsHTML
},
afterBubbleRendered: function(container, data, hook) {
var rt = this.$root,
i, leni, form;
for (i = 0, leni = data.ads.length; i < leni; i++) {
if (data.ads[i].actualTemplate == "iframe") {
form = container.getElementsByTagName("form");
if (form.length && form[0].className.indexOf(this.settings.cls + "_ad_form") != -1) {
form[0].submit()
}
}
}
var anchors = container.getElementsByTagName("a"),
href;
for (i = 0, leni = anchors.length; i < leni; i++) {
if (anchors[i].href) {
href = anchors[i].href;
anchors[i].removeAttribute("href");
rt.event.dom.bind(anchors[i], {
event: "click",
listener: (function() {
return function(domEvt) {
rt.utils.dom.event.stop(domEvt.domEvent);
rt.event.fire("productClick", {
hookId: hook.id,
url: href,
clickType: "onWin"
})
}
})()
})
}
}
var objects = container.getElementsByTagName("object");
for (i = 0; i < objects.length; i++) {
rt.utils.dom.event.disableEventBubbling("click", objects[i])
}
var embeds = container.getElementsByTagName("embed");
for (i = 0; i < embeds.length; i++) {
rt.utils.dom.event.disableEventBubbling("click", embeds[i])
}
}
}, {
settings: {
initialized: false,
activeHook: null,
base: {
status: "closed",
node: null,
pos: null
},
def: {
width: 316,
height: 176
},
cls: "ice_it",
oldIE: (function() {
var b = $root.browser;
return b.IE && b.getVersion(true) < 9
})(),
oldFF: (function() {
var b = $root.browser;
return b.Firefox && b.getVersion(true) < 4
})()
}
}, true);
bubble.bind({
event: "initBubble",
listener: {
initBubble: function(event) {
var rt = this.$root,
hp = rt.helpers,
bst = rt.bubble.settings;
bst.initialized = true;
bst.dcbbs = hp.getVar("deny_click_before_bubble_show") || false;
this.skins[rt.products[event.data].settings.behavior.merged.skin].init()
}
}
});
bubble.bind({
event: "hookMouseover",
listener: {
hookMouseover: function(event) {
var rt = this.$root,
st = rt.settings,
hookId = event.data.hookId,
bh = rt.helpers.getHookBehavior(hookId),
hook = st.hooksMap[hookId],
hrd = bh.hoverRequestDelay;
delete hook.killHoverStart;
if (st.clickStatus != "none") {
return
}
if (hook.bubble.status.indexOf("open") == 0) {
hrd = 0
}
var de = event.data.domEvent || event.domEvent;
hook.domEvent = {
pageX: de.pageX,
pageY: de.pageY,
clientX: de.clientX,
clientY: de.clientY
};
rt.event.fire(hook.type + "HookMouseover", {
hookId: hookId
});
rt.event.fire("hookHoverStart", {
hookId: hookId
}, hrd)
}
}
});
bubble.bind({
event: "hookMouseout",
listener: {
hookMouseout: function(event) {
var rt = this.$root,
st = rt.settings,
hookId = event.data.hookId,
hook = st.hooksMap[hookId];
hook.killHoverStart = true;
rt.event.fire(hook.type + "HookMouseout", {
hookId: hook.id
});
rt.event.fire("hideBubble", {
hookId: hook.id
})
}
}
});
bubble.bind({
event: "hookHoverStart",
listener: {
hookHoverStart: function(event) {
var rt = this.$root,
bst = this.settings,
hookId = event.data.hookId,
hook = rt.settings.hooksMap[hookId],
activeHook;
if (hook.killHoverStart) {
delete hook.killHoverStart;
return
}
hook.hovered = true;
if (bst.activeHook && bst.activeHook != hookId) {
activeHook = bst.activeHook;
bst.activeHook = null;
rt.event.fire("closeBubble", {
hookId: activeHook
})
}
bst.activeHook = hookId;
if (hook.bubble.status.indexOf("open") != -1) {
return
}
hook.bubble.status = "opening";
var bubbleShowDelay = rt.helpers.getHookBehavior(hookId).bubbleShowDelay;
var data = rt.helpers.getHookData(hookId);
if (!data) {
rt.event.fire("getAds", event.data)
}
rt.event.fire("showBubble", event.data, bubbleShowDelay)
}
}
});
bubble.bind({
event: "getadsResponse",
listener: {
setAdData: function(event) {
var rt = this.$root,
st = rt.settings,
data = event.data,
hookId = data.lid,
bst = this.settings,
i, leni, ad, hook = st.hooksMap[hookId];
if (!hook) {
rt.logger.error("Error: Misssing hook.", this.setAdData);
return false
}
if (bst.activeHook == hookId && hook.bubble.status == "open") {
return
}
data.sentence = decodeURIComponent(data.sentence);
ad = data.ads[hook.currentAdIndex];
if (ad.template == "external") {
data = rt.externalTags.setExternalTagData(hook, data)
} else {
if (hook.externalTag) {
delete hook.externalTag
}
if (!data.width || data.width < 200) {
data.width = bst.def.width
}
if (!data.height || data.height < 60) {
data.height = bst.def.height
}
if (bst.dcbbs) {
data.dcbbs = bst.dcbbs
}
if (data.dcbbs && !rt.helpers.getHookBehavior(hookId).adsReuseWindow) {
data.dcbbs = false
}
if (data.dcbbs && st.clickStatus == "pending") {
st.clickStatus = "none";
st.hookClicked = null
}
}
rt.helpers.setHookData(hookId, data);
for (i = 0, leni = data.ads.length; i < leni; i++) {
ad = data.ads[i];
rt.helpers.setAdThumbnail(ad);
if (ad.trackerURL) {
rt.helpers.hitTrackerURL(ad.trackerURL)
}
}
if (bst.activeHook != hookId) {
rt.event.fire("closeBubble", {
hookId: hookId
});
return
}
rt.event.fire("showBubble", {
hookId: hookId
})
}
}
});
bubble.bind({
event: "showBubble",
listener: {
showBubble: function(event) {
var rt = this.$root,
st = rt.settings,
hookId = event.data.hookId,
hook = st.hooksMap[hookId],
dm = rt.utils.dom,
rtb = rt.bubble,
bst = rtb.settings;
if (hook.bubble.status == "open") {
return
}
var data = rt.helpers.getHookData(hookId);
hook.pos = dm.element.offset(hook.node);
var preloader = hook.bubble.preloader;
if (data && data != "pending") {
if (preloader) {
preloader.style.display = "none"
}
var skin = data.ads[hook.currentAdIndex].skin || rt.helpers.getHookBehavior(hookId).skin;
rtb.skins[skin].showBubble(hookId)
} else {
if (data == "pending") {
var pos = rtb.getPreloaderPosition(hook, {
width: bst.def.width,
height: bst.def.height
});
if (!preloader) {
var path = rtb.getSkinPath();
preloader = hook.bubble.preloader = dm.createDOMFragment({
tag: "div",
cls: st.baseClass,
parent: document.body,
style: {
position: "absolute",
display: "none",
width: "30px",
height: "30px",
top: "0px",
left: "0px",
zIndex: st.baseZIndex + 101,
background: ['transparent url("', path, 'loader-bg.png") no-repeat scroll 0 0'].join("")
},
children: {
tag: "img",
cls: st.baseClass,
attributes: {
width: 30,
height: 30,
alt: "",
src: path + "loader.gif"
}
}
})
}
dm.element.setStyle(preloader, {
top: pos.top + "px",
left: pos.left + "px",
display: "block"
})
}
}
}
}
});
bubble.bind({
event: "bubbleShowing",
listener: {
bubbleShowing: function(event) {
var rt = this.$root,
st = rt.settings,
hookId = event.data.hookId,
hook = st.hooksMap[hookId],
bh = rt.helpers.getHookBehavior(hookId),
time = bh.bubbleHideDelay,
data = rt.helpers.getHookData(hookId);
hook.bubble.status = "open";
if (hook.externalTag) {
rt.externalTags.updateViewedTags(hookId)
}
var params = {
bdc: hook.bdc,
midx: hook.currentAdIndex,
prod_t: hook.prod,
emd: data.ads[hook.currentAdIndex].emd || ""
};
rt.event.fire("sendAdView", {
hookId: hookId,
params: params
});
if (st.clickStatus == "pending") {
rt.event.fire("productClick", {
hookId: hookId
}, time);
return
}
rt.utils.timer.start("adView" + hookId);
if (!hook.hovered) {
rt.event.fire("hideBubble", {
hookId: hookId
})
}
}
}
});
bubble.bind({
event: "hideBubble",
listener: {
hideBubble: function(event) {
var rt = this.$root,
hookId = event.data.hookId,
hook = rt.settings.hooksMap[hookId],
viewTime = null;
hook.hovered = false;
if (hook.bubble.status == "closed") {
return
}
var data = rt.helpers.getHookData(hookId);
if (hook.externalTag && data) {
viewTime = data.ads[hook.currentAdIndex].vt
}
var delay = parseInt(event.data.xBtn ? 0 : (viewTime || rt.helpers.getHookBehavior(hookId).bubbleHideDelay));
rt.event.fire("closeBubble", event.data, delay)
}
}
});
bubble.bind({
event: "closeBubble",
listener: {
closeBubble: function(event) {
var rt = this.$root,
st = rt.settings,
bst = this.settings,
hookId = event.data.hookId,
hook = st.hooksMap[hookId],
data = rt.helpers.getHookData(hookId);
if (bst.activeHook == hookId) {
bst.activeHook = null
}
if (hook.hovered) {
return
}
if (hook.bubble.node) {
hook.bubble.node.style.display = "none"
}
if (hook.bubble.preloader) {
hook.bubble.preloader.style.display = "none"
}
if (st.clickStatus != "pending") {
if (data && data.cacheOverride) {
rt.helpers.clearHookData(hookId);
if (hook.externalTag) {
delete hook.externalTag
}
}
}
if (st.clickStatus == "none") {
rt.utils.timer.clear("adView" + hookId)
}
hook.bubble.status = "closed";
if (data && data != "pending" && data.ads[0].template == "html") {
rt.event.fire("clearBubbleDOM", {
hookId: hookId
}, 1000)
}
}
}
});
bubble.bind({
event: "clearBubbleDOM",
listener: {
clearBubbleDOM: function(event) {
var rt = this.$root,
st = rt.settings,
hookId = event.data.hookId,
hook = st.hooksMap[hookId],
el;
if (hook.bubble.status == "open") {
return
}
el = rt.utils.dom.filterByClass(this.settings.cls + "_bodyMain", null, hook.bubble.node);
if (el.length) {
el[0].innerHTML = ""
}
}
}
});
bubble.bind({
event: "bubbleMouseover",
listener: {
bubbleMouseover: function(event) {
var rt = this.$root,
hookId = event.data.hookId,
hook = rt.settings.hooksMap[hookId],
data = rt.helpers.getHookData(hook.id);
hook.hovered = true;
rt.event.fire((data.ads[hook.currentAdIndex].skin || rt.helpers.getHookBehavior(hookId).skin) + "BubbleMouseover", event.data)
}
}
});
bubble.bind({
event: "bubbleMouseout",
listener: {
bubbleMouseout: function(event) {
var rt = this.$root,
st = rt.settings,
hookId = event.data.hookId,
hook = st.hooksMap[hookId],
data = rt.helpers.getHookData(hook.id);
hook.hovered = false;
rt.event.fire((data.ads[hook.currentAdIndex].skin || rt.helpers.getHookBehavior(hookId).skin) + "BubbleMouseout", event.data);
if (st.clickStatus == "pending") {
return
}
rt.event.fire("hideBubble", event.data)
}
}
});
bubble.$create("templates", {
text: function(hook, adIndex) {
var rt = this.$root,
pr = this.$parent,
st = rt.settings,
b = rt.browser,
data = rt.helpers.getHookData(hook.id),
ad = data.ads[hook.currentAdIndex],
thumbURL = "",
hasThumb = false,
bst = pr.settings;
var skinPath = pr.getSkinPath(data.skin || rt.helpers.getHookBehavior(hook.id).skin);
if (ad.thumbURL != "no-image") {
thumbURL = ad.thumbURL;
hasThumb = true
}
var html = '<div class="<%= cls %>" style="color:#003366; font-family: Arial,sans-serif; font-size:11pt; font-weight:bold; line-height:11pt; margin-left:15px; margin-top:10px; margin-bottom:10px; margin-right:5px; max-height:22pt; overflow:hidden;"><%= ad.title %></div> <div class="<%= cls %>" style="position:absolute; height:88px; width:<%= data.width %>px;"> <%if (hasThumb){ %> <img class="<%= cls %>" width="110" height="82" style="position:absolute; top:0; left:15px; width:110px; height:82px; background-color:#e8e8e8; box-shadow:2px 2px 5px #888; -moz-box-shadow:2px 2px 5px #888; -webkit-box-shadow:2px 2px 5px #888;" src="<%= thumbURL %>"> <% } %> <div class="<%= cls %>" style="position:absolute; top:0; left:<%= hasThumb ? 140 : 15 %>px; width:168px; height:51px; overflow:hidden; color:#666666; font-family: Arial,sans-serif; font-size:10pt; font-weight:normal; line-height:17px;"><%= ad.text %></div> <div id="<%= intextCls %>_btn_<%= hookId %>" class="<%= cls %> <%= intextCls %>_btn" style="position:absolute; display:block; bottom:0px; right:13px; width:93px; height:24px; font-family:Arial,sans-serif; font-size:9pt; font-weight:bold; cursor:pointer; text-align:center; line-height:24px; color:#ffffff;"><%= rt.helpers.translate("clickHere") %></div> </div> <div class="<%= cls %>" style="position:absolute; bottom:12px; left:15px; width:280px; height:15px; color:#003366; font-family: Arial,sans-serif; font-size:9pt; font-weight:normal; text-decoration:underline; overflow:hidden;"><%= ad.displayedURL %></div>';
return rt.utils.VeST(html, {
rt: rt,
intextCls: bst.cls,
cls: st.baseClass,
btnCls: [st.baseClass, " ", bst.cls, "_bg ", bst.cls, "_btn"].join(""),
hookId: hook.id,
data: data,
ad: ad,
thumbURL: thumbURL,
hasThumb: hasThumb,
display: adIndex != hook.currentAdIndex ? "none" : "block",
skinPath: skinPath
})
},
html: function(hook, adIndex) {
var rt = this.$root,
st = rt.settings;
return rt.utils.VeST('<div class="<%= cls %>" style="height:<%= data.height %>px; position:relative; display:<%= display %>;"><%= content %></div>', {
cls: st.baseClass,
adIndex: adIndex,
data: rt.helpers.getHookData(hook.id),
display: adIndex != hook.currentAdIndex ? "none" : "block",
content: rt.helpers.parseTokens(hook)
})
},
iframe: function(hook, adIndex) {
var rt = this.$root,
st = rt.settings,
bst = this.$parent.settings;
var html = '<div class="<%= cls %>" style="display:<%= display %>;"><div cls="<%= cls %>" style="width:<%= data.width %>px; height:<%= data.height %>px;"> <iframe name="<%= iframeName %>" src="<%= st.blankURL %>" width="<%= data.width %>" height="<%= data.height %>" frameborder="0" scrolling="no"></iframe></div><%= rt.helpers.getEchoForm(content, iframeName, null, formCls) %></div>';
return rt.utils.VeST(html, {
rt: rt,
version: rt.version,
cls: st.baseClass,
adIndex: adIndex,
data: rt.helpers.getHookData(hook.id),
display: adIndex != hook.currentAdIndex ? "none" : "block",
content: rt.helpers.parseTokens(hook),
iframeName: bst.cls + "_ad_frame" + adIndex,
formCls: bst.cls + "_ad_form",
st: st
})
},
external: function(hook, adIndex) {
var rt = this.$root,
st = rt.settings,
data = rt.helpers.getHookData(hook.id);
var html = '<div class="<%= cls %>" style="display:<%= display %>; width:<%= data.width %>px; height:<%= data.height %>px;"> <iframe src="<%= contentUrl %>" width="<%= data.width %>" height="<%= data.height %>" frameborder="0" scrolling="no" allowtransparency="true" leftmargin="0" topmargin="0" marginwidth="0" marginheight="0"></iframe></div>';
return rt.utils.VeST(html, {
cls: st.baseClass,
data: data,
display: adIndex != hook.currentAdIndex ? "none" : "block",
contentUrl: rt.helpers.parseTokens(hook, data.ads[adIndex].contentUrl)
})
}
}, null, false);
var skins = bubble.$create("skins", {}, null, false);
skins.$create("brand", {
init: function() {
var rt = this.$root,
dms = rt.utils.dom.style,
bbl = rt.bubble,
bst = bbl.settings,
intextCls = bst.cls,
skinPath = bbl.getSkinPath(this.$id),
images = "";
if (rt.browser.IE || bst.oldFF) {
dms.addRule("." + intextCls + "_btn", ["background:url(", skinPath, "btn.png) no-repeat scroll 0 0 !important;"].join(""));
dms.addRule("." + intextCls + "_bg", ["background:url(", skinPath, "hdr-btns.png) no-repeat scroll 0 0;"].join(""));
images = "btn.png hdr-btns.png loading.gif"
} else {
dms.addRule("." + intextCls + "_btn", ["background:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAF0AAABICAYAAACUavnrAAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAAA4JJREFUeNrsnL9u01AUxs+xbxOS1LQVBQkGJBgQMPUNGCshMiB1zgqoOwMViBfoxMYGqjqwMIBgYqC8AQsStAyVaAmllDZN4j+xL/fGdsgD9J4I8X1SFDvZfv70+dxzj60eP3119vXGx9V6rXLzdP2U0gSdtNh8umEct/ePXn7ebt9nutZ6dvHyhdZsUKcsA3JX8n2mvV/HtLN38ET5Qb1prgJ1+xHIuHS7sXuSZvagqcy5l//IIOMYOudB4ivSpG2seGDuVgZ4kd5a2TOtNSHO3d9MM51DHlYrWZYRjC5gdp3l0K3t7QWA0SWgF06nwumQ80inEvMwXlINn0soG3e6xl1UyO3j8QKnyzrdhvsgRaaLBfsoXuB0UXlAAOiADgE6oEOA/s9B94FBVL6p03mLmBfAQmqBpDcVZ/EKJ701s0CaAxHHseJxW081HilD/c1sw1vu9JMl4/qGbREAz8nzZtKdoF5Z/51kGyqhynxXBYtXrp+7MV2rKrQETl52U7obJtGX7fbPOI7e2UxfNb+3dvcO0YNxCt5uiOq75iBR7FEzihMKowRkBBxvZOde2GNDHmMvAtDNJ6XUloykAVy2aFTlFYDkpP6GPCSSLyV0DzN1MrlScFcMp8tSHzkd0OWYs4XOebxgWSRBvRjBGMaLgc6gLpQubOOFTbyYxRG2MwSMXk54FfGCWBdLlzxefEOcUTYKOt3Gi4/ei6jT82hntALkynRMA0xCgA7o/w90zL3Iylea9JapFxfQCnCr4WPq8cAebqo0Dh909neeK6XmCRvTTqn3++Gu1pWHitL47XHv6B771dvmn4Aw9+IoxvWhTsMXVJ35oGiqMR/MnLl19dL5xelaBe97cWJytm8ZiT993e12euF7uzhaNaBb334c5I/cgbob8Pk98445ipU5afbjhHphDDIC4M3SP597sQ0v7aMR4Bw62bkXKude0HsRlMYIhiTt4luVhTskFzFw+gSsnm9MI9FFrZ47Hb1GWadb8ogXWeqj7TpILl+KWUagkBRKxslA5+Gd1EOjSyDRxzLdQwUzieoFETOBTEf9Ig+dMEAqCr18/AXQ3cc5jznd57wBg4hxuiQa7fj7SmvaYs/OvaB8cQ3dzr2YsnFTZYNopXfwfc1An8OutFtFcdJmXbXve0nfVDlZPu4NlgxyvO/FjTyPdSeoVdbTRG/8EWAAta8y0OqpUAcAAAAASUVORK5CYII=) no-repeat scroll 0 0 !important;"].join(""));
dms.addRule("." + intextCls + "_bg", ["background:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAB4AAAAeCAYAAAA7MK6iAAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAAB+hJREFUeNrEV3tMm9cVP7Y/29gY/MBvg3klgFJGAnFeBUpok03NOhJeaVcSdVvGEu2fbdqmNm23bkmqRk1bbVm0PiKtTaVtSkLTh9SQlLY0CWSDpkugy8MmCY+AwRiwzbDBYJudc+FzP0e0+W+70pG/ex733Hvuub9zLPr9/gPAj/n5edDr9TA2NmbG6fJF9i3kuZEHIpEorvvbZ59hv7y9WCyGWCwGJpMJPB5PBrKykWJITp1O652Y8DE9fg0OEscGpIOl999fbjQaUEMEXq8Xbjid7ch/Guk8fPP4DtKBB8rLHXp9Gm5knjYRc7qcnyD/KaR/8YpCx3vWrllzZN26tRIJ7p4fmfYMKCkuLv380qXWf3Z0/AxZR77G6TMPlJftL161SiSMTFamXby6pGRz+8WLFZevXPkRsv4qdFyBix9ZuXKlZGYmzBh+v5+FXqvVsnlhYaE4Eo0cvnTpCydOW+5yWrdhw/oD+fkFEJqeWXJXDodDFolE/vLvq1ev08m55ORkkMvkLxcUFEimF40+bvkYOjo62HdJSQk8vOVh9p2fly/q6+v/QzAYvE+wpsRisbycnZUDZD/q8YA8SQ5qtYYJMdSQtDgvLPyWrH9g4EWplNtEMc2z2qyrZ2dnIRyewcTyQmdnJzz51K9h794nobu7G0ZGRpgsHA6D1WpdgTZFvFeZTFaabrPZF+Qz4Ha74bXXXofhYTc4nTfg6BtHYXJykskikTmyfxDNzFw0EimkU/Mhlkg42LZtKwSD00CbofuibOXlqmQV8Urws3vBsdQhtF+etxzm5ubg2Ftvo6MI7NjRwE7Ly1FX1NMTyOPkSUkKUiAn/DAYjeByuqC19VNYsWIFyOXyuBzvGRQKhSoeZwknj0SicTn9yBVJbJ6UlASRWJRFih9R1MWDiLg0ne5OIDAJKSkpCckQDE1BUVERONY4YCb8VcIEAgFIVipd/BxP0OsP+EEqk7I5hfps81loaHic8ABOHj8J1TXVkJK6sH4Aw45ZPinChy1veueUJzc3Vy10HJ5ZcIYRSdjQzVs3p6q3VlkMBsMUzZ0ul+n8hbaB3JxcGXM8NIQRM4AMo8ThtY16RhAOxOx1zKP89q2b7sYf78qg5Aqr1al/HB4exjBG4xSbj7GwCnkjuAjqvoo2U4K9eJRKxTEvno50bOnpIEaHc3MRmMbNa7Q6JC2TDQ4OEjK+RIgmordKBzt+sukTVC4lyFxqjI+PI6bGOhoe/34lTqd5/sxCZNRo34a5UKjRaJe0p2elUinP1lZXf5eumnfMEvZ085lXh9zuBsw3kVKpBAKgUCjEFjebTccf2bJlN12TcMFFx5Tp+rMftbzpGR19hGwVCiUCUAxfRwgTLRyzZ6Qf/fbmzT8nk7shk8K389H6ukNd3d31Pp+/gJho4EIYbDp34cLle+D0GNL36mtr1l3p6qqZnPxPLpaOWG5O1tXiVcXH29rbbgiVhSf+nw4x/J8Gt+/A8wn1eHEzhEz5FBF6MUhfUCbyNZfGc795NqEecxzHkIowBWkt0jJKIqRrSF20/DfV49qUlNRDaWm6bEoQGqHQNExMjPcj3u7F6d/vcZBdGo1mn1arsyoQvegcWFDI3jk1NfULlDcvVY9/l5WV9ZzRaEpYSaVKAaPRmInF4299fX1UHPYu4ZCO8edly5bv0el0CQJCRLPZnI848eGdOwO/QtYrwjveSk7NZgtrYYgI7sa8Y/E5bSg7O5u6iMeWcLwbkW8PYQCvfzfZbDaR3W4n8KhkJ0bAB6lU9qLVaouvcrG9HaFulBmkYQtTWlbG+LSx8fGJF/x+34nFfoqBT1qafr9eb2ATQkCZVMbsaAwhWimxehFkpqdniHw+30EspevoxEWIu3lSTA6iWawkg3cG4Qc/fAJ27twBHqzFM9Mh4OXYi2WhoYPfJKJVhclk1PPyZKUCmk+fhglEut7bt+H8ufNYSpOZTCaVgj5NT4mXyeHl5KtTU+PVRSvTwqOP1cMs1lRKDCpvKrwnXq7B2orO6K47aS6VSldiQsXlVpsNtm+vgxMnmjDTJdDYuCseGnbnWKX6B/qzOKwiHMd2I4sL1WotuFwuONN8BjZteghSMMF4oCFddBxXxrlEykkT7Cd8fqzTEpZz3rFxwNYIBPpMJraYzX2hUJAVeyHRm9y4cSOsdjiovYnzg6ir0aivfZW1KmdQYN/X18t6tp/sboR6PPmpd06xGs7LQxhF7GbHCDIlb751bKi0tNQkbEspuQgszBZzAsBgm+rbVlVl0Wo1rK3o7x/QII67N6xfr6B5b28vqFPVoEvTMbCg+sxhRKhGx6IxaP9H+217hj2XkiuKz+BgT08PKLDo84QlDFiVEfBoUa1Gc4hquODa/Cg7TLWWdKhVstms7DsJT5iTkwP2TDubX8fmz2K27KeejC8S4nffe78J25hqbEsS/qrwJ73cdYV67Q/qampqFqFQOOQnTjY149+XysLC+/BmE+0pch2fd0I0Gn0b8+GJu6sT99m5c/uwk/glprwMn8hCAR8dBe+odxb/kvzpwcpK+hsz+zVwqfyopeUlfyDQaDaZOYNBzxyOYAMwMT4xjfX8+fKyshf49y+ETEL4p+traw9fvXatyu0ezqONWSzmm5UVFe9/2trqvgdOh5B+ur2u7mD3l19WDQ25cygyGRnp1x+qrPzgQlvbmFD5vwIMAAZsT2nNzBrxAAAAAElFTkSuQmCC) no-repeat scroll 0 0;"].join(""))
}
dms.addRule("." + intextCls + "_btn_over", "background-position:0 -24px !important;");
bbl.preloadImages(skinPath, images)
},
showBubble: function(hookId) {
var rt = this.$root,
st = rt.settings,
hook = st.hooksMap[hookId],
hp = rt.helpers,
ed = rt.event.dom,
ut = rt.utils,
dmel = ut.dom.element,
node, rtb = rt.bubble,
cls = rtb.settings.cls,
b = rt.browser;
var data = hp.getHookData(hookId);
var pos = hook.bubble.pos = rt.bubble.adjustBubblePosition(hook, {
width: data.width + 2,
height: data.height + 41
});
if (hook.externalTag) {
pos.top += hook.orientationY == "T" ? 80 : -80;
var hookWidth = dmel.getActualWidth(hook.node);
pos.left += hook.orientationX == "L" ? hookWidth + 20 : -20
} else {
pos.top += hook.orientationY == "T" ? -5 : 5;
pos.left += hook.orientationX == "L" ? 30 : 0
}
if (hook.bubble.node && hook.bubble.node.parentNode) {
var parent = hook.bubble.node.parentNode;
parent.removeChild(hook.bubble.node)
}
node = hook.bubble.node = ut.dom.createDOMFragment({
tag: "div",
cls: st.baseClass,
parent: document.body,
style: {
display: "none"
},
innerHTML: this.renderBubble(data.width, data.height, hook)
});
var contentNode = dmel.$([cls, "content", hookId].join("_"));
if (contentNode) {
ed.bind(contentNode, {
event: "mouseenter",
data: {
hookId: hookId
},
listener: function(event) {
rt.event.fire("bubbleMouseover", {
hookId: hookId,
sender: event.domEvent.currentTarget || event.domEvent.srcElement
})
}
});
ed.bind(contentNode, {
event: "mouseleave",
data: {
hookId: hookId
},
listener: function(event) {
rt.event.fire("bubbleMouseout", {
hookId: hookId,
sender: event.domEvent.currentTarget || event.domEvent.srcElement
})
}
})
}
var bodyMain = dmel.$([cls, "body", hookId].join("_"));
if (bodyMain) {
ed.bind(bodyMain, {
event: "click",
data: {
hookId: hookId
},
listener: rtb.hookClick
})
}
var logoNode = dmel.$([cls, "logo", hookId].join("_"));
if (logoNode) {
ed.bind(logoNode, {
event: "click",
data: {
hookId: hookId
},
listener: function(event) {
rt.utils.dom.event.stop(event.domEvent);
if (st.homeUrl) {
window.open(st.homeUrl, "_blank")
}
}
})
}
var xBtn = dmel.$([cls, "x", hookId].join("_"));
if (xBtn) {
ed.bind(xBtn, {
event: "click",
data: {
hookId: hookId
},
listener: function() {
rt.event.fire("hideBubble", {
hookId: hookId,
xBtn: true
})
}
});
ed.bind(xBtn, {
event: "mouseover",
data: {
el: xBtn,
pos: "-15px -15px"
},
listener: this.setBackgroundPosition
});
ed.bind(xBtn, {
event: "mouseout",
data: {
el: xBtn,
pos: "-15px 0"
},
listener: this.setBackgroundPosition
})
}
var helpBtn = dmel.$([cls, "help", hookId].join("_"));
if (helpBtn) {
ed.bind(helpBtn, {
event: "click",
listener: function(event) {
rt.utils.dom.event.stop(event.domEvent);
if (st.helpUrl) {
window.open(st.helpUrl, "_blank")
}
}
});
ed.bind(helpBtn, {
event: "mouseover",
data: {
el: helpBtn,
pos: "0 -15px"
},
listener: this.setBackgroundPosition
});
ed.bind(helpBtn, {
event: "mouseout",
data: {
el: helpBtn,
pos: "0 0"
},
listener: this.setBackgroundPosition
})
}
var btnNode = dmel.$([cls, "btn", hookId].join("_"));
if (btnNode) {
ed.bind(btnNode, {
event: "mouseover",
listener: function(event) {
event.element.className = [st.baseClass, " ", cls, "_btn ", cls, "_btn_over"].join("")
}
});
ed.bind(btnNode, {
event: "mouseout",
listener: function(event) {
event.element.className = [st.baseClass, " ", cls, "_btn "].join("")
}
})
}
rt.bubble.afterBubbleRendered(bodyMain, data, hook);
hook.bubble.node.style.display = "block";
rt.event.fire("bubbleShowing", {
hookId: hookId
})
},
renderBubble: function(width, height, hook) {
var rt = this.$root,
hookId = hook.id,
st = rt.settings,
bh = rt.helpers.getHookBehavior(hookId),
data = rt.helpers.getHookData(hookId),
bst = rt.bubble.settings,
skst = this.settings;
var logo = {
url: bh.bubbleLogoUrl || false,
width: Math.min(bh.bubbleLogoWidth || 53, 120),
height: Math.min(bh.bubbleLogoHeight || 12, 25)
};
var html = '<div id="<%= intextCls %>_<%= hookId %>" class="<%= cls %>" style="position:absolute; top:<%= hook.bubble.pos.top %>px; left:<%= hook.bubble.pos.left %>px; width:<%= width+2 %>px; height:<%= height+41 %>px; z-index:<%= zIndex+3 %>;"> <%-- Box --%> <div id="<%= intextCls %>_content_<%= hookId %>" class="<%= cls %>" style="position:absolute; top:<%= oY == \'T\' ? 0 : 8 %>px; left:0; width:<%= width+2 %>px; height:<%= height+33 %>px; box-shadow:0 0 8px 0 rgba(0, 0, 0, 0.25); -moz-box-shadow:0 0 8px 0 rgba(0, 0, 0, 0.25); -webkit-box-shadow:0 0 8px 0 rgba(0, 0, 0, 0.25);"> <%-- Header --%> <div class="<%= cls %>" style="position:absolute; width:<%= width %>px; height:33px; left:0; <%= oY == \'T\' ? \'bottom\' : \'top\' %>:0; z-index:1; background-color:#f1f1f2; border-<%= oY == \'T\' ? \'bottom\' : \'top\' %>:2px solid <%= themeColor %>; border-left:1px solid #a7a9ab; border-right:1px solid #a7a9ab;"> <% if (bh.favicon){ %><div class="<%= cls %>" style="position:absolute; width:16px; height:16px; left:14px; <%= oY == \'T\' ? \'bottom\' : \'top\' %>:8px; background:url(<%= bh.favicon %>) no-repeat scroll 0 0 transparent;"></div><% } %> <% if (bh.bubbleLogoUrl){ %> <div id="<%= intextCls %>_logo_<%= hookId %>" class="<%= cls %>" style="position:absolute; width:<%= bh.bubbleLogoWidth %>px; height:<%= bh.bubbleLogoHeight %>px; right:56px; top:<%= parseInt((33 - bh.bubbleLogoHeight) / 2) %>px; cursor:pointer; font-size:1px; background-image:url(<%= bh.bubbleLogoUrl %>)"></div> <% } else { %> <div id="<%= intextCls %>_logo_<%= hookId %>" class="<%= cls %>" style="position:absolute; width:53px; height:12px; right:56px; <%= oY == \'T\' ? \'bottom\' : \'top\' %>:9px; cursor:pointer; font-size:1px; <% if (b.IE || bst.oldFF){ %>background:url(<%= skinPath %>logo.png) no-repeat scroll 0 0 transparent;<% } %>"> <% if (!b.IE && !bst.oldFF){ %> <svg version="1.1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" x="0px" y="0px" width="53px" height="12px" viewBox="0 0 636 144" enable-background="new 0 0 636 144" xml:space="preserve"> <g> <!-- dot (first) --> <path id="<%= intextCls %>_logo_dot_<%= hookId %>_1" fill="<%= bh.theme == \'def\' ? \'#208CE5\' : themeColor %>" d="M16.918,24.865c5.848,0,10.57-4.735,10.57-10.583s-4.722-10.57-10.57-10.57 S6.334,8.434,6.334,14.282S11.07,24.865,16.918,24.865"/> <!-- in --> <path fill="#003366" d="M88.085,43.784H77.024c-17.149,0-31.181,14.031-31.181,31.182v34.796 c0,0.218,0.016,0.415,0.027,0.618v5.185c0,5.71-4.672,10.382-10.382,10.382h-0.467c-5.71,0-10.382-4.672-10.382-10.382V92.608 h0.015V45.889v-0.025c0-1.124-0.885-2.033-2.01-2.08h-11.49c-1.09,0.047-1.949,0.907-1.986,1.996v46.828h0.04 c-0.015,0.355-0.04,0.707-0.04,1.066v22.246c0,14.031,11.479,25.512,25.511,25.512h1.151c14.031,0,25.511-11.48,25.511-25.512 v-5.466v-4.62v-28.89c0.082-9.872,8.159-17.948,18.031-17.948h6.366c9.871,0,17.948,8.076,18.042,17.948v28.89v4.62v28.873 c0.013,0.023,0.013,0.034,0.013,0.048c0,1.111,0.883,2.008,1.983,2.057h11.505c1.077-0.036,1.936-0.887,1.985-1.973v-27.966v-5.659 V74.966C119.267,57.815,105.234,43.784,88.085,43.784"/> <!-- f (part) --> <path fill="#003366" d="M155.069,56.972v82.643c-0.072,0.992-0.886,1.78-1.903,1.818h-11.014 c-1.062-0.038-1.912-0.897-1.912-1.962c0-0.024,0-0.048-0.023-0.073V34.456c0.716-17.064,14.923-30.744,32.179-30.744h8.536 c0.025,0,0.038,0.011,0.06,0.011c1.053,0,1.915,0.849,1.974,1.901v11.037c-0.035,1.016-0.85,1.844-1.878,1.889h-8.692 c-9.509,0-17.327,7.75-17.327,17.268v6.301V56.972z"/> <!-- f (part) --> <path fill="#003366" d="M151.99,59.104h28.873c0.023-0.012,0.034-0.012,0.047-0.012 c1.111,0,2.008-0.884,2.057-1.984V45.604c-0.036-1.078-0.887-1.938-1.973-1.986h-27.965"/> <!-- o --> <path fill="#003366" d="M276.24,107.925h0.158V76.608c-0.37-18.164-15.248-32.825-33.494-32.825 h-16.756v0.022c-17.875,0.431-32.322,14.924-32.679,32.803h-0.026v31.316c0,18.213,14.601,33.064,32.705,33.496v0.012h16.589h0.021 h0.146C261.304,141.349,276.24,126.354,276.24,107.925 M208.93,107.925L208.93,107.925V77.289c0-9.914,8.096-18.02,18.021-18.02 h15.953c9.946,0,18.02,8.106,18.02,18.02v30.636h-0.167c0,9.949-8.074,18.021-17.999,18.021h-15.807 C217.026,125.946,208.93,117.874,208.93,107.925"/> <!-- l --> <path fill="#003366" d="M312.844,139.376L312.844,139.376c0,1.064-0.798,1.938-1.829,2.045h-11.816 c-1.027-0.107-1.837-0.98-1.837-2.045h-0.013V5.769h0.013c0-1.135,0.908-2.033,2.031-2.057h11.432 c1.124,0.024,2.019,0.922,2.019,2.057V139.376z"/> <!-- dot (second) --> <path id="<%= intextCls %>_logo_dot_<%= hookId %>_2" fill="<%= bh.theme == \'def\' ? \'#208CE5\' : themeColor %>" d="M341.662,24.865c5.848,0,10.57-4.735,10.57-10.583s-4.723-10.57-10.57-10.57 s-10.584,4.722-10.584,10.57S335.814,24.865,341.662,24.865"/> <!-- in (second) --> <path fill="#003366" d="M412.829,43.784h-11.061c-17.149,0-31.181,14.031-31.181,31.182v34.796 c0,0.218,0.016,0.415,0.026,0.618v5.185c0,5.71-4.672,10.382-10.382,10.382h-0.468c-5.71,0-10.382-4.672-10.382-10.382V92.608 h0.016V45.723v-0.025c0-1.123-0.885-2.033-2.01-2.08h-11.49c-1.091,0.047-1.949,0.908-1.986,1.996v46.994h0.04 c-0.015,0.355-0.04,0.707-0.04,1.066v22.246c0,14.031,11.479,25.512,25.512,25.512h1.15c14.031,0,25.512-11.48,25.512-25.512 v-5.466v-4.62v-28.89c0.082-9.872,8.158-17.948,18.029-17.948h6.367c9.871,0,17.947,8.076,18.041,17.948v28.89v4.62v28.873 c0.014,0.023,0.014,0.034,0.014,0.048c0,1.111,0.883,2.008,1.982,2.057h11.506c1.076-0.036,1.936-0.887,1.984-1.973v-27.966v-5.659 V74.966C444.01,57.815,429.979,43.784,412.829,43.784"/> <!-- k --> <path fill="#003366" d="M480.277,139.376L480.277,139.376V91.735h0.146h9.255l40.656,48.766 c0.599,0.549,1.15,0.906,1.841,0.932h16.073c0.882-0.025,2.869-0.322,1.794-2.056l-0.013-0.024l-47.58-56.777l44.599-36.815 c0.015-0.049,0.015-0.049,0.036-0.073c1.066-1.734-0.886-2.032-1.78-2.069H527.08c-0.621,0.024-1.15,0.324-1.666,0.791 l-36.812,31.075h-8.325V5.769c0-1.135-0.896-2.033-2.02-2.057h-11.422c-1.124,0.024-2.033,0.922-2.033,2.057v133.607 c0,1.064,0.803,1.938,1.844,2.045h11.802C479.476,141.313,480.277,140.44,480.277,139.376"/> <!-- s --> <path fill="#003366" d="M603.208,84.782H577.99c-6.91-0.114-12.508-5.785-12.508-12.783 c0-6.996,5.598-12.895,12.508-12.895h39.271c1.146,0,2.08-0.959,2.08-2.111v0.191V45.752v-0.037c0-1.164-0.935-2.097-2.08-2.097 H577.99c-15.451,0-28.008,12.73-28.008,28.381c0,15.651,12.557,28.381,28.008,28.27h24.252c6.911,0.111,12.508,5.812,12.508,12.795 c0,6.996-5.597,12.896-12.508,12.896H591.56l0.001-0.014h-28.874c-0.022,0.014-0.034,0.014-0.047,0.014 c-1.11,0-2.007,0.896-2.056,2.01v11.449c0.035,1.092,0.886,1.963,1.973,2.014h0.225h27.74h12.224 c15.209-0.279,27.491-12.9,27.491-28.369C630.236,97.737,618.191,85.202,603.208,84.782"/> </g> </svg> <% } %> </div> <% } %> <div class="<%= cls %> <%= intextCls %>_bg" id="<%= intextCls %>_help_<%= hookId %>" style="position:absolute; width:15px; height:15px; right:29px; <%= oY == \'T\' ? \'bottom\' : \'top\' %>:7px; display:block; background-position:0 0; cursor:pointer; font-size:1px;"></div> <div class="<%= cls %> <%= intextCls %>_bg" id="<%= intextCls %>_x_<%= hookId %>" style="position:absolute; width:15px; height:15px; right:13px; <%= oY == \'T\' ? \'bottom\' : \'top\' %>:7px; background-position:-15px 0; cursor:pointer; font-size:1px;"></div> </div> <%-- Body --%> <div id="<%= intextCls %>_body_<%= hookId %>" class="<%= cls %> <%= intextCls %>_bodyMain" style="position:absolute; <%= oY == \'T\' ? \'top\' : \'bottom\' %>:0px; left:0; width:<%= width %>px; height:<%= height %>px; z-index:2; background-color:#ffffff; cursor: pointer; border-<%= oY == \'T\' ? \'top\' : \'bottom\' %>:1px solid #a7a9ab; border-left:1px solid #a7a9ab; border-right:1px solid #a7a9ab;"> <%= rt.bubble.renderAdsContent(hook, data) %> </div> </div> <% if (!hook.externalTag){ %> <%-- Tail --%> <div class="<%= cls %>" style="position:absolute; <%= oY == \'T\' ? \'bottom\' : \'top\' %>:0; <%= oX == \'L\' ? \'right\' : \'left\' %>:15px; width:15px; height:8px; font-size:1px; <% if (b.IE || bst.oldFF){ %>background:url(<%= skinPath %>tail.png) no-repeat scroll <%= tailBgLeft %>px <%= tailBgTop %>px transparent;<% } %>"> <% if (!b.IE && !bst.oldFF){ %> <svg version="1.0" xmlns="http://www.w3.org/2000/svg" width="15px" height="8px" viewBox="0 0 30 16" preserveAspectRatio="xMidYMid meet" style="position:absolute; font-size:1px;"> <g transform="translate(0,16) scale(0.1,-0.1)" fill="<%= themeColor %>" stroke="none"> <% if (oY == \'T\'){ %> <path d="M37 138 c11 -13 30 -42 42 -65 22 -44 54 -73 81 -73 20 0 52 34 75 80 10 19 27 45 38 57 l20 23 -138 0 -138 0 20 -22z"/> <% } else { %> <path d="M109 143 c-9 -10 -31 -43 -49 -73 -18 -30 -38 -58 -44 -62 -6 -4 51 -8 126 -8 l137 0 -22 36 c-73 118 -114 147 -148 107z"/> <% } %> </g> </svg> <% } %> </div> <% } %></div>';
return rt.utils.VeST(html, {
rt: rt,
st: st,
bh: bh,
b: rt.browser,
hookId: hookId,
hook: hook,
data: data,
intextCls: bst.cls,
cls: st.baseClass,
bst: bst,
width: width,
height: height,
oX: hook.orientationX,
oY: hook.orientationY,
zIndex: st.baseZIndex + 100,
logo: logo,
themeColor: rt.products[hook.type].settings.themes.color[bh.theme],
skinPath: rt.bubble.getSkinPath(this.$id),
tailBgLeft: skst.tailMap[bh.theme],
tailBgTop: hook.orientationY == "T" ? -8 : 0
}, hookId + "brand", true)
},
setBackgroundPosition: function(event) {
event.data.el.style.backgroundPosition = event.data.pos
}
}, {
settings: {
rv: 1,
tailMap: {
def: 0,
lightBlue: -15,
green: -30,
orange: -45,
red: -60,
pink: -75,
purple: -90
}
}
}, true);
skins.brand.bind({
event: "brandBubbleMouseover",
listener: {
bubleMouseover: function(event) {
var boxShadow = this.$root.utils.dom.style.supports("boxShadow");
if (boxShadow) {
event.data.sender.style[boxShadow] = "0 0 8px 0 rgba(0, 0, 0, 0.5)"
}
}
}
});
skins.brand.bind({
event: "brandBubbleMouseout",
listener: {
bubleMouseout: function(event) {
var boxShadow = this.$root.utils.dom.style.supports("boxShadow");
if (boxShadow) {
event.data.sender.style[boxShadow] = "0 0 8px 0 rgba(0, 0, 0, 0.25)"
}
}
}
});
skins.$create("less", {
init: function() {
var rtb = this.$root.bubble,
skinPath = rtb.getSkinPath(this.$id);
rtb.preloadImages(skinPath, "x")
},
showBubble: function(hookId) {
var rt = this.$root,
ut = rt.utils,
dmel = ut.dom.element,
st = rt.settings,
hook = st.hooksMap[hookId],
data = rt.helpers.getHookData(hookId),
cls = rt.bubble.settings.cls,
ed = rt.event.dom;
var pos = hook.bubble.pos = rt.bubble.adjustBubblePosition(hook, {
width: data.width + 11,
height: data.height + 22
});
if (hook.externalTag) {
pos.top += hook.orientationY == "T" ? 60 : -60;
var hookWidth = dmel.getActualWidth(hook.node);
pos.left += hook.orientationX == "L" ? hookWidth + 20 : -20
}
if (hook.bubble.node && hook.bubble.node.parentNode) {
var parent = hook.bubble.node.parentNode;
parent.removeChild(hook.bubble.node)
}
hook.bubble.node = ut.dom.createDOMFragment({
tag: "div",
cls: st.baseClass,
parent: document.body,
style: {
display: "none"
},
innerHTML: this.renderBubble(data.width, data.height, hook)
});
var bubbleNode = ut.dom.element.$([cls, "content", hookId].join("_"));
if (bubbleNode) {
ed.bind(bubbleNode, {
event: "mouseenter",
data: {
hookId: hookId
},
listener: function(event) {
rt.event.fire("bubbleMouseover", {
hookId: hookId,
sender: event.domEvent.currentTarget || event.domEvent.srcElement
})
}
});
ed.bind(bubbleNode, {
event: "mouseleave",
data: {
hookId: hookId
},
listener: function(event) {
rt.event.fire("bubbleMouseout", {
hookId: hookId,
sender: event.domEvent.currentTarget || event.domEvent.srcElement
})
}
})
}
var bodyMain = ut.dom.element.$([cls, "body", hookId].join("_"));
if (bodyMain) {
ed.bind(bodyMain, {
event: "click",
data: {
hookId: hookId
},
listener: rt.bubble.hookClick
})
}
var xNode = ut.dom.element.$([cls, "x", hookId].join("_"));
if (xNode) {
ed.bind(xNode, {
event: "click",
data: {
hookId: hookId
},
listener: function() {
rt.event.fire("hideBubble", {
hookId: hookId,
xBtn: true
})
}
})
}
rt.bubble.afterBubbleRendered(bodyMain, data, hook);
hook.bubble.node.style.display = "block";
rt.event.fire("bubbleShowing", {
hookId: hookId
})
},
renderBubble: function(width, height, hook) {
var rt = this.$root,
st = rt.settings,
bst = rt.bubble.settings,
cls = st.baseClass,
hookId = hook.id,
b = rt.browser,
skinPath = rt.bubble.getSkinPath(this.$id),
data = rt.helpers.getHookData(hookId);
var html = '<div id="<%= intextCls %>_<%= hookId %>" class="<%= cls %>" style="<%= abs %> width:<%= width+11 %>px; height:<%= height+22 %>px; top:<%= hook.bubble.pos.top %>px; left:<%= hook.bubble.pos.left %>px; z-index:<%= zIndex+3 %>;"> <% if (!hook.externalTag){ %> <div class="<%= cls %> <%= intextCls %>_head" style="width:100%; height:22px; <%= abs %> left:0; z-index:<%= zIndex+4 %>; <%= (oY == \'T\') ? \'bottom:0;\' : \'top:0;\' %>" > <div id="<%= intextCls %>_x_<%= hookId %>" class="<%= cls %> <%= intextCls %>_x" style="<%= abs %> width:22px; height:22px; background:transparent url(<%= skinPath %>x.png) no-repeat scroll 0 0; cursor:pointer; top:<%= (oY == \'T\') ? \'2px\' : 0 %>; <%= (oX == \'L\') ? \'right:0\' : \'left:0\' %>;"></div> </div> <% } %> <div id="<%= intextCls %>_content_<%= hookId %>" class="<%= cls %> <%= intextCls %>_body" style="<%= abs%> width:<%= width %>px; height:<%= height %>px; zindex:<%= zIndex+3 %>; top:<%= (oY == \'T\') ? 0 : \'22px\' %>; <%= (oX == \'L\') ? \'left:0\' : \'left:11px;\' %>; "> <div id="<%= intextCls %>_body_<%= hookId %>" class="<%= cls %> <%= intextCls %>_bodyMain" style="<%= abs %> top:0; left:0; width:<%= width %>px; height:<%= height %>px; cursor:pointer; color:#000000;"> <%= rt.bubble.renderAdsContent(hook, data) %> </div> </div> </div>';
return rt.utils.VeST(html, {
rt: rt,
hookId: hookId,
hook: hook,
data: data,
intextCls: bst.cls,
cls: st.baseClass,
width: width,
height: height,
oX: hook.orientationX,
oY: hook.orientationY,
abs: "position:absolute;",
zIndex: st.baseZIndex + 100,
skinPath: skinPath
}, hookId + "less", true)
}
}, {
settings: {}
}, true);
event.fire("main")
} catch (ex) {
if (typeof $root == "object" && $root.logger && $root.logger.error) {
$root.logger.error("CatchAll. Exception: " + ex.message, window)
}
}
})() |