| | |
| | | this.dom = document.getElementById ? true : false; |
| | | this.dom2 = (document.addEventListener && document.removeEventListener); |
| | | |
| | | this.ie = (document.all && !window.opery); |
| | | this.ie = (document.all && !window.opera); |
| | | this.ie4 = (this.ie && !this.dom); |
| | | this.ie5 = (this.dom && this.appver.indexOf('MSIE 5')>0); |
| | | this.ie8 = (this.dom && this.appver.indexOf('MSIE 8')>0); |
| | |
| | | (this.ie && this.win && this.vendver >= 5.5) || this.safari); |
| | | this.opacity = (this.mz || (this.ie && this.vendver >= 5.5 && !this.opera) || (this.safari && this.vendver >= 100)); |
| | | this.cookies = navigator.cookieEnabled; |
| | | |
| | | |
| | | // test for XMLHTTP support |
| | | this.xmlhttp_test = function() |
| | | { |
| | |
| | | this.xmlhttp = (window.XMLHttpRequest || (window.ActiveXObject && activeX_test())); |
| | | return this.xmlhttp; |
| | | }; |
| | | |
| | | |
| | | // set class names to html tag according to the current user agent detection |
| | | // this allows browser-specific css selectors like "html.chrome .someclass" |
| | | this.set_html_class = function() |
| | |
| | | |
| | | if (bw.mac && e) { |
| | | opcode += (e.metaKey && CONTROL_KEY) + (e.shiftKey && SHIFT_KEY); |
| | | return opcode; |
| | | return opcode; |
| | | } |
| | | if (e) { |
| | | opcode += (e.ctrlKey && CONTROL_KEY) + (e.shiftKey && SHIFT_KEY); |
| | |
| | | get_mouse_pos: function(e) |
| | | { |
| | | if (!e) e = window.event; |
| | | var mX = (e.pageX) ? e.pageX : e.clientX; |
| | | var mY = (e.pageY) ? e.pageY : e.clientY; |
| | | var mX = (e.pageX) ? e.pageX : e.clientX, |
| | | mY = (e.pageY) ? e.pageY : e.clientY; |
| | | |
| | | if (document.body && document.all) { |
| | | mX += document.body.scrollLeft; |
| | |
| | | |
| | | if (!p.object._rc_events) |
| | | p.object._rc_events = []; |
| | | |
| | | |
| | | var key = p.event + '*' + p.method; |
| | | if (!p.object._rc_events[key]) |
| | | p.object._rc_events[key] = function(e){ return p.object[p.method](e); }; |
| | |
| | | this._events = {}; |
| | | if (!this._events[evt]) |
| | | this._events[evt] = []; |
| | | |
| | | |
| | | var e = {func:func, obj:obj ? obj : window}; |
| | | this._events[evt][this._events[evt].length] = e; |
| | | }, |
| | |
| | | { |
| | | if (typeof obj == 'undefined') |
| | | obj = window; |
| | | |
| | | |
| | | for (var h,i=0; this._events && this._events[evt] && i < this._events[evt].length; i++) |
| | | if ((h = this._events[evt][i]) && h.func == func && h.obj == obj) |
| | | this._events[evt][i] = null; |
| | |
| | | ret = h.func.call ? h.func.call(h.obj, e) : h.func(e); |
| | | else if (typeof h.obj[h.func] == 'function') |
| | | ret = h.obj[h.func](e); |
| | | |
| | | |
| | | // cancel event execution |
| | | if (typeof ret != 'undefined' && !ret) |
| | | break; |
| | |
| | | function rcube_layer(id, attributes) |
| | | { |
| | | this.name = id; |
| | | |
| | | |
| | | // create a new layer in the current document |
| | | this.create = function(arg) |
| | | { |
| | | var l = (arg.x) ? arg.x : 0; |
| | | var t = (arg.y) ? arg.y : 0; |
| | | var w = arg.width; |
| | | var h = arg.height; |
| | | var z = arg.zindex; |
| | | var vis = arg.vis; |
| | | var parent = arg.parent; |
| | | var obj; |
| | | var l = (arg.x) ? arg.x : 0, |
| | | t = (arg.y) ? arg.y : 0, |
| | | w = arg.width, |
| | | h = arg.height, |
| | | z = arg.zindex, |
| | | vis = arg.vis, |
| | | parent = arg.parent, |
| | | obj = document.createElement('DIV'); |
| | | |
| | | obj = document.createElement('DIV'); |
| | | |
| | | with(obj) { |
| | | with (obj) { |
| | | id = this.name; |
| | | with(style) { |
| | | with (style) { |
| | | position = 'absolute'; |
| | | visibility = (vis) ? (vis==2) ? 'inherit' : 'visible' : 'hidden'; |
| | | left = l+'px'; |
| | |
| | | width = w.toString().match(/\%$/) ? w : w+'px'; |
| | | if (h) |
| | | height = h.toString().match(/\%$/) ? h : h+'px'; |
| | | if(z) zIndex = z; |
| | | if (z) |
| | | zIndex = z; |
| | | } |
| | | } |
| | | |
| | |
| | | }; |
| | | |
| | | // create new layer |
| | | if(attributes != null) { |
| | | if (attributes != null) { |
| | | this.create(attributes); |
| | | this.name = this.elm.id; |
| | | } |
| | | else // just refer to the object |
| | | this.elm = document.getElementById(id); |
| | | |
| | | if(!this.elm) |
| | | if (!this.elm) |
| | | return false; |
| | | |
| | | |
| | |
| | | function rcube_clone_object(obj) |
| | | { |
| | | var out = {}; |
| | | |
| | | |
| | | for (var key in obj) { |
| | | if (obj[key] && typeof obj[key] == 'object') |
| | | out[key] = clone_object(obj[key]); |
| | | else |
| | | out[key] = obj[key]; |
| | | } |
| | | |
| | | |
| | | return out; |
| | | }; |
| | | |
| | |
| | | |
| | | return obj; |
| | | } |
| | | }; |
| | | } |