src/cm/media/js/lib/yui/yui3.0.0/build/node/node-base-debug.js
author Yves-Marie Haussonne <ymh.work+github@gmail.com>
Fri, 09 May 2014 18:35:26 +0200
changeset 656 a84519031134
parent 0 40c8f766c9b8
permissions -rw-r--r--
add link to "privacy policy" in the header test
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('node-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
/**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    11
 * The Node Utility provides a DOM-like interface for interacting with DOM nodes.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    12
 * @module node
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    13
 * @submodule node-base
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    14
 */    
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    15
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    16
/**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    17
 * The Node class provides a wrapper for manipulating DOM Nodes.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    18
 * Node properties can be accessed via the set/get methods.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    19
 * Use Y.get() to retrieve Node instances.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    20
 *
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    21
 * <strong>NOTE:</strong> Node properties are accessed using
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    22
 * the <code>set</code> and <code>get</code> methods.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    23
 *
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    24
 * @class Node
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    25
 * @constructor
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    26
 * @for Node
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    27
 */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    28
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    29
// "globals"
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    30
var DOT = '.',
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    31
    NODE_NAME = 'nodeName',
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    32
    NODE_TYPE = 'nodeType',
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    33
    OWNER_DOCUMENT = 'ownerDocument',
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    34
    TAG_NAME = 'tagName',
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    35
    UID = '_yuid',
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    36
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    37
    Node = function(node) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    38
        var uid = node[UID];
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    39
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    40
        if (uid && Node._instances[uid] && Node._instances[uid]._node !== node) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    41
            node[UID] = null; // unset existing uid to prevent collision (via clone or hack)
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    42
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    43
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    44
        uid = Y.stamp(node);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    45
        if (!uid) { // stamp failed; likely IE non-HTMLElement
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    46
            uid = Y.guid();
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    47
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    48
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    49
        this[UID] = uid;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    50
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    51
        this._node = node;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    52
        Node._instances[uid] = this;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    53
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    54
        this._stateProxy = node; // when augmented with Attribute
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    55
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    56
        if (this._initPlugins) { // when augmented with Plugin.Host
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    57
            this._initPlugins();
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    58
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    59
    },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    60
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    61
    // used with previous/next/ancestor tests
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    62
    _wrapFn = function(fn) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    63
        var ret = null;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    64
        if (fn) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    65
            ret = (typeof fn === 'string') ?
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    66
            function(n) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    67
                return Y.Selector.test(n, fn);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    68
            } : 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    69
            function(n) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    70
                return fn(Node.get(n));
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    71
            };
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;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    75
    };
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    76
// end "globals"
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    77
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    78
Node.NAME = 'Node';
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    79
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    80
Node.re_aria = /^(?:role$|aria-)/;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    81
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    82
Node.DOM_EVENTS = {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    83
    abort: true,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    84
    beforeunload: true,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    85
    blur: true,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    86
    change: true,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    87
    click: true,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    88
    close: true,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    89
    command: true,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    90
    contextmenu: true,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    91
    drag: true,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    92
    dragstart: true,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    93
    dragenter: true,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    94
    dragover: true,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    95
    dragleave: true,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    96
    dragend: true,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    97
    drop: true,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    98
    dblclick: true,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    99
    error: true,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   100
    focus: true,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   101
    keydown: true,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   102
    keypress: true,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   103
    keyup: true,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   104
    load: true,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   105
    message: true,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   106
    mousedown: true,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   107
    mousemove: true,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   108
    mouseout: true, 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   109
    mouseover: true, 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   110
    mouseup: true,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   111
    mousemultiwheel: true,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   112
    mousewheel: true,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   113
    submit: true,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   114
    mouseenter: true,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   115
    mouseleave: true,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   116
    scroll: true,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   117
    reset: true,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   118
    resize: true,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   119
    select: true,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   120
    textInput: true,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   121
    unload: true
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   122
};
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   123
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   124
// Add custom event adaptors to this list.  This will make it so
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   125
// that delegate, key, available, contentready, etc all will
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   126
// be available through Node.on
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   127
Y.mix(Node.DOM_EVENTS, Y.Env.evt.plugins);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   128
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   129
Node._instances = {};
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   130
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   131
/**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   132
 * Retrieves the DOM node bound to a Node instance
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   133
 * @method Node.getDOMNode
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   134
 * @static
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   135
 *
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   136
 * @param {Y.Node || HTMLNode} node The Node instance or an HTMLNode
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   137
 * @return {HTMLNode} The DOM node bound to the Node instance.  If a DOM node is passed
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   138
 * as the node argument, it is simply returned.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   139
 */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   140
Node.getDOMNode = function(node) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   141
    if (node) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   142
        return (node.nodeType) ? node : node._node || null;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   143
    }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   144
    return null;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   145
};
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   146
 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   147
Node.scrubVal = function(val, node) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   148
    if (node && val) { // only truthy values are risky
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   149
        if (typeof val === 'object' || typeof val === 'function') { // safari nodeList === function
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   150
            if (NODE_TYPE in val || Y.DOM.isWindow(val)) {// node || window
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   151
                val = Node.get(val);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   152
            } else if ((val.item && !val._nodes) || // dom collection or Node instance
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   153
                    (val[0] && val[0][NODE_TYPE])) { // array of DOM Nodes
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   154
                val = Y.all(val);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   155
            }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   156
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   157
    } else if (val === undefined) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   158
        val = node; // for chaining
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
    return val;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   162
};
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   163
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   164
Node.addMethod = function(name, fn, context) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   165
    if (name && fn && typeof fn === 'function') {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   166
        Node.prototype[name] = function() {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   167
            context = context || this;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   168
            var args = Y.Array(arguments),
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   169
                ret;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   170
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   171
            if (args[0] && args[0] instanceof Node) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   172
                args[0] = args[0]._node;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   173
            }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   174
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   175
            if (args[1] && args[1] instanceof Node) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   176
                args[1] = args[1]._node;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   177
            }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   178
            args.unshift(this._node);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   179
            ret = Node.scrubVal(fn.apply(context, args), this);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   180
            return ret;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   181
        };
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   182
    } else {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   183
        Y.log('unable to add method: ' + name, 'warn', 'Node');
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   184
    }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   185
};
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   186
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   187
Node.importMethod = function(host, name, altName) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   188
    if (typeof name === 'string') {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   189
        altName = altName || name;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   190
        Node.addMethod(altName, host[name], host);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   191
    } else {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   192
        Y.each(name, function(n) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   193
            Node.importMethod(host, n);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   194
        });
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   195
    }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   196
};
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   197
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   198
/**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   199
 * Returns a single Node instance bound to the node or the
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   200
 * first element matching the given selector.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   201
 * @method Y.one
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   202
 * @static
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   203
 * @param {String | HTMLElement} node a node or Selector 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   204
 * @param {Y.Node || HTMLElement} doc an optional document to scan. Defaults to Y.config.doc. 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   205
 */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   206
Node.one = function(node) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   207
    var instance = null,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   208
        cachedNode,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   209
        uid;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   210
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   211
    if (node) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   212
        if (typeof node === 'string') {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   213
            if (node.indexOf('doc') === 0) { // doc OR document
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   214
                node = Y.config.doc;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   215
            } else if (node.indexOf('win') === 0) { // win OR window
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   216
                node = Y.config.win;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   217
            } else {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   218
                node = Y.Selector.query(node, null, true);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   219
            }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   220
            if (!node) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   221
                return null;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   222
            }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   223
        } else if (node instanceof Node) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   224
            return node; // NOTE: return
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   225
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   226
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   227
        uid = node._yuid;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   228
        instance = Node._instances[uid]; // reuse exising instances
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   229
        cachedNode = instance ? instance._node : null;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   230
        if (!instance || (cachedNode && node !== cachedNode)) { // new Node when nodes don't match
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   231
            instance = new Node(node);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   232
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   233
    }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   234
    return instance;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   235
};
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   236
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   237
/**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   238
 * Returns a single Node instance bound to the node or the
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   239
 * first element matching the given selector.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   240
 * @method Y.get
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   241
 * @deprecated Use Y.one
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   242
 * @static
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   243
 * @param {String | HTMLElement} node a node or Selector 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   244
 * @param {Y.Node || HTMLElement} doc an optional document to scan. Defaults to Y.config.doc. 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   245
 */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   246
Node.get = function() {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   247
    Y.log('Y.get is deprecated, use Y.one', 'warn', 'deprecated');
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   248
    return Node.one.apply(Node, arguments);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   249
};
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   250
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   251
/**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   252
 * Creates a new dom node using the provided markup string. 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   253
 * @method create
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   254
 * @static
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   255
 * @param {String} html The markup used to create the element
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   256
 * @param {HTMLDocument} doc An optional document context 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   257
 * @return {Node} A Node instance bound to a DOM node or fragment 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   258
 */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   259
Node.create = function() {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   260
    return Node.get(Y.DOM.create.apply(Y.DOM, arguments));
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
Node.ATTRS = {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   264
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   265
     * Allows for getting and setting the text of an element.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   266
     * Formatting is preserved and special characters are treated literally.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   267
     * @config text
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   268
     * @type String
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   269
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   270
    text: {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   271
        getter: function() {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   272
            return Y.DOM.getText(this._node);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   273
        },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   274
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   275
        setter: function(content) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   276
            Y.DOM.setText(this._node, content);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   277
            return content;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   278
        }
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
    'options': {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   282
        getter: function() {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   283
            return this._node.getElementsByTagName('option');
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   284
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   285
    },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   286
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   287
     // IE: elements collection is also FORM node which trips up scrubVal.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   288
     // preconverting to NodeList
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   289
     // TODO: break out for IE only
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   290
    'elements': {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   291
        getter: function() {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   292
            return Y.all(this._node.elements);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   293
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   294
    },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   295
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   296
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   297
     * Returns a NodeList instance of all HTMLElement children.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   298
     * @readOnly
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   299
     * @config children
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   300
     * @type NodeList
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   301
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   302
    'children': {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   303
        getter: function() {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   304
            var node = this._node,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   305
                children = node.children,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   306
                childNodes, i, len;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   307
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   308
            if (!children) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   309
                childNodes = node.childNodes;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   310
                children = [];
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   311
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   312
                for (i = 0, len = childNodes.length; i < len; ++i) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   313
                    if (childNodes[i][TAG_NAME]) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   314
                        children[children.length] = childNodes[i];
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   315
                    }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   316
                }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   317
            }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   318
            return Y.all(children);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   319
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   320
    },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   321
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   322
    value: {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   323
        getter: function() {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   324
            return Y.DOM.getValue(this._node);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   325
        },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   326
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   327
        setter: function(val) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   328
            Y.DOM.setValue(this._node, val);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   329
            return val;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   330
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   331
    },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   332
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   333
    data: {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   334
        getter: function() {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   335
            return this._data;
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
        setter: function(val) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   339
            this._data = val;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   340
            return val;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   341
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   342
    }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   343
};
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   344
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   345
// call with instance context
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   346
Node.DEFAULT_SETTER = function(name, val) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   347
    var node = this._stateProxy,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   348
        strPath;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   349
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   350
    if (name.indexOf(DOT) > -1) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   351
        strPath = name;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   352
        name = name.split(DOT);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   353
        // only allow when defined on node
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   354
        Y.Object.setValue(node, name, val);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   355
    } else if (node[name] !== undefined) { // pass thru DOM properties 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   356
        node[name] = val;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   357
    }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   358
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   359
    return val;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   360
};
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   361
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   362
// call with instance context
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   363
Node.DEFAULT_GETTER = function(name) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   364
    var node = this._stateProxy,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   365
        val;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   366
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   367
    if (name.indexOf && name.indexOf(DOT) > -1) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   368
        val = Y.Object.getValue(node, name.split(DOT));
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   369
    } else if (node[name] !== undefined) { // pass thru from DOM
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   370
        val = node[name];
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   371
    }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   372
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   373
    return val;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   374
};
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   375
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   376
Y.augment(Node, Y.Event.Target);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   377
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   378
Y.mix(Node.prototype, {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   379
    toString: function() {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   380
        var str = '',
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   381
            errorMsg = this[UID] + ': not bound to a node',
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   382
            node = this._node;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   383
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   384
        if (node) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   385
            str += node[NODE_NAME];
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   386
            if (node.id) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   387
                str += '#' + node.id; 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   388
            }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   389
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   390
            if (node.className) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   391
                str += '.' + node.className.replace(' ', '.'); 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   392
            }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   393
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   394
            // TODO: add yuid?
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   395
            str += ' ' + this[UID];
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   396
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   397
        return str || errorMsg;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   398
    },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   399
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   400
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   401
     * Returns an attribute value on the Node instance
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   402
     * @method get
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   403
     * @param {String} attr The attribute to be set
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   404
     * @return {any} The current value of the attribute
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   405
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   406
    get: function(attr) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   407
        var val;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   408
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   409
        if (this._getAttr) { // use Attribute imple
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   410
            val = this._getAttr(attr);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   411
        } else {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   412
            val = this._get(attr);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   413
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   414
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   415
        if (val) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   416
            val = Y.Node.scrubVal(val, this);
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 val;
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
    _get: function(attr) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   422
        var attrConfig = Node.ATTRS[attr],
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   423
            val;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   424
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   425
        if (attrConfig && attrConfig.getter) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   426
            val = attrConfig.getter.call(this);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   427
        } else if (Node.re_aria.test(attr)) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   428
            val = this._node.getAttribute(attr, 2); 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   429
        } else {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   430
            val = Node.DEFAULT_GETTER.apply(this, arguments);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   431
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   432
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   433
        return val;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   434
    },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   435
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   436
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   437
     * Sets an attribute on the Node instance.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   438
     * @method set
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   439
     * @param {String} attr The attribute to be set.  
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   440
     * @param {any} val The value to set the attribute to.  
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   441
     * @chainable
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   442
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   443
    set: function(attr, val) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   444
        var attrConfig = Node.ATTRS[attr];
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   445
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   446
        if (this._setAttr) { // use Attribute imple
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   447
            this._setAttr.apply(this, arguments);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   448
        } else { // use setters inline
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   449
            if (attrConfig && attrConfig.setter) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   450
                attrConfig.setter.call(this, val);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   451
            } else if (Node.re_aria.test(attr)) { // special case Aria
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   452
                this._node.setAttribute(attr, val);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   453
            } else {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   454
                Node.DEFAULT_SETTER.apply(this, arguments);
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
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   458
        return this;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   459
    },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   460
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   461
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   462
     * Sets multiple attributes. 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   463
     * @method setAttrs
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   464
     * @param {Object} attrMap an object of name/value pairs to set  
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   465
     * @chainable
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   466
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   467
    setAttrs: function(attrMap) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   468
        if (this._setAttrs) { // use Attribute imple
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   469
            this._setAttrs(attrMap);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   470
        } else { // use setters inline
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   471
            Y.Object.each(attrMap, function(v, n) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   472
                this.set(n, v); 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   473
            }, this);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   474
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   475
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   476
        return this;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   477
    },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   478
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   479
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   480
     * Returns an object containing the values for the requested attributes. 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   481
     * @method getAttrs
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   482
     * @param {Array} attrs an array of attributes to get values  
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   483
     * @return {Object} An object with attribute name/value pairs.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   484
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   485
    getAttrs: function(attrs) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   486
        var ret = {};
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   487
        if (this._getAttrs) { // use Attribute imple
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   488
            this._getAttrs(attrs);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   489
        } else { // use setters inline
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   490
            Y.Array.each(attrs, function(v, n) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   491
                ret[v] = this.get(v); 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   492
            }, this);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   493
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   494
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   495
        return ret;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   496
    },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   497
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   498
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   499
     * Creates a new Node using the provided markup string. 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   500
     * @method create
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   501
     * @param {String} html The markup used to create the element
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   502
     * @param {HTMLDocument} doc An optional document context 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   503
     * @return {Node} A Node instance bound to a DOM node or fragment 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   504
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   505
    create: Node.create,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   506
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   507
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   508
     * Compares nodes to determine if they match.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   509
     * Node instances can be compared to each other and/or HTMLElements.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   510
     * @method compareTo
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   511
     * @param {HTMLElement | Node} refNode The reference node to compare to the node.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   512
     * @return {Boolean} True if the nodes match, false if they do not. 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   513
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   514
    compareTo: function(refNode) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   515
        var node = this._node;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   516
        if (refNode instanceof Y.Node) { 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   517
            refNode = refNode._node;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   518
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   519
        return node === refNode;
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
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   523
     * Determines whether the node is appended to the document.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   524
     * @method inDoc
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   525
     * @param {Node|HTMLElement} doc optional An optional document to check against.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   526
     * Defaults to current document. 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   527
     * @return {Boolean} Whether or not this node is appended to the document. 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   528
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   529
    inDoc: function(doc) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   530
        var node = this._node;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   531
        doc = (doc) ? doc._node || doc : node[OWNER_DOCUMENT];
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   532
        if (doc.documentElement) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   533
            return Y.DOM.contains(doc.documentElement, node);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   534
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   535
    },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   536
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   537
    getById: function(id) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   538
        var node = this._node,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   539
            ret = Y.DOM.byId(id, node[OWNER_DOCUMENT]);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   540
        if (ret && Y.DOM.contains(node, ret)) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   541
            ret = Y.one(ret);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   542
        } else {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   543
            ret = null;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   544
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   545
        return ret;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   546
    },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   547
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   548
   /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   549
     * Returns the nearest ancestor that passes the test applied by supplied boolean method.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   550
     * @method ancestor
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   551
     * @param {String | Function} fn A selector string or boolean method for testing elements.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   552
     * If a function is used, it receives the current node being tested as the only argument.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   553
     * @return {Node} The matching Node instance or null if not found
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   554
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   555
    ancestor: function(fn) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   556
        return Node.get(Y.DOM.elementByAxis(this._node, 'parentNode', _wrapFn(fn)));
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   557
    },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   558
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   559
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   560
     * Returns the previous matching sibling. 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   561
     * Returns the nearest element node sibling if no method provided.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   562
     * @method previous
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   563
     * @param {String | Function} fn A selector or boolean method for testing elements.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   564
     * If a function is used, it receives the current node being tested as the only argument.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   565
     * @return {Node} Node instance or null if not found
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   566
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   567
    previous: function(fn, all) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   568
        return Node.get(Y.DOM.elementByAxis(this._node, 'previousSibling', _wrapFn(fn), all));
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   569
    }, 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   570
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   571
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   572
     * Returns the next matching sibling. 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   573
     * Returns the nearest element node sibling if no method provided.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   574
     * @method next
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   575
     * @param {String | Function} fn A selector or boolean method for testing elements.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   576
     * If a function is used, it receives the current node being tested as the only argument.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   577
     * @return {Node} Node instance or null if not found
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   578
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   579
    next: function(node, fn, all) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   580
        return Node.get(Y.DOM.elementByAxis(this._node, 'nextSibling', _wrapFn(fn), all));
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   581
    },
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
     * Retrieves a Node instance of nodes based on the given CSS selector. 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   585
     * @method one
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   586
     *
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   587
     * @param {string} selector The CSS selector to test against.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   588
     * @return {Node} A Node instance for the matching HTMLElement.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   589
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   590
    one: function(selector) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   591
        return Y.one(Y.Selector.query(selector, this._node, true));
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   592
    },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   593
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   594
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   595
     * Retrieves a Node instance of nodes based on the given CSS selector. 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   596
     * @method query
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   597
     * @deprecated Use one()
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   598
     * @param {string} selector The CSS selector to test against.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   599
     * @return {Node} A Node instance for the matching HTMLElement.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   600
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   601
    query: function(selector) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   602
        Y.log('query() is deprecated, use one()', 'warn', 'deprecated');
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   603
        return this.one(selector);
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
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   607
     * Retrieves a nodeList based on the given CSS selector. 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   608
     * @method all
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   609
     *
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   610
     * @param {string} selector The CSS selector to test against.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   611
     * @return {NodeList} A NodeList instance for the matching HTMLCollection/Array.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   612
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   613
    all: function(selector) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   614
        var nodelist = Y.all(Y.Selector.query(selector, this._node));
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   615
        nodelist._query = selector;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   616
        return nodelist;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   617
    },
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
     * Retrieves a nodeList based on the given CSS selector. 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   621
     * @method queryAll
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   622
     * @deprecated Use all()
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   623
     * @param {string} selector The CSS selector to test against.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   624
     * @return {NodeList} A NodeList instance for the matching HTMLCollection/Array.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   625
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   626
    queryAll: function(selector) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   627
        Y.log('queryAll() is deprecated, use all()', 'warn', 'deprecated');
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   628
        return this.all(selector);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   629
    },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   630
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   631
    // TODO: allow fn test
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   632
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   633
     * Test if the supplied node matches the supplied selector.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   634
     * @method test
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   635
     *
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   636
     * @param {string} selector The CSS selector to test against.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   637
     * @return {boolean} Whether or not the node matches the selector.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   638
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   639
    test: function(selector) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   640
        return Y.Selector.test(this._node, selector);
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
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   644
     * Removes the node from its parent.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   645
     * Shortcut for myNode.get('parentNode').removeChild(myNode);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   646
     * @method remove
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   647
     * @chainable
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   648
     *
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   649
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   650
    remove: function(destroy) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   651
        var node = this._node;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   652
        node.parentNode.removeChild(node);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   653
        if (destroy) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   654
            this.destroy(true);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   655
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   656
        return this;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   657
    },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   658
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   659
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   660
     * Replace the node with the other node. This is a DOM update only
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   661
     * and does not change the node bound to the Node instance.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   662
     * Shortcut for myNode.get('parentNode').replaceChild(newNode, myNode);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   663
     * @method replace
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   664
     * @chainable
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   665
     *
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   666
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   667
    replace: function(newNode) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   668
        var node = this._node;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   669
        node.parentNode.replaceChild(newNode, node);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   670
        return this;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   671
    },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   672
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   673
    purge: function(recurse, type) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   674
        Y.Event.purgeElement(this._node, recurse, type);
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
    destroy: function(purge) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   678
        delete Node._instances[this[UID]];
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   679
        if (purge) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   680
            this.purge(true);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   681
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   682
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   683
        if (this.unplug) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   684
            this.unplug();
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
        this._node._yuid = null;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   688
        this._node = null;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   689
        this._stateProxy = null;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   690
    },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   691
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   692
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   693
     * Invokes a method on the Node instance 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   694
     * @method invoke
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   695
     * @param {String} method The name of the method to invoke
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   696
     * @param {Any}  a, b, c, etc. Arguments to invoke the method with. 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   697
     * @return Whatever the underly method returns. 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   698
     * DOM Nodes and Collections return values
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   699
     * are converted to Node/NodeList instances.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   700
     *
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   701
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   702
    invoke: function(method, a, b, c, d, e) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   703
        var node = this._node,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   704
            ret;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   705
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   706
        if (a && a instanceof Y.Node) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   707
            a = a._node;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   708
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   709
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   710
        if (b && b instanceof Y.Node) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   711
            b = b._node;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   712
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   713
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   714
        ret = node[method](a, b, c, d, e);    
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   715
        return Y.Node.scrubVal(ret, this);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   716
    },
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
     * Applies the given function to each Node in the NodeList.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   720
     * @method each
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   721
     * @deprecated Use NodeList
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   722
     * @param {Function} fn The function to apply 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   723
     * @param {Object} context optional An optional context to apply the function with
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   724
     * Default context is the NodeList instance
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   725
     * @chainable
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   726
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   727
    each: function(fn, context) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   728
        context = context || this;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   729
        Y.log('each is deprecated on Node', 'warn', 'deprecated');
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   730
        return fn.call(context, this);
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
     * Retrieves the Node instance at the given index. 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   735
     * @method item
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   736
     * @deprecated Use NodeList
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   737
     *
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   738
     * @param {Number} index The index of the target Node.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   739
     * @return {Node} The Node instance at the given index.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   740
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   741
    item: function(index) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   742
        Y.log('item is deprecated on Node', 'warn', 'deprecated');
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   743
        return this;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   744
    },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   745
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   746
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   747
     * Returns the current number of items in the Node.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   748
     * @method size
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   749
     * @deprecated Use NodeList
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   750
     * @return {Int} The number of items in the Node. 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   751
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   752
    size: function() {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   753
        Y.log('size is deprecated on Node', 'warn', 'deprecated');
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   754
        return this._node ? 1 : 0;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   755
    },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   756
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   757
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   758
     * Inserts the content before the reference node. 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   759
     * @method insert
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   760
     * @param {String | Y.Node | HTMLElement} content The content to insert 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   761
     * @param {Int | Y.Node | HTMLElement | String} where The position to insert at.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   762
     * @chainable
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   763
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   764
    insert: function(content, where) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   765
        var node = this._node;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   766
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   767
        if (content) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   768
            if (typeof where === 'number') { // allow index
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   769
                where = this._node.childNodes[where];
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   770
            }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   771
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   772
            if (typeof content !== 'string') { // allow Node or NodeList/Array instances
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   773
                if (content._node) { // Node
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   774
                    content = content._node;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   775
                } else if (content._nodes || (!content.nodeType && content.length)) { // NodeList or Array
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   776
                    Y.each(content._nodes, function(n) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   777
                        Y.DOM.addHTML(node, n, where);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   778
                    });
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   779
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   780
                    return this; // NOTE: early return
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   781
                }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   782
            }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   783
            Y.DOM.addHTML(node, content, where);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   784
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   785
        return this;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   786
    },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   787
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   788
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   789
     * Inserts the content as the firstChild of the node. 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   790
     * @method prepend
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   791
     * @param {String | Y.Node | HTMLElement} content The content to insert 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   792
     * @chainable
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   793
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   794
    prepend: function(content) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   795
        return this.insert(content, 0);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   796
    },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   797
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   798
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   799
     * Inserts the content as the lastChild of the node. 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   800
     * @method append
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   801
     * @param {String | Y.Node | HTMLElement} content The content to insert 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   802
     * @chainable
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   803
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   804
    append: function(content) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   805
        return this.insert(content, null);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   806
    },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   807
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   808
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   809
     * Replaces the node's current content with the content.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   810
     * @method setContent
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   811
     * @param {String | Y.Node | HTMLElement} content The content to insert 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   812
     * @chainable
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   813
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   814
    setContent: function(content) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   815
        Y.DOM.addHTML(this._node, content, 'replace');
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   816
        return this;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   817
    },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   818
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   819
    // TODO: need this?
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   820
    hasMethod: function(method) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   821
        var node = this._node;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   822
        return (node && (typeof node === 'function'));
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   823
    }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   824
}, true);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   825
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   826
Y.Node = Node;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   827
Y.get = Y.Node.get;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   828
Y.one = Y.Node.one;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   829
/**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   830
 * The NodeList module provides support for managing collections of Nodes.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   831
 * @module node
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   832
 * @submodule nodelist
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   833
 */    
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   834
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   835
/**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   836
 * The NodeList class provides a wrapper for manipulating DOM NodeLists.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   837
 * NodeList properties can be accessed via the set/get methods.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   838
 * Use Y.all() to retrieve NodeList instances.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   839
 *
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   840
 * @class NodeList
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   841
 * @constructor
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   842
 */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   843
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   844
var NodeList = function(nodes) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   845
    if (typeof nodes === 'string') {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   846
        this._query = nodes;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   847
        nodes = Y.Selector.query(nodes);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   848
    } else {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   849
        nodes = Y.Array(nodes, 0, true);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   850
    }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   851
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   852
    NodeList._instances[Y.stamp(this)] = this;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   853
    this._nodes = nodes;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   854
};
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   855
// end "globals"
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   856
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   857
NodeList.NAME = 'NodeList';
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   858
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   859
/**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   860
 * Retrieves the DOM nodes bound to a NodeList instance
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   861
 * @method NodeList.getDOMNodes
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   862
 * @static
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   863
 *
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   864
 * @param {Y.NodeList} node The NodeList instance
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   865
 * @return {Array} The array of DOM nodes bound to the NodeList
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   866
 */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   867
NodeList.getDOMNodes = function(nodeList) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   868
    return nodeList._nodes;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   869
};
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   870
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   871
NodeList._instances = [];
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   872
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   873
NodeList.each = function(instance, fn, context) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   874
    var nodes = instance._nodes;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   875
    if (nodes && nodes.length) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   876
        Y.Array.each(nodes, fn, context || instance);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   877
    } else {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   878
        Y.log('no nodes bound to ' + this, 'warn', 'NodeList');
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   879
    }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   880
};
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   881
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   882
NodeList.addMethod = function(name, fn, context) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   883
    if (name && fn) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   884
        NodeList.prototype[name] = function() {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   885
            var ret = [],
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   886
                args = arguments;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   887
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   888
            Y.Array.each(this._nodes, function(node) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   889
                var UID = '_yuid',
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   890
                    instance = Y.Node._instances[node[UID]],
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   891
                    ctx,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   892
                    result;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   893
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   894
                if (!instance) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   895
                    instance = NodeList._getTempNode(node);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   896
                }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   897
                ctx = context || instance;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   898
                result = fn.apply(ctx, args);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   899
                if (result !== undefined && result !== instance) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   900
                    ret[ret.length] = result;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   901
                }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   902
            });
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   903
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   904
            // TODO: remove tmp pointer
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   905
            return ret.length ? ret : this;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   906
        };
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   907
    } else {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   908
        Y.log('unable to add method: ' + name, 'warn', 'Node');
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   909
    }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   910
};
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   911
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   912
NodeList.importMethod = function(host, name, altName) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   913
    if (typeof name === 'string') {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   914
        altName = altName || name;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   915
        NodeList.addMethod(name, host[name]);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   916
    } else {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   917
        Y.each(name, function(n) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   918
            NodeList.importMethod(host, n);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   919
        });
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   920
    }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   921
};
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   922
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   923
NodeList._getTempNode = function(node) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   924
    var tmp = NodeList._tempNode;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   925
    if (!tmp) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   926
        tmp = Y.Node.create('<div></div>');
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   927
        NodeList._tempNode = tmp;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   928
    }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   929
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   930
    tmp._node = node;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   931
    tmp._stateProxy = node;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   932
    return tmp;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   933
};
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   934
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   935
Y.mix(NodeList.prototype, {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   936
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   937
     * Retrieves the Node instance at the given index. 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   938
     * @method item
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   939
     *
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   940
     * @param {Number} index The index of the target Node.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   941
     * @return {Node} The Node instance at the given index.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   942
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   943
    item: function(index) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   944
        return Y.one((this._nodes || [])[index]);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   945
    },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   946
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   947
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   948
     * Applies the given function to each Node in the NodeList.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   949
     * @method each
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   950
     * @param {Function} fn The function to apply. It receives 3 arguments:
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   951
     * the current node instance, the node's index, and the NodeList instance
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   952
     * @param {Object} context optional An optional context to apply the function with
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   953
     * Default context is the current Node instance
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   954
     * @chainable
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   955
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   956
    each: function(fn, context) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   957
        var instance = this;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   958
        Y.Array.each(this._nodes, function(node, index) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   959
            node = Y.one(node);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   960
            return fn.call(context || node, node, index, instance);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   961
        });
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   962
        return instance;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   963
    },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   964
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   965
    batch: function(fn, context) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   966
        var nodelist = this;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   967
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   968
        Y.Array.each(this._nodes, function(node, index) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   969
            var instance = Y.Node._instances[node[UID]];
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   970
            if (!instance) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   971
                instance = NodeList._getTempNode(node);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   972
            }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   973
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   974
            return fn.call(context || instance, instance, index, nodelist);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   975
        });
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   976
        return nodelist;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   977
    },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   978
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   979
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   980
     * Executes the function once for each node until a true value is returned.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   981
     * @method some
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   982
     * @param {Function} fn The function to apply. It receives 3 arguments:
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   983
     * the current node instance, the node's index, and the NodeList instance
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   984
     * @param {Object} context optional An optional context to execute the function from.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   985
     * Default context is the current Node instance
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   986
     * @return {Boolean} Whether or not the function returned true for any node.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   987
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   988
    some: function(fn, context) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   989
        var instance = this;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   990
        return Y.Array.some(this._nodes, function(node, index) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   991
            node = Y.one(node);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   992
            context = context || node;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   993
            return fn.call(context, node, index, instance);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   994
        });
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   995
    },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   996
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   997
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   998
     * Creates a documenFragment from the nodes bound to the NodeList instance 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   999
     * @method toDocFrag
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1000
     * @return Node a Node instance bound to the documentFragment
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1001
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1002
    toFrag: function() {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1003
        return Y.one(Y.DOM._nl2frag(this._nodes));
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1004
    },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1005
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1006
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1007
     * Returns the index of the node in the NodeList instance
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1008
     * or -1 if the node isn't found.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1009
     * @method indexOf
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1010
     * @param {Y.Node || DOMNode} node the node to search for
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1011
     * @return {Int} the index of the node value or -1 if not found
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1012
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1013
    indexOf: function(node) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1014
        return Y.Array.indexOf(this._nodes, Y.Node.getDOMNode(node));
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1015
    },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1016
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1017
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1018
     * Filters the NodeList instance down to only nodes matching the given selector.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1019
     * @method filter
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1020
     * @param {String} selector The selector to filter against
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1021
     * @return {NodeList} NodeList containing the updated collection 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1022
     * @see Selector
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1023
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1024
    filter: function(selector) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1025
        return Y.all(Y.Selector.filter(this._nodes, selector));
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1026
    },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1027
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1028
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1029
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1030
     * Creates a new NodeList containing all nodes at every n indices, where 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1031
     * remainder n % index equals r.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1032
     * (zero-based index).
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1033
     * @method modulus
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1034
     * @param {Int} n The offset to use (return every nth node)
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1035
     * @param {Int} r An optional remainder to use with the modulus operation (defaults to zero) 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1036
     * @return {NodeList} NodeList containing the updated collection 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1037
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1038
    modulus: function(n, r) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1039
        r = r || 0;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1040
        var nodes = [];
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1041
        NodeList.each(this, function(node, i) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1042
            if (i % n === r) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1043
                nodes.push(node);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1044
            }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1045
        });
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1046
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1047
        return Y.all(nodes);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1048
    },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1049
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1050
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1051
     * Creates a new NodeList containing all nodes at odd indices
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1052
     * (zero-based index).
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1053
     * @method odd
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1054
     * @return {NodeList} NodeList containing the updated collection 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1055
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1056
    odd: function() {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1057
        return this.modulus(2, 1);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1058
    },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1059
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1060
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1061
     * Creates a new NodeList containing all nodes at even indices
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1062
     * (zero-based index), including zero. 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1063
     * @method even
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1064
     * @return {NodeList} NodeList containing the updated collection 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1065
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1066
    even: function() {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1067
        return this.modulus(2);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1068
    },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1069
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1070
    destructor: function() {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1071
        delete NodeList._instances[this[UID]];
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1072
    },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1073
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1074
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1075
     * Reruns the initial query, when created using a selector query 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1076
     * @method refresh
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1077
     * @chainable
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1078
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1079
    refresh: function() {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1080
        var doc,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1081
            nodes = this._nodes;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1082
        if (this._query) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1083
            if (nodes && nodes[0] && nodes[0].ownerDocument) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1084
                doc = nodes[0].ownerDocument;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1085
            }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1086
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1087
            this._nodes = Y.Selector.query(this._query, doc || Y.config.doc);        
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1088
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1089
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1090
        return this;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1091
    },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1092
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1093
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1094
     * Applies an event listener to each Node bound to the NodeList. 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1095
     * @method on
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1096
     * @param {String} type The event being listened for
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1097
     * @param {Function} fn The handler to call when the event fires
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1098
     * @param {Object} context The context to call the handler with.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1099
     * Default is the NodeList instance. 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1100
     * @return {Object} Returns an event handle that can later be use to detach(). 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1101
     * @see Event.on
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1102
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1103
    on: function(type, fn, context) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1104
        var args = Y.Array(arguments, 0, true);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1105
        args.splice(2, 0, this._nodes);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1106
        args[3] = context || this;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1107
        return Y.on.apply(Y, args);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1108
    },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1109
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1110
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1111
     * Applies an event listener to each Node bound to the NodeList. 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1112
     * The handler is called only after all on() handlers are called
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1113
     * and the event is not prevented.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1114
     * @method after
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1115
     * @param {String} type The event being listened for
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1116
     * @param {Function} fn The handler to call when the event fires
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1117
     * @param {Object} context The context to call the handler with.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1118
     * Default is the NodeList instance. 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1119
     * @return {Object} Returns an event handle that can later be use to detach(). 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1120
     * @see Event.on
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1121
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1122
    after: function(type, fn, context) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1123
        var args = Y.Array(arguments, 0, true);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1124
        args.splice(2, 0, this._nodes);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1125
        args[3] = context || this;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1126
        return Y.after.apply(Y, args);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1127
    },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1128
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1129
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1130
     * Returns the current number of items in the NodeList.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1131
     * @method size
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1132
     * @return {Int} The number of items in the NodeList. 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1133
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1134
    size: function() {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1135
        return this._nodes.length;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1136
    },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1137
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1138
    toString: function() {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1139
        var str = '',
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1140
            errorMsg = this[UID] + ': not bound to any nodes',
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1141
            nodes = this._nodes,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1142
            node;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1143
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1144
        if (nodes && nodes[0]) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1145
            node = nodes[0];
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1146
            str += node[NODE_NAME];
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1147
            if (node.id) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1148
                str += '#' + node.id; 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1149
            }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1150
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1151
            if (node.className) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1152
                str += '.' + node.className.replace(' ', '.'); 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1153
            }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1154
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1155
            if (nodes.length > 1) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1156
                str += '...[' + nodes.length + ' items]';
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1157
            }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1158
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1159
        return str || errorMsg;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1160
    }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1161
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1162
}, true);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1163
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1164
NodeList.importMethod(Y.Node.prototype, [
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1165
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1166
     * Called on each Node instance
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1167
     * @for NodeList
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1168
     * @method append
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1169
     * @see Node.append
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1170
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1171
    'append',
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1172
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1173
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1174
      * Called on each Node instance
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1175
      * @method detach
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1176
      * @see Node.detach
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1177
      */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1178
    'detach',
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1179
    
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1180
    /** Called on each Node instance
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1181
      * @method detachAll
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1182
      * @see Node.detachAll
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1183
      */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1184
    'detachAll',
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1185
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1186
    /** Called on each Node instance
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1187
      * @method insert
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1188
      * @see NodeInsert
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1189
      */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1190
    'insert',
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1191
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1192
    /** Called on each Node instance
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1193
      * @method prepend
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1194
      * @see Node.prepend
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1195
      */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1196
    'prepend',
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1197
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1198
    /** Called on each Node instance
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1199
      * @method remove
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1200
      * @see Node.remove
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1201
      */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1202
    'remove',
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1203
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1204
    /** Called on each Node instance
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1205
      * @method set
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1206
      * @see Node.set
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1207
      */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1208
    'set',
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1209
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1210
    /** Called on each Node instance
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1211
      * @method setContent
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1212
      * @see Node.setContent
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1213
      */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1214
    'setContent'
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1215
]);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1216
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1217
// one-off implementation to convert array of Nodes to NodeList
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1218
// e.g. Y.all('input').get('parentNode');
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1219
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1220
/** Called on each Node instance
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1221
  * @method get
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1222
  * @see Node
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1223
  */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1224
NodeList.prototype.get = function(attr) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1225
    var ret = [],
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1226
        nodes = this._nodes,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1227
        isNodeList = false,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1228
        getTemp = NodeList._getTempNode,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1229
        instance,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1230
        val;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1231
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1232
    if (nodes[0]) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1233
        instance = Y.Node._instances[nodes[0]._yuid] || getTemp(nodes[0]);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1234
        val = instance._get(attr);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1235
        if (val && val.nodeType) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1236
            isNodeList = true;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1237
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1238
    }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1239
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1240
    Y.Array.each(nodes, function(node) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1241
        instance = Y.Node._instances[node._yuid];
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1242
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1243
        if (!instance) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1244
            instance = getTemp(node);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1245
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1246
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1247
        val = instance._get(attr);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1248
        if (!isNodeList) { // convert array of Nodes to NodeList
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1249
            val = Y.Node.scrubVal(val, instance);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1250
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1251
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1252
        ret.push(val);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1253
    });
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1254
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1255
    return (isNodeList) ? Y.all(ret) : ret;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1256
};
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1257
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1258
Y.NodeList = NodeList;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1259
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1260
Y.all = function(nodes) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1261
    return new NodeList(nodes);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1262
};
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1263
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1264
Y.Node.all = Y.all;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1265
Y.Array.each([
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1266
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1267
     * Passes through to DOM method.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1268
     * @method replaceChild
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1269
     * @for Node
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1270
     * @param {HTMLElement | Node} node Node to be inserted 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1271
     * @param {HTMLElement | Node} refNode Node to be replaced 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1272
     * @return {Node} The replaced node 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1273
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1274
    'replaceChild',
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1275
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1276
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1277
     * Passes through to DOM method.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1278
     * @method appendChild
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1279
     * @param {HTMLElement | Node} node Node to be appended 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1280
     * @return {Node} The appended node 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1281
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1282
    'appendChild',
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1283
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1284
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1285
     * Passes through to DOM method.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1286
     * @method insertBefore
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1287
     * @param {HTMLElement | Node} newNode Node to be appended 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1288
     * @param {HTMLElement | Node} refNode Node to be inserted before 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1289
     * @return {Node} The inserted node 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1290
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1291
    'insertBefore',
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1292
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1293
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1294
     * Passes through to DOM method.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1295
     * @method removeChild
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1296
     * @param {HTMLElement | Node} node Node to be removed 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1297
     * @return {Node} The removed node 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1298
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1299
    'removeChild',
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1300
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1301
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1302
     * Passes through to DOM method.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1303
     * @method hasChildNodes
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1304
     * @return {Boolean} Whether or not the node has any childNodes 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1305
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1306
    'hasChildNodes',
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1307
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1308
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1309
     * Passes through to DOM method.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1310
     * @method cloneNode
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1311
     * @param {Boolean} deep Whether or not to perform a deep clone, which includes
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1312
     * subtree and attributes
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1313
     * @return {Node} The clone 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1314
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1315
    'cloneNode',
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1316
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1317
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1318
     * Passes through to DOM method.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1319
     * @method hasAttribute
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1320
     * @param {String} attribute The attribute to test for 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1321
     * @return {Boolean} Whether or not the attribute is present 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1322
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1323
    'hasAttribute',
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1324
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1325
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1326
     * Passes through to DOM method.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1327
     * @method removeAttribute
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1328
     * @param {String} attribute The attribute to be removed 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1329
     * @chainable
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1330
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1331
    'removeAttribute',
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1332
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1333
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1334
     * Passes through to DOM method.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1335
     * @method scrollIntoView
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1336
     * @chainable
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1337
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1338
    'scrollIntoView',
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1339
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1340
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1341
     * Passes through to DOM method.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1342
     * @method getElementsByTagName
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1343
     * @param {String} tagName The tagName to collect 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1344
     * @return {NodeList} A NodeList representing the HTMLCollection
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1345
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1346
    'getElementsByTagName',
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1347
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1348
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1349
     * Passes through to DOM method.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1350
     * @method focus
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1351
     * @chainable
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1352
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1353
    'focus',
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1354
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1355
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1356
     * Passes through to DOM method.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1357
     * @method blur
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1358
     * @chainable
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1359
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1360
    'blur',
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1361
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1362
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1363
     * Passes through to DOM method.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1364
     * Only valid on FORM elements
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1365
     * @method submit
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1366
     * @chainable
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1367
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1368
    'submit',
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1369
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1370
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1371
     * Passes through to DOM method.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1372
     * Only valid on FORM elements
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1373
     * @method reset
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1374
     * @chainable
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1375
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1376
    'reset',
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1377
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1378
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1379
     * Passes through to DOM method.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1380
     * @method select
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1381
     * @chainable
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1382
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1383
     'select'
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1384
], function(method) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1385
    Y.Node.prototype[method] = function(arg1, arg2, arg3) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1386
        var ret = this.invoke(method, arg1, arg2, arg3);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1387
        return ret;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1388
    };
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1389
});
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1390
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1391
Node.importMethod(Y.DOM, [
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1392
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1393
     * Determines whether the ndoe is an ancestor of another HTML element in the DOM hierarchy.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1394
     * @method contains
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1395
     * @param {Node | HTMLElement} needle The possible node or descendent
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1396
     * @return {Boolean} Whether or not this node is the needle its ancestor
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1397
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1398
    'contains',
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1399
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1400
     * Allows setting attributes on DOM nodes, normalizing in some cases.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1401
     * This passes through to the DOM node, allowing for custom attributes.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1402
     * @method setAttribute
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1403
     * @for Node
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1404
     * @for NodeList
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1405
     * @chainable
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1406
     * @param {string} name The attribute name 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1407
     * @param {string} value The value to set
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1408
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1409
    'setAttribute',
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1410
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1411
     * Allows getting attributes on DOM nodes, normalizing in some cases.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1412
     * This passes through to the DOM node, allowing for custom attributes.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1413
     * @method getAttribute
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1414
     * @for Node
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1415
     * @for NodeList
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1416
     * @param {string} name The attribute name 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1417
     * @return {string} The attribute value 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1418
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1419
    'getAttribute'
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1420
]);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1421
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1422
/**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1423
 * Allows setting attributes on DOM nodes, normalizing in some cases.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1424
 * This passes through to the DOM node, allowing for custom attributes.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1425
 * @method setAttribute
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1426
 * @see Node
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1427
 * @for NodeList
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1428
 * @chainable
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1429
 * @param {string} name The attribute name 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1430
 * @param {string} value The value to set
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1431
 */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1432
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1433
/**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1434
 * Allows getting attributes on DOM nodes, normalizing in some cases.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1435
 * This passes through to the DOM node, allowing for custom attributes.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1436
 * @method getAttribute
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1437
 * @see Node
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1438
 * @for NodeList
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1439
 * @param {string} name The attribute name 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1440
 * @return {string} The attribute value 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1441
 */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1442
Y.NodeList.importMethod(Y.Node.prototype, ['getAttribute', 'setAttribute']);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1443
(function(Y) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1444
    var methods = [
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1445
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1446
     * Determines whether each node has the given className.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1447
     * @method hasClass
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1448
     * @for Node
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1449
     * @param {String} className the class name to search for
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1450
     * @return {Array} An array of booleans for each node bound to the NodeList. 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1451
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1452
     'hasClass',
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1453
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1454
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1455
     * Adds a class name to each node.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1456
     * @method addClass         
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1457
     * @param {String} className the class name to add to the node's class attribute
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1458
     * @chainable
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1459
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1460
     'addClass',
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1461
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1462
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1463
     * Removes a class name from each node.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1464
     * @method removeClass         
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1465
     * @param {String} className the class name to remove from the node's class attribute
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1466
     * @chainable
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1467
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1468
     'removeClass',
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1469
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1470
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1471
     * Replace a class with another class for each node.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1472
     * If no oldClassName is present, the newClassName is simply added.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1473
     * @method replaceClass  
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1474
     * @param {String} oldClassName the class name to be replaced
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1475
     * @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
  1476
     * @chainable
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1477
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1478
     'replaceClass',
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1479
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1480
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1481
     * 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
  1482
     * @method toggleClass  
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1483
     * @param {String} className the class name to be toggled
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1484
     * @chainable
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1485
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1486
     'toggleClass'
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1487
    ];
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1488
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1489
    Y.Node.importMethod(Y.DOM, methods);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1490
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1491
     * Determines whether each node has the given className.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1492
     * @method hasClass
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1493
     * @see Node.hasClass
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1494
     * @for NodeList
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1495
     * @param {String} className the class name to search for
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1496
     * @return {Array} An array of booleans for each node bound to the NodeList. 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1497
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1498
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1499
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1500
     * Adds a class name to each node.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1501
     * @method addClass         
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1502
     * @see Node.addClass
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1503
     * @param {String} className the class name to add to the node's class attribute
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1504
     * @chainable
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1505
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1506
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1507
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1508
     * Removes a class name from each node.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1509
     * @method removeClass         
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1510
     * @see Node.removeClass
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1511
     * @param {String} className the class name to remove from the node's class attribute
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1512
     * @chainable
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1513
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1514
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1515
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1516
     * Replace a class with another class for each node.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1517
     * If no oldClassName is present, the newClassName is simply added.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1518
     * @method replaceClass  
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1519
     * @see Node.replaceClass
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1520
     * @param {String} oldClassName the class name to be replaced
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1521
     * @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
  1522
     * @chainable
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1523
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1524
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1525
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1526
     * 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
  1527
     * @method toggleClass  
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1528
     * @see Node.toggleClass
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1529
     * @param {String} className the class name to be toggled
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1530
     * @chainable
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1531
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1532
    Y.NodeList.importMethod(Y.Node.prototype, methods);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1533
})(Y);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1534
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1535
if (!document.documentElement.hasAttribute) { // IE < 8
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1536
    Y.Node.prototype.hasAttribute = function(attr) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1537
        return Y.DOM.getAttribute(this._node, attr) !== '';
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1538
    };
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1539
}
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1540
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1541
// IE throws error when setting input.type = 'hidden',
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1542
// input.setAttribute('type', 'hidden') and input.attributes.type.value = 'hidden'
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1543
Y.Node.ATTRS.type = {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1544
    setter: function(val) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1545
        if (val === 'hidden') {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1546
            try {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1547
                this._node.type = 'hidden';
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1548
            } catch(e) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1549
                this.setStyle('display', 'none');
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1550
                this._inputType = 'hidden';
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1551
            }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1552
        } else {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1553
            try { // IE errors when changing the type from "hidden'
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1554
                this._node.type = val;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1555
            } catch (e) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1556
                Y.log('error setting type: ' + val, 'info', 'node');
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1557
            }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1558
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1559
        return val;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1560
    },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1561
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1562
    getter: function() {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1563
        return this._inputType || this._node.type;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1564
    },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1565
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1566
    _bypassProxy: true // don't update DOM when using with Attribute
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1567
};
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1568
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1569
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1570
}, '3.0.0' ,{requires:['dom-base', 'selector-css2', 'event-base']});