
var dom = {

  elById : function(id) {
    return (typeof id != "string") ? id : (document["getElementById"] ? document.getElementById(id) : false );
  },
  
  elsByTag : function(t, p) {
    var p = p ? dom.elById(p) : document;
    return p["getElementsByTagName"] ? p.getElementsByTagName(t) : [];
  },
  
  elByTag : function(t, p) {
    var els = dom.elsByTag(t, p);
    return els.length ? els[0] : 0;
  },
  
  parentByTag : function(t, el) {
    var el = dom.elById(el);
    if (el.parentNode) {
      var p = el.parentNode;
      if (p.tagName.toLowerCase() == t) {
        return p;
      }
      return dom.parentByTag(t, p);
    }
    return 0;
  },
  
  parentByClass : function(c, el) {
    var el = dom.elById(el);
    if (el.parentNode) {
      var p = el.parentNode;
      if (dom.hasClass(p, c)) {
        return p;
      }
      return dom.parentByClass(c, p);
    }
    return 0;
  },
  
  elsByClass : function(c, p, t) {
    var els = t ? dom.elsByTag(t, p) : dom.elsByTag("*", p);
    var re = new RegExp("(^|\\s)" + c + "(\\s|$)");
    var r = [];
    for (var i = 0, i_max = els.length; i < i_max; i++) {
      if (els[i].className && els[i].className.match(re)) {
        r[r.length] = els[i];
      }
    }
    return r;
  },
  
  elByClass : function(c, p, t) {
    var els = dom.elsByClass(c, p, t);
    return els.length ? els[0] : 0;
  },
  
  hasClass : function(el, c) {
    var re = new RegExp("(^|\\s)" + c + "(\\s|$)");
    return (el.className && el.className.match(re)) ? 1 : 0;
  },

  addClass : function(el, c) {
    if (!dom.hasClass(el, c)) {
      el.className += el.className ? " " + c : c;
    }
  },

  elsByAttr : function(a_name, a, p) {
    var els = dom.elsByTag("*", p);
    var esc_a = a.replace(/([\.])/g, '\\$1');
    var re = new RegExp("(^|\\s)" + esc_a + "(\\s|$)");
    var r = [];
    var cur_a;
    for (var i = 0, i_max = els.length; i < i_max; i++) {
      if ((cur_a = els[i].getAttribute(a_name)) && cur_a.match(re)) {
        r[r.length] = els[i];
      }
    }
    return r;
  },

  elByAttr : function(a_name, a, p) {
    var els = dom.elsByAttr(t, p);
    return els.length ? els[0] : 0;
  },
  
  elsByPath : function(path, p) {
    var p = p ? dom.elById(p) : document;
    var parts = path.split(" ");
    var part = parts.shift();
    var rest = parts.join(" ");
    var m;
    var r = [];
    var sub_r;
    var els = [];
    if (m = part.match(/^[\.](.*)$/)) {/* .foo */
      var els = dom.elsByClass(m[1], p);
    }
    else if (m = part.match(/^[\#](.*)$/)) {/* #foo */
      var els = [dom.elById(m[1])];
    }
    else if (m = part.match(/^([^\.]+)\.(.*)$/)) {/* foo.bar */
      var els = dom.elsByClass(m[2], p, m[1]);
    }
    else {/* foo */
      var els = dom.elsByTag(part, p);
    }
    if (rest) {
      for (var i = 0, i_max = els.length; i < i_max; i++) {
        r.append(dom.elsByPath(rest, els[i]));
      }
    }
    else {
      r = els;
    }
    return r;
  },
  
  elByPath : function(path, p) {
    var els = dom.elsByPath(path, p);
    return els.length ? els[0] : 0;
  },
  
  attrVal : function(el, a_name) {
  	return(el && el["getAttribute"]) ? el.getAttribute(a_name) : false;
  },
  
  setEl : function(id, val) {
    var el = dom.elById(id);
    if (el) el.innerHTML = val;
  },
  
  appendEls : function(id, els) {
    var el = dom.elById(id);
    if (el) {
      for (var i = 0; i < els.length; i++) {
        el.appendChild((els[i].nodeType == 3) ? document.createTextNode(els[i].nodeValue) : els[i]);
      }
    }
  },

  toggleEl : function(id) {
    var el = dom.elById(id);
    el.style.display = (el.style.display == "none") ? "" : "none";
    window.focus();
  },
  
  removeEl : function(id) {
    var el = dom.elById(id);
    if (el) el.parentNode.removeChild(el);
  },
  
  getId : function(el) {
    var el = dom.elById(el);
    if (!el) return 0;
    if (el.id) return el.id;
    if (!el.dom_id) {
      var pos = 0;
      if (p = el.parentNode) {
        var cn = p.childNodes;
        while (cn[pos] != el) {
          pos++;
        }
      }
      el.dom_id = p ? dom.getId(p) + '.' + pos : pos;
    }
    return el.dom_id;
  },
  
  event_registry : {'count' : 0},
  
  addEvent : function(el, e_type, fnc) {
    var el = dom.elById(el);
    if (!el || (typeof el != "object")) return 0;
    /* dom_id */
    var dom_id = dom.getId(el);
    /* fnc key */
    var fnc_key = escape(dom_id + e_type + fnc);
    /* already registered ? */
    if (dom.event_registry[fnc_key]) {
      if (dom.event_registry[fnc_key]["el"] == el) return 1;
      /* el changed, unregister */
      dom.removeEvent(el, e_type, fnc);
    }
    /* register */
    dom.event_registry[fnc_key] = { "el" : el, "e_type" : e_type, "fnc" : fnc };
    dom.event_registry.count++;
    /* add handler */
    if (el.addEventListener) el.addEventListener(e_type, fnc, false);
    else if (el.attachEvent) el.attachEvent('on' + e_type, fnc);
    else {
      var cur_fnc = el['on' + e_type];
      el['on' + e_type] = (typeof old_fnc == 'function') ? function() { cur_fnc(); fnc();} : fnc;
    }
  },
  
  removeEvent : function(el, e_type, fnc) {
    var el = dom.elById(el);
    if (!el || (typeof el != "object")) return 0;
    var dom_id = dom.getId(el);
    var fnc_key = escape(dom_id + e_type + fnc);
    if (!dom.event_registry[fnc_key]) return 0;
    var old_el = dom.event_registry[fnc_key]["el"];
    var old_fnc = dom.event_registry[fnc_key]["fnc"];
    if (old_el['removeEventListener']) {
      try {
        old_el.removeEventListener(e_type, old_fnc, false);
      } catch (e) {};
    }
    else if (old_el['detachEvent']) {
      try {
        old_el.detachEvent('on' + e_type, old_fnc); 
      } catch (e) {};
    }
    else try {
      old_el['on' + e_type] = null;
    } catch (e) {};
    dom.event_registry.fnc_key = null;
    dom.event_registry.count--;
  },
  
  cancelEvent : function(e) {
    if (e.preventDefault) {
      e.preventDefault();
      e.stopPropagation();
    }
    else {
      e.cancelBubble = true;
      e.returnValue = false;
    }
  },
  
  getEventPos : function(event) {
    var x, y;
    try {
      x = (event && event.pageX) ? event.pageX : ((event && event.x) ? event.x : 0);
      y = (event && event.pageY) ? event.pageY : ((event && event.y) ? event.y : 0);
    	var ua = navigator.userAgent.toLowerCase();
    	if(document.body && document.body.scrollTop && (ua.indexOf("msie") != -1) && (ua.indexOf("opera")==-1)){
    		y += document.body.scrollTop;
    	}
      else if(document.documentElement && document.documentElement.scrollTop && (ua.indexOf("msie") != -1) && (ua.indexOf("opera")==-1)){
    		y += document.documentElement.scrollTop;
      }
    } catch(e){}
    return {'x' : x,  'y' : y};
  },
  
  elPos : function(el) {
    var el = dom.elById(el);
    var r = {'x' : el.offsetLeft - el.scrollLeft, 'y' : el.offsetTop - el.scrollTop };
    if (el.offsetParent) {
      var sub_r = dom.elPos(el.offsetParent);
      r = { 'x' : r.x + sub_r.x, 'y' : r.y + sub_r.y };
    }
    return r;
  }
  
};
