src/cm/media/js/lib/yui/yui3.0.0/build/dom/dom-base-debug.js
author raph
Mon, 23 Nov 2009 15:14:29 +0100
changeset 0 40c8f766c9b8
permissions -rw-r--r--
import from internal svn r 4007
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
0
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
     1
/*
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
     2
Copyright (c) 2009, Yahoo! Inc. All rights reserved.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
     3
Code licensed under the BSD License:
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
     4
http://developer.yahoo.net/yui/license.txt
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
     5
version: 3.0.0
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
     6
build: 1549
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
     7
*/
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
     8
YUI.add('dom-base', function(Y) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
     9
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    10
(function(Y) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    11
/** 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    12
 * The DOM utility provides a cross-browser abtraction layer
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    13
 * normalizing DOM tasks, and adds extra helper functionality
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    14
 * for other common tasks. 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    15
 * @module dom
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    16
 * @submodule dom-base
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    17
 *
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    18
 */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    19
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    20
/**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    21
 * Provides DOM helper methods.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    22
 * @class DOM
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    23
 *
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    24
 */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    25
var NODE_TYPE = 'nodeType',
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    26
    OWNER_DOCUMENT = 'ownerDocument',
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    27
    DEFAULT_VIEW = 'defaultView',
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    28
    PARENT_WINDOW = 'parentWindow',
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    29
    TAG_NAME = 'tagName',
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    30
    PARENT_NODE = 'parentNode',
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    31
    FIRST_CHILD = 'firstChild',
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    32
    PREVIOUS_SIBLING = 'previousSibling',
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    33
    NEXT_SIBLING = 'nextSibling',
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    34
    CONTAINS = 'contains',
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    35
    COMPARE_DOCUMENT_POSITION = 'compareDocumentPosition',
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    36
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    37
    documentElement = document.documentElement,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    38
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    39
    re_tag = /<([a-z]+)/i;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    40
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    41
Y.DOM = {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    42
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    43
     * Returns the HTMLElement with the given ID (Wrapper for document.getElementById).
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    44
     * @method byId         
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    45
     * @param {String} id the id attribute 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    46
     * @param {Object} doc optional The document to search. Defaults to current document 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    47
     * @return {HTMLElement | null} The HTMLElement with the id, or null if none found. 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    48
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    49
    byId: function(id, doc) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    50
        doc = doc || Y.config.doc;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    51
        // TODO: IE Name
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    52
        return doc.getElementById(id);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    53
    },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    54
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    55
    // @deprecated
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    56
    children: function(node, tag) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    57
        var ret = [];
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    58
        if (node) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    59
            tag = tag || '*';
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    60
            ret = Y.Selector.query('> ' + tag, node); 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    61
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    62
        return ret;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    63
    },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    64
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    65
    // @deprecated
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    66
    firstByTag: function(tag, root) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    67
        var ret;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    68
        root = root || Y.config.doc;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    69
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    70
        if (tag && root.getElementsByTagName) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    71
            ret = root.getElementsByTagName(tag)[0];
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    72
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    73
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    74
        return ret || null;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    75
    },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    76
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    77
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    78
     * Returns the text content of the HTMLElement. 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    79
     * @method getText         
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    80
     * @param {HTMLElement} element The html element. 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    81
     * @return {String} The text content of the element (includes text of any descending elements).
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    82
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    83
    getText: (documentElement.textContent !== undefined) ?
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    84
        function(element) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    85
            var ret = '';
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    86
            if (element) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    87
                ret = element.textContent;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    88
            }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    89
            return ret || '';
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    90
        } : function(element) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    91
            var ret = '';
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    92
            if (element) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    93
                ret = element.innerText;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    94
            }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    95
            return ret || '';
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    96
        },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    97
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    98
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    99
     * Sets the text content of the HTMLElement. 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   100
     * @method setText         
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   101
     * @param {HTMLElement} element The html element. 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   102
     * @param {String} content The content to add. 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   103
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   104
    setText: (documentElement.textContent !== undefined) ?
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   105
        function(element, content) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   106
            if (element) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   107
                element.textContent = content;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   108
            }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   109
        } : function(element, content) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   110
            if (element) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   111
                element.innerText = content;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   112
            }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   113
        },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   114
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   115
    /*
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   116
     * Finds the previous sibling of the element.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   117
     * @method previous
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   118
     * @deprecated Use elementByAxis
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   119
     * @param {HTMLElement} element The html element.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   120
     * @param {Function} fn optional An optional boolean test to apply.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   121
     * The optional function is passed the current DOM node being tested as its only argument.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   122
     * If no function is given, the first sibling is returned.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   123
     * @param {Boolean} all optional Whether all node types should be scanned, or just element nodes.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   124
     * @return {HTMLElement | null} The matching DOM node or null if none found. 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   125
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   126
    previous: function(element, fn, all) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   127
        return Y.DOM.elementByAxis(element, PREVIOUS_SIBLING, fn, all);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   128
    },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   129
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   130
    /*
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   131
     * Finds the next sibling of the element.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   132
     * @method next
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   133
     * @deprecated Use elementByAxis
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   134
     * @param {HTMLElement} element The html element.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   135
     * @param {Function} fn optional An optional boolean test to apply.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   136
     * The optional function is passed the current DOM node being tested as its only argument.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   137
     * If no function is given, the first sibling is returned.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   138
     * @param {Boolean} all optional Whether all node types should be scanned, or just element nodes.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   139
     * @return {HTMLElement | null} The matching DOM node or null if none found. 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   140
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   141
    next: function(element, fn, all) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   142
        return Y.DOM.elementByAxis(element, NEXT_SIBLING, fn, all);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   143
    },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   144
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   145
    /*
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   146
     * Finds the ancestor of the element.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   147
     * @method ancestor
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   148
     * @deprecated Use elementByAxis
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   149
     * @param {HTMLElement} element The html element.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   150
     * @param {Function} fn optional An optional boolean test to apply.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   151
     * The optional function is passed the current DOM node being tested as its only argument.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   152
     * If no function is given, the parentNode is returned.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   153
     * @param {Boolean} all optional Whether all node types should be scanned, or just element nodes.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   154
     * @return {HTMLElement | null} The matching DOM node or null if none found. 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   155
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   156
     // TODO: optional stopAt node?
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   157
    ancestor: function(element, fn, all) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   158
        return Y.DOM.elementByAxis(element, PARENT_NODE, fn, all);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   159
    },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   160
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   161
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   162
     * Searches the element by the given axis for the first matching element.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   163
     * @method elementByAxis
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   164
     * @param {HTMLElement} element The html element.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   165
     * @param {String} axis The axis to search (parentNode, nextSibling, previousSibling).
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   166
     * @param {Function} fn optional An optional boolean test to apply.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   167
     * @param {Boolean} all optional Whether all node types should be returned, or just element nodes.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   168
     * The optional function is passed the current HTMLElement being tested as its only argument.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   169
     * If no function is given, the first element is returned.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   170
     * @return {HTMLElement | null} The matching element or null if none found.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   171
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   172
    elementByAxis: function(element, axis, fn, all) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   173
        while (element && (element = element[axis])) { // NOTE: assignment
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   174
                if ( (all || element[TAG_NAME]) && (!fn || fn(element)) ) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   175
                    return element;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   176
                }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   177
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   178
        return null;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   179
    },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   180
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   181
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   182
     * Determines whether or not one HTMLElement is or contains another HTMLElement.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   183
     * @method contains
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   184
     * @param {HTMLElement} element The containing html element.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   185
     * @param {HTMLElement} needle The html element that may be contained.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   186
     * @return {Boolean} Whether or not the element is or contains the needle.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   187
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   188
    contains: function(element, needle) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   189
        var ret = false;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   190
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   191
        if ( !needle || !element || !needle[NODE_TYPE] || !element[NODE_TYPE]) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   192
            ret = false;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   193
        } else if (element[CONTAINS])  {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   194
            if (Y.UA.opera || needle[NODE_TYPE] === 1) { // IE & SAF contains fail if needle not an ELEMENT_NODE
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   195
                ret = element[CONTAINS](needle);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   196
            } else {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   197
                ret = Y.DOM._bruteContains(element, needle); 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   198
            }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   199
        } else if (element[COMPARE_DOCUMENT_POSITION]) { // gecko
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   200
            if (element === needle || !!(element[COMPARE_DOCUMENT_POSITION](needle) & 16)) { 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   201
                ret = true;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   202
            }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   203
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   204
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   205
        return ret;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   206
    },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   207
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   208
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   209
     * Determines whether or not the HTMLElement is part of the document.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   210
     * @method inDoc
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   211
     * @param {HTMLElement} element The containing html element.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   212
     * @param {HTMLElement} doc optional The document to check.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   213
     * @return {Boolean} Whether or not the element is attached to the document. 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   214
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   215
    inDoc: function(element, doc) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   216
        doc = doc || element[OWNER_DOCUMENT];
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   217
        var id = element.id;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   218
        if (!id) { // TODO: remove when done?
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   219
            id = element.id = Y.guid();
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   220
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   221
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   222
        return !! (doc.getElementById(id));
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   223
    },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   224
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   225
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   226
     * Creates a new dom node using the provided markup string. 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   227
     * @method create
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   228
     * @param {String} html The markup used to create the element
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   229
     * @param {HTMLDocument} doc An optional document context 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   230
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   231
    create: function(html, doc) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   232
        if (typeof html === 'string') {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   233
            html = Y.Lang.trim(html); // match IE which trims whitespace from innerHTML
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   234
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   235
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   236
        if (!doc && Y.DOM._cloneCache[html]) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   237
            return Y.DOM._cloneCache[html].cloneNode(true); // NOTE: return
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   238
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   239
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   240
        doc = doc || Y.config.doc;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   241
        var m = re_tag.exec(html),
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   242
            create = Y.DOM._create,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   243
            custom = Y.DOM.creators,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   244
            ret = null,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   245
            tag, nodes;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   246
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   247
        if (m && custom[m[1]]) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   248
            if (typeof custom[m[1]] === 'function') {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   249
                create = custom[m[1]];
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   250
            } else {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   251
                tag = custom[m[1]];
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   252
            }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   253
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   254
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   255
        nodes = create(html, doc, tag).childNodes;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   256
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   257
        if (nodes.length === 1) { // return single node, breaking parentNode ref from "fragment"
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   258
            ret = nodes[0].parentNode.removeChild(nodes[0]);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   259
        } else { // return multiple nodes as a fragment
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   260
             ret = Y.DOM._nl2frag(nodes, doc);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   261
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   262
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   263
        if (ret) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   264
            Y.DOM._cloneCache[html] = ret.cloneNode(true);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   265
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   266
        return ret;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   267
    },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   268
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   269
    _nl2frag: function(nodes, doc) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   270
        var ret = null,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   271
            i, len;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   272
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   273
        if (nodes && (nodes.push || nodes.item) && nodes[0]) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   274
            doc = doc || nodes[0].ownerDocument; 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   275
            ret = doc.createDocumentFragment();
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   276
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   277
            if (nodes.item) { // convert live list to static array
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   278
                nodes = Y.Array(nodes, 0, true);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   279
            }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   280
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   281
            for (i = 0, len = nodes.length; i < len; i++) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   282
                ret.appendChild(nodes[i]); 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   283
            }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   284
        } // else inline with log for minification
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   285
        else { Y.log('unable to convert ' + nodes + ' to fragment', 'warn', 'dom'); }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   286
        return ret;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   287
    },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   288
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   289
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   290
    CUSTOM_ATTRIBUTES: (!documentElement.hasAttribute) ? { // IE < 8
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   291
        'for': 'htmlFor',
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   292
        'class': 'className'
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   293
    } : { // w3c
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   294
        'htmlFor': 'for',
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   295
        'className': 'class'
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   296
    },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   297
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   298
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   299
     * Provides a normalized attribute interface. 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   300
     * @method setAttibute
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   301
     * @param {String | HTMLElement} el The target element for the attribute.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   302
     * @param {String} attr The attribute to set.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   303
     * @param {String} val The value of the attribute.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   304
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   305
    setAttribute: function(el, attr, val, ieAttr) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   306
        if (el && el.setAttribute) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   307
            attr = Y.DOM.CUSTOM_ATTRIBUTES[attr] || attr;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   308
            el.setAttribute(attr, val, ieAttr);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   309
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   310
    },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   311
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   312
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   313
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   314
     * Provides a normalized attribute interface. 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   315
     * @method getAttibute
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   316
     * @param {String | HTMLElement} el The target element for the attribute.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   317
     * @param {String} attr The attribute to get.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   318
     * @return {String} The current value of the attribute. 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   319
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   320
    getAttribute: function(el, attr, ieAttr) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   321
        ieAttr = (ieAttr !== undefined) ? ieAttr : 2;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   322
        var ret = '';
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   323
        if (el && el.getAttribute) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   324
            attr = Y.DOM.CUSTOM_ATTRIBUTES[attr] || attr;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   325
            ret = el.getAttribute(attr, ieAttr);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   326
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   327
            if (ret === null) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   328
                ret = ''; // per DOM spec
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   329
            }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   330
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   331
        return ret;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   332
    },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   333
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   334
    isWindow: function(obj) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   335
        return obj.alert && obj.document;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   336
    },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   337
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   338
    _fragClones: {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   339
        div: document.createElement('div')
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   340
    },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   341
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   342
    _create: function(html, doc, tag) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   343
        tag = tag || 'div';
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   344
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   345
        var frag = Y.DOM._fragClones[tag];
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   346
        if (frag) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   347
            frag = frag.cloneNode(false);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   348
        } else {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   349
            frag = Y.DOM._fragClones[tag] = doc.createElement(tag);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   350
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   351
        frag.innerHTML = html;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   352
        return frag;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   353
    },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   354
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   355
    _removeChildNodes: function(node) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   356
        while (node.firstChild) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   357
            node.removeChild(node.firstChild);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   358
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   359
    },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   360
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   361
    _cloneCache: {},
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   362
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   363
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   364
     * Inserts content in a node at the given location 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   365
     * @method addHTML
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   366
     * @param {HTMLElement} node The node to insert into
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   367
     * @param {String} content The content to be inserted 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   368
     * @param {String} where Where to insert the content; default is after lastChild 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   369
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   370
    addHTML: function(node, content, where) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   371
        if (typeof content === 'string') {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   372
            content = Y.Lang.trim(content); // match IE which trims whitespace from innerHTML
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   373
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   374
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   375
        var newNode = Y.DOM._cloneCache[content],
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   376
            nodeParent = node.parentNode;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   377
            
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   378
        if (newNode) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   379
            newNode = newNode.cloneNode(true);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   380
        } else {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   381
            if (content.nodeType) { // domNode
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   382
                newNode = content;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   383
            } else { // create from string and cache
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   384
                newNode = Y.DOM.create(content);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   385
            }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   386
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   387
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   388
        if (where) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   389
            if (where.nodeType) { // insert regardless of relationship to node
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   390
                // TODO: check if node.contains(where)?
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   391
                where.parentNode.insertBefore(newNode, where);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   392
            } else {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   393
                switch (where) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   394
                    case 'replace':
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   395
                        while (node.firstChild) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   396
                            node.removeChild(node.firstChild);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   397
                        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   398
                        node.appendChild(newNode);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   399
                        break;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   400
                    case 'before':
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   401
                        nodeParent.insertBefore(newNode, node);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   402
                        break;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   403
                    case 'after':
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   404
                        if (node.nextSibling) { // IE errors if refNode is null
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   405
                            nodeParent.insertBefore(newNode, node.nextSibling);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   406
                        } else {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   407
                            nodeParent.appendChild(newNode);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   408
                        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   409
                        break;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   410
                    default:
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   411
                        node.appendChild(newNode);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   412
                }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   413
            }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   414
        } else {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   415
            node.appendChild(newNode);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   416
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   417
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   418
        return newNode;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   419
    },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   420
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   421
    VALUE_SETTERS: {},
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   422
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   423
    VALUE_GETTERS: {},
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   424
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   425
    getValue: function(node) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   426
        var ret = '', // TODO: return null?
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   427
            getter;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   428
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   429
        if (node && node[TAG_NAME]) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   430
            getter = Y.DOM.VALUE_GETTERS[node[TAG_NAME].toLowerCase()];
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   431
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   432
            if (getter) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   433
                ret = getter(node);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   434
            } else {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   435
                ret = node.value;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   436
            }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   437
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   438
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   439
        return (typeof ret === 'string') ? ret : '';
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   440
    },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   441
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   442
    setValue: function(node, val) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   443
        var setter;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   444
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   445
        if (node && node[TAG_NAME]) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   446
            setter = Y.DOM.VALUE_SETTERS[node[TAG_NAME].toLowerCase()];
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   447
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   448
            if (setter) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   449
                setter(node, val);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   450
            } else {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   451
                node.value = val;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   452
            }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   453
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   454
    },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   455
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   456
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   457
     * Brute force version of contains.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   458
     * Used for browsers without contains support for non-HTMLElement Nodes (textNodes, etc).
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   459
     * @method _bruteContains
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   460
     * @private
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   461
     * @param {HTMLElement} element The containing html element.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   462
     * @param {HTMLElement} needle The html element that may be contained.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   463
     * @return {Boolean} Whether or not the element is or contains the needle.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   464
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   465
    _bruteContains: function(element, needle) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   466
        while (needle) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   467
            if (element === needle) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   468
                return true;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   469
            }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   470
            needle = needle.parentNode;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   471
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   472
        return false;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   473
    },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   474
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   475
// TODO: move to Lang?
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   476
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   477
     * Memoizes dynamic regular expressions to boost runtime performance. 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   478
     * @method _getRegExp
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   479
     * @private
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   480
     * @param {String} str The string to convert to a regular expression.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   481
     * @param {String} flags optional An optinal string of flags.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   482
     * @return {RegExp} An instance of RegExp
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   483
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   484
    _getRegExp: function(str, flags) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   485
        flags = flags || '';
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   486
        Y.DOM._regexCache = Y.DOM._regexCache || {};
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   487
        if (!Y.DOM._regexCache[str + flags]) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   488
            Y.DOM._regexCache[str + flags] = new RegExp(str, flags);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   489
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   490
        return Y.DOM._regexCache[str + flags];
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   491
    },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   492
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   493
// TODO: make getDoc/Win true privates?
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   494
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   495
     * returns the appropriate document.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   496
     * @method _getDoc
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   497
     * @private
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   498
     * @param {HTMLElement} element optional Target element.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   499
     * @return {Object} The document for the given element or the default document. 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   500
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   501
    _getDoc: function(element) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   502
        element = element || {};
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   503
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   504
        return (element[NODE_TYPE] === 9) ? element : // element === document
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   505
                element[OWNER_DOCUMENT] || // element === DOM node
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   506
                element.document || // element === window
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   507
                Y.config.doc; // default
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   508
    },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   509
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   510
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   511
     * returns the appropriate window.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   512
     * @method _getWin
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   513
     * @private
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   514
     * @param {HTMLElement} element optional Target element.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   515
     * @return {Object} The window for the given element or the default window. 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   516
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   517
    _getWin: function(element) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   518
        var doc = Y.DOM._getDoc(element);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   519
        return doc[DEFAULT_VIEW] || doc[PARENT_WINDOW] || Y.config.win;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   520
    },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   521
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   522
    _batch: function(nodes, fn, arg1, arg2, arg3, etc) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   523
        fn = (typeof name === 'string') ? Y.DOM[fn] : fn;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   524
        var result,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   525
            ret = [];
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   526
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   527
        if (fn && nodes) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   528
            Y.each(nodes, function(node) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   529
                if ((result = fn.call(Y.DOM, node, arg1, arg2, arg3, etc)) !== undefined) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   530
                    ret[ret.length] = result;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   531
                }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   532
            });
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   533
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   534
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   535
        return ret.length ? ret : nodes;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   536
    },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   537
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   538
    _testElement: function(element, tag, fn) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   539
        tag = (tag && tag !== '*') ? tag.toUpperCase() : null;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   540
        return (element && element[TAG_NAME] &&
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   541
                (!tag || element[TAG_NAME].toUpperCase() === tag) &&
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   542
                (!fn || fn(element)));
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   543
    },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   544
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   545
    creators: {},
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   546
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   547
    _IESimpleCreate: function(html, doc) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   548
        doc = doc || Y.config.doc;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   549
        return doc.createElement(html);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   550
    }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   551
};
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   552
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   553
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   554
(function(Y) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   555
    var creators = Y.DOM.creators,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   556
        create = Y.DOM.create,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   557
        re_tbody = /(?:\/(?:thead|tfoot|tbody|caption|col|colgroup)>)+\s*<tbody/,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   558
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   559
        TABLE_OPEN = '<table>',
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   560
        TABLE_CLOSE = '</table>';
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   561
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   562
    if (Y.UA.ie) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   563
        Y.mix(creators, {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   564
        // TODO: thead/tfoot with nested tbody
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   565
            // IE adds TBODY when creating TABLE elements (which may share this impl)
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   566
            tbody: function(html, doc) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   567
                var frag = create(TABLE_OPEN + html + TABLE_CLOSE, doc),
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   568
                    tb = frag.children.tags('tbody')[0];
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   569
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   570
                if (frag.children.length > 1 && tb && !re_tbody.test(html)) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   571
                    tb[PARENT_NODE].removeChild(tb); // strip extraneous tbody
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   572
                }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   573
                return frag;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   574
            },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   575
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   576
            script: function(html, doc) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   577
                var frag = doc.createElement('div');
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   578
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   579
                frag.innerHTML = '-' + html;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   580
                frag.removeChild(frag[FIRST_CHILD]);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   581
                return frag;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   582
            }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   583
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   584
        }, true);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   585
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   586
        Y.mix(Y.DOM.VALUE_GETTERS, {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   587
            button: function(node) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   588
                return (node.attributes && node.attributes.value) ? node.attributes.value.value : '';
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   589
            }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   590
        });
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   591
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   592
        Y.mix(Y.DOM.VALUE_SETTERS, {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   593
            // IE: node.value changes the button text, which should be handled via innerHTML
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   594
            button: function(node, val) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   595
                var attr = node.attributes.value;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   596
                if (!attr) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   597
                    attr = node[OWNER_DOCUMENT].createAttribute('value');
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   598
                    node.setAttributeNode(attr);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   599
                }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   600
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   601
                attr.value = val;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   602
            }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   603
        });
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   604
    }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   605
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   606
    if (Y.UA.gecko || Y.UA.ie) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   607
        Y.mix(creators, {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   608
            option: function(html, doc) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   609
                return create('<select>' + html + '</select>', doc);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   610
            },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   611
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   612
            tr: function(html, doc) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   613
                return create('<tbody>' + html + '</tbody>', doc);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   614
            },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   615
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   616
            td: function(html, doc) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   617
                return create('<tr>' + html + '</tr>', doc);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   618
            }, 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   619
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   620
            tbody: function(html, doc) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   621
                return create(TABLE_OPEN + html + TABLE_CLOSE, doc);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   622
            }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   623
        });
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   624
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   625
        Y.mix(creators, {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   626
            legend: 'fieldset',
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   627
            th: creators.td,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   628
            thead: creators.tbody,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   629
            tfoot: creators.tbody,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   630
            caption: creators.tbody,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   631
            colgroup: creators.tbody,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   632
            col: creators.tbody,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   633
            optgroup: creators.option
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   634
        });
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   635
    }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   636
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   637
    Y.mix(Y.DOM.VALUE_GETTERS, {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   638
        option: function(node) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   639
            var attrs = node.attributes;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   640
            return (attrs.value && attrs.value.specified) ? node.value : node.text;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   641
        },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   642
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   643
        select: function(node) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   644
            var val = node.value,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   645
                options = node.options;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   646
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   647
            if (options && val === '') {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   648
                if (node.multiple) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   649
                    Y.log('multiple select normalization not implemented', 'warn', 'DOM');
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   650
                } else {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   651
                    val = Y.DOM.getValue(options[node.selectedIndex], 'value');
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   652
                }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   653
            }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   654
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   655
            return val;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   656
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   657
    });
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   658
})(Y);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   659
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   660
})(Y);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   661
var addClass, hasClass, removeClass;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   662
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   663
Y.mix(Y.DOM, {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   664
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   665
     * Determines whether a DOM element has the given className.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   666
     * @method hasClass
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   667
     * @param {HTMLElement} element The DOM element. 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   668
     * @param {String} className the class name to search for
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   669
     * @return {Boolean} Whether or not the element has the given class. 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   670
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   671
    hasClass: function(node, className) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   672
        var re = Y.DOM._getRegExp('(?:^|\\s+)' + className + '(?:\\s+|$)');
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   673
        return re.test(node.className);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   674
    },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   675
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   676
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   677
     * Adds a class name to a given DOM element.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   678
     * @method addClass         
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   679
     * @param {HTMLElement} element The DOM element. 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   680
     * @param {String} className the class name to add to the class attribute
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   681
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   682
    addClass: function(node, className) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   683
        if (!Y.DOM.hasClass(node, className)) { // skip if already present 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   684
            node.className = Y.Lang.trim([node.className, className].join(' '));
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   685
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   686
    },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   687
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   688
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   689
     * Removes a class name from a given element.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   690
     * @method removeClass         
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   691
     * @param {HTMLElement} element The DOM element. 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   692
     * @param {String} className the class name to remove from the class attribute
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   693
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   694
    removeClass: function(node, className) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   695
        if (className && hasClass(node, className)) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   696
            node.className = Y.Lang.trim(node.className.replace(Y.DOM._getRegExp('(?:^|\\s+)' +
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   697
                            className + '(?:\\s+|$)'), ' '));
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   698
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   699
            if ( hasClass(node, className) ) { // in case of multiple adjacent
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   700
                removeClass(node, className);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   701
            }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   702
        }                 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   703
    },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   704
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   705
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   706
     * Replace a class with another class for a given element.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   707
     * If no oldClassName is present, the newClassName is simply added.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   708
     * @method replaceClass  
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   709
     * @param {HTMLElement} element The DOM element. 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   710
     * @param {String} oldClassName the class name to be replaced
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   711
     * @param {String} newClassName the class name that will be replacing the old class name
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   712
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   713
    replaceClass: function(node, oldC, newC) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   714
        //Y.log('replaceClass replacing ' + oldC + ' with ' + newC, 'info', 'Node');
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   715
        addClass(node, newC);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   716
        removeClass(node, oldC);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   717
    },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   718
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   719
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   720
     * If the className exists on the node it is removed, if it doesn't exist it is added.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   721
     * @method toggleClass  
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   722
     * @param {HTMLElement} element The DOM element. 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   723
     * @param {String} className the class name to be toggled
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   724
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   725
    toggleClass: function(node, className) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   726
        if (hasClass(node, className)) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   727
            removeClass(node, className);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   728
        } else {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   729
            addClass(node, className);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   730
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   731
    }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   732
});
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   733
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   734
hasClass = Y.DOM.hasClass;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   735
removeClass = Y.DOM.removeClass;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   736
addClass = Y.DOM.addClass;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   737
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   738
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   739
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   740
}, '3.0.0' ,{requires:['oop']});