src/cm/media/js/lib/yui/yui_3.0.0b1/build/node/node-debug.js
author raph
Mon, 23 Nov 2009 15:14:29 +0100
changeset 0 40c8f766c9b8
permissions -rw-r--r--
import from internal svn r 4007
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
0
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
     1
/*
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
     2
Copyright (c) 2009, Yahoo! Inc. All rights reserved.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
     3
Code licensed under the BSD License:
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
     4
http://developer.yahoo.net/yui/license.txt
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
     5
version: 3.0.0b1
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
     6
build: 1163
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 g_nodes = {},
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    31
    g_nodelists = {},
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    32
    g_restrict = {},
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    33
    g_slice = Array.prototype.slice,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    34
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    35
    DOT = '.',
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    36
    NODE_NAME = 'nodeName',
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    37
    NODE_TYPE = 'nodeType',
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    38
    OWNER_DOCUMENT = 'ownerDocument',
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    39
    TAG_NAME = 'tagName',
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    40
    UID = '_yuid',
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    41
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    42
    SuperConstr = Y.Base,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    43
    SuperConstrProto = Y.Base.prototype,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    44
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    45
    Node = function(node, restricted) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    46
        var config = null;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    47
        this[UID] = Y.stamp(node);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    48
        if (!this[UID]) { // stamp failed; likely IE non-HTMLElement
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    49
            this[UID] = Y.guid(); 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    50
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    51
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    52
        g_nodes[this[UID]] = node;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    53
        Node._instances[this[UID]] = this;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    54
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    55
        if (restricted) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    56
            config = {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    57
                restricted: restricted
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    58
            };
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    59
            g_restrict[this[UID]] = true; 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    60
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    61
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    62
        this._lazyAttrInit = true;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    63
        this._silentInit = true;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    64
        SuperConstr.call(this, config);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    65
    },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    66
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    67
    // used with previous/next/ancestor tests
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    68
    _wrapFn = function(fn) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    69
        var ret = null;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    70
        if (fn) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    71
            ret = (typeof fn === 'string') ?
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    72
            function(n) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    73
                return Y.Selector.test(n, fn);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    74
            } : 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    75
            function(n) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    76
                return fn(Node.get(n));
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    77
            };
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    78
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    79
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    80
        return ret;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    81
    };
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    82
// end "globals"
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    83
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    84
Node.NAME = 'Node';
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    85
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    86
Node.DOM_EVENTS = {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    87
    abort: true,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    88
    blur: true,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    89
    change: true,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    90
    click: true,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    91
    close: true,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    92
    command: true,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    93
    contextmenu: true,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    94
    drag: true,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    95
    dragstart: true,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    96
    dragenter: true,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    97
    dragover: true,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    98
    dragleave: true,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    99
    dragend: true,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   100
    drop: true,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   101
    dblclick: true,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   102
    error: true,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   103
    focus: true,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   104
    keydown: true,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   105
    keypress: true,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   106
    keyup: true,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   107
    load: true,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   108
    mousedown: true,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   109
    mousemove: true,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   110
    mouseout: true, 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   111
    mouseover: true, 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   112
    mouseup: true,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   113
    mousemultiwheel: true,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   114
    mousewheel: true,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   115
    submit: true,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   116
    mouseenter: true,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   117
    mouseleave: true,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   118
    scroll: true,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   119
    reset: true,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   120
    resize: true,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   121
    select: true,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   122
    textInput: true,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   123
    unload: true
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   124
};
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   125
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   126
// Add custom event adaptors to this list.  This will make it so
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   127
// that delegate, key, available, contentready, etc all will
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   128
// be available through Node.on
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   129
Y.mix(Node.DOM_EVENTS, Y.Env.evt.plugins);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   130
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   131
Node._instances = {};
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   132
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   133
/**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   134
 * Registers plugins to be instantiated at the class level (plugins 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   135
 * which should be plugged into every instance of Node by default).
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   136
 *
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   137
 * @method Node.plug
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   138
 * @static
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   139
 *
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   140
 * @param {Function | Array} plugin Either the plugin class, an array of plugin classes or an array of objects (with fn and cfg properties defined)
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   141
 * @param {Object} config (Optional) If plugin is the plugin class, the configuration for the plugin
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   142
 */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   143
Node.plug = function() {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   144
    var args = g_slice.call(arguments, 0);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   145
    args.unshift(Node);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   146
    Y.Base.plug.apply(Y.Base, args);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   147
    return Node;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   148
};
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   149
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   150
/**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   151
 * Unregisters any class level plugins which have been registered by the Node
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   152
 *
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   153
 * @method Node.unplug
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   154
 * @static
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   155
 *
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   156
 * @param {Function | Array} plugin The plugin class, or an array of plugin classes
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   157
 */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   158
Node.unplug = function() {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   159
    var args = g_slice.call(arguments, 0);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   160
    args.unshift(Node);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   161
    Y.Base.unplug.apply(Y.Base, args);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   162
    return Node;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   163
};
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   164
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   165
/**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   166
 * Retrieves the DOM node bound to a Node instance
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   167
 * @method Node.getDOMNode
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   168
 * @static
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   169
 *
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   170
 * @param {Y.Node || HTMLNode} node The Node instance or an HTMLNode
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   171
 * @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
   172
 * as the node argument, it is simply returned.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   173
 */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   174
Node.getDOMNode = function(node) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   175
    if (node) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   176
        if (node instanceof Node) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   177
            node = g_nodes[node[UID]];
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   178
        } else if (!node[NODE_NAME] || Y.DOM.isWindow(node)) { // must already be a DOMNode 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   179
            node = null;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   180
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   181
    }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   182
    return node || null;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   183
};
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   184
 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   185
Node.scrubVal = function(val, node, depth) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   186
    if (node && val) { // only truthy values are risky
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   187
        if (typeof val === 'object' || typeof val === 'function') { // safari nodeList === function
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   188
            if (NODE_TYPE in val || Y.DOM.isWindow(val)) {// node || window
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   189
                if (g_restrict[node[UID]] && !node.contains(val)) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   190
                    val = null; // not allowed to go outside of root node
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
                    val = Node.get(val);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   193
                }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   194
            } else if (val.item || // dom collection or Node instance // TODO: check each node for restrict? block ancestor?
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   195
                    (val[0] && val[0][NODE_TYPE])) { // array of DOM Nodes
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   196
                val = Y.all(val);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   197
            } else {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   198
                depth = (depth === undefined) ? 4 : depth;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   199
                if (depth > 0) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   200
                    for (var i in val) { // TODO: test this and pull hasOwnProperty check if safe?
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   201
                        if (val.hasOwnProperty && val.hasOwnProperty(i)) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   202
                            val[i] = Node.scrubVal(val[i], node, --depth);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   203
                        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   204
                    }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   205
                }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   206
            }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   207
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   208
    } else if (val === undefined) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   209
        val = node; // for chaining
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   210
    }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   211
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   212
    return val;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   213
};
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   214
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   215
Node.addMethod = function(name, fn, context) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   216
    if (name && fn && typeof fn === 'function') {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   217
        Node.prototype[name] = function() {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   218
            context = context || this;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   219
            var args = g_slice.call(arguments),
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   220
                ret;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   221
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   222
            if (args[0] && args[0] instanceof Node) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   223
                args[0] = Node.getDOMNode(args[0]);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   224
            }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   225
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   226
            if (args[1] && args[1] instanceof Node) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   227
                args[1] = Node.getDOMNode(args[1]);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   228
            }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   229
            args.unshift(g_nodes[this[UID]]);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   230
            ret = Node.scrubVal(fn.apply(context, args), this);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   231
            return ret;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   232
        };
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   233
    } else {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   234
        Y.log('unable to add method: ' + name, 'warn', 'Node');
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
Node.importMethod = function(host, name, altName) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   239
    if (typeof name === 'string') {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   240
        altName = altName || name;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   241
        Node.addMethod(altName, host[name], host);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   242
    } else {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   243
        Y.each(name, function(n) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   244
            Node.importMethod(host, n);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   245
        });
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   246
    }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   247
};
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   248
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   249
/**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   250
 * Returns a single Node instance bound to the node or the
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   251
 * first element matching the given selector.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   252
 * @method Y.get
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   253
 * @static
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   254
 * @param {String | HTMLElement} node a node or Selector 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   255
 * @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
   256
 * @param {Boolean} restrict Whether or not the Node instance should be restricted to accessing
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   257
 * its subtree only.
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.get = function(node, doc, restrict) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   260
    var instance = null;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   261
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   262
    if (typeof node === 'string') {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   263
        if (node.indexOf('doc') === 0) { // doc OR document
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   264
            node = Y.config.doc;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   265
        } else if (node.indexOf('win') === 0) { // doc OR document
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   266
            node = Y.config.win;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   267
        } else {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   268
            node = Y.Selector.query(node, doc, true);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   269
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   270
    }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   271
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   272
    if (node) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   273
        instance = Node._instances[node[UID]]; // reuse exising instances
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   274
        if (!instance) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   275
            instance = new Node(node, restrict);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   276
        } else if (restrict) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   277
            g_restrict[instance[UID]] = true;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   278
            instance._set('restricted', true);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   279
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   280
    }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   281
    // TODO: restrict on subsequent call?
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   282
    return instance;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   283
};
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
 * Creates a new dom node using the provided markup string. 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   287
 * @method create
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   288
 * @static
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   289
 * @param {String} html The markup used to create the element
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   290
 * @param {HTMLDocument} doc An optional document context 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   291
 */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   292
Node.create = function() {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   293
    return Node.get(Y.DOM.create.apply(Y.DOM, arguments));
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
Node.ATTRS = {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   297
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   298
     * Allows for getting and setting the text of an element.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   299
     * Formatting is preserved and special characters are treated literally.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   300
     * @config text
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   301
     * @type String
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   302
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   303
    text: {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   304
        getter: function() {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   305
            return Y.DOM.getText(g_nodes[this[UID]]);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   306
        },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   307
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   308
        setter: function(content) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   309
            Y.DOM.setText(g_nodes[this[UID]], content);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   310
            return content;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   311
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   312
    },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   313
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   314
    'options': {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   315
        getter: function() {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   316
            return this.getElementsByTagName('option');
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   317
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   318
    },
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
     * Returns a NodeList instance of all HTMLElement children.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   322
     * @readOnly
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   323
     * @config children
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   324
     * @type NodeList
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   325
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   326
    'children': {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   327
        getter: function() {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   328
            var node = g_nodes[this[UID]],
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   329
                children = node.children,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   330
                childNodes, i, len;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   331
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   332
            if (children === undefined) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   333
                childNodes = node.childNodes;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   334
                children = [];
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   335
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   336
                for (i = 0, len = childNodes.length; i < len; ++i) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   337
                    if (childNodes[i][TAG_NAME]) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   338
                        children[children.length] = childNodes[i];
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   339
                    }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   340
                }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   341
            }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   342
            return Y.all(children);
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
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   346
    value: {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   347
        getter: function() {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   348
            return Y.DOM.getValue(g_nodes[this[UID]]);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   349
        },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   350
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   351
        setter: function(val) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   352
            Y.DOM.setValue(g_nodes[this[UID]], val);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   353
            return val;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   354
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   355
    },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   356
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   357
/*
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   358
    style: {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   359
        getter: function(attr) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   360
            return Y.DOM.getStyle(g_nodes[this[UID]].style, attr);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   361
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   362
    },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   363
*/
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   364
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   365
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   366
     * Whether or not this Node can traverse outside of its subtree.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   367
     * @config restricted
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   368
     * @writeOnce
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   369
     * @type Boolean
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   370
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   371
    restricted: {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   372
        writeOnce: true,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   373
        value: false
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
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   377
// call with instance context
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   378
Node.DEFAULT_SETTER = function(name, val) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   379
    var node = g_nodes[this[UID]],
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   380
        strPath;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   381
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   382
    if (name.indexOf(DOT) > -1) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   383
        strPath = name;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   384
        name = name.split(DOT);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   385
        Y.Object.setValue(node, name, val);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   386
    } else if (node[name] !== undefined) { // only set DOM attributes
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   387
        node[name] = val;
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
    return val;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   391
};
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   392
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   393
// call with instance context
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   394
Node.DEFAULT_GETTER = function(name) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   395
    var node = g_nodes[this[UID]],
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   396
        val;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   397
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   398
    if (name.indexOf && name.indexOf(DOT) > -1) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   399
        val = Y.Object.getValue(node, name.split(DOT));
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   400
    } else {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   401
        val = node[name];
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   402
    }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   403
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   404
    return val ? Y.Node.scrubVal(val, this) : val;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   405
};
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   406
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   407
Y.extend(Node, Y.Base);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   408
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   409
Y.mix(Node.prototype, {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   410
    toString: function() {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   411
        var str = '',
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   412
            errorMsg = this[UID] + ': not bound to a node',
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   413
            node = g_nodes[this[UID]];
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 (node) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   416
            str += node[NODE_NAME];
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   417
            if (node.id) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   418
                str += '#' + node.id; 
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
            if (node.className) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   422
                str += '.' + node.className.replace(' ', '.'); 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   423
            }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   424
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   425
            // TODO: add yuid?
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   426
            str += ' ' + this[UID];
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   427
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   428
        return str || errorMsg;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   429
    },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   430
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   431
    _addDOMAttr: function(attr) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   432
        var domNode = g_nodes[this[UID]];
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   433
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   434
        if (domNode && domNode[attr] !== undefined) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   435
            this.addAttr(attr, {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   436
                getter: function() {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   437
                    return Node.DEFAULT_GETTER.call(this, attr);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   438
                },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   439
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   440
                setter: function(val) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   441
                    return Node.DEFAULT_SETTER.call(this, attr, val);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   442
                }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   443
            });
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   444
        } else {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   445
            Y.log('unable to add DOM attribute: ' + attr + ' to node: ' + this, 'warn', 'Node');
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   446
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   447
    },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   448
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   449
    get: function(attr) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   450
        if (!this.attrAdded(attr)) { // use DEFAULT_GETTER for unconfigured attrs
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   451
            if (Node.re_aria && Node.re_aria.test(attr)) { // except for aria
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   452
                this._addAriaAttr(attr);
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
                return Node.DEFAULT_GETTER.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 SuperConstrProto.get.apply(this, arguments);
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
    set: function(attr, val) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   462
        if (!this.attrAdded(attr)) { // use DEFAULT_SETTER for unconfigured attrs
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   463
            // except for aria
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   464
            if (Node.re_aria && Node.re_aria.test(attr)) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   465
                this._addAriaAttr(attr);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   466
            //  or chained properties or if no change listeners
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   467
            } else if (attr.indexOf(DOT) < 0 && this._yuievt.events['Node:' + attr + 'Change']) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   468
                this._addDOMAttr(attr);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   469
            } else {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   470
                Node.DEFAULT_SETTER.call(this, attr, val);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   471
                return this; // NOTE: return
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   472
            }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   473
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   474
        SuperConstrProto.set.apply(this, arguments);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   475
        return this;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   476
    },
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
     * Creates a new Node using the provided markup string. 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   480
     * @method create
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   481
     * @param {String} html The markup used to create the element
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   482
     * @param {HTMLDocument} doc An optional document context 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   483
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   484
    create: Node.create,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   485
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   486
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   487
     * Compares nodes to determine if they match.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   488
     * Node instances can be compared to each other and/or HTMLElements.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   489
     * @method compareTo
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   490
     * @param {HTMLElement | Node} refNode The reference node to compare to the node.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   491
     * @return {Boolean} True if the nodes match, false if they do not. 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   492
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   493
    compareTo: function(refNode) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   494
        var node = g_nodes[this[UID]];
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   495
        if (refNode instanceof Y.Node) { 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   496
            refNode = Y.Node.getDOMNode(refNode);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   497
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   498
        return node === refNode;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   499
    },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   500
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   501
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   502
     * Determines whether the node is appended to the document.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   503
     * @method inDoc
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   504
     * @param {Node|HTMLElement} doc optional An optional document to check against.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   505
     * Defaults to current document. 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   506
     * @return {Boolean} Whether or not this node is appended to the document. 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   507
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   508
    inDoc: function(doc) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   509
        var node = g_nodes[this[UID]];
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   510
        doc = (doc) ? Node.getDOMNode(doc) : node[OWNER_DOCUMENT];
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   511
        if (doc.documentElement) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   512
            return Y.DOM.contains(doc.documentElement, node);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   513
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   514
    },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   515
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   516
    getById: function(id) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   517
        var node = g_nodes[this[UID]],
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   518
            ret = Y.DOM.byId(id, node[OWNER_DOCUMENT]);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   519
        if (ret && Y.DOM.contains(node, ret)) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   520
            ret = Y.get(ret);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   521
        } else {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   522
            ret = null;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   523
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   524
        return ret;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   525
    },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   526
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   527
   /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   528
     * Returns the nearest ancestor that passes the test applied by supplied boolean method.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   529
     * @method ancestor
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   530
     * @param {String | Function} fn A selector or boolean method for testing elements.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   531
     * 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
   532
     * @return {Node} The matching Node instance or null if not found
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   533
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   534
    ancestor: function(fn) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   535
        return Node.get(Y.DOM.elementByAxis(g_nodes[this[UID]], 'parentNode', _wrapFn(fn)));
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   536
    },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   537
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   538
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   539
     * Returns the previous matching sibling. 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   540
     * Returns the nearest element node sibling if no method provided.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   541
     * @method previous
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   542
     * @param {String | Function} fn A selector or boolean method for testing elements.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   543
     * 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
   544
     * @return {Node} Node instance or null if not found
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   545
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   546
    previous: function(fn, all) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   547
        return Node.get(Y.DOM.elementByAxis(g_nodes[this[UID]], 'previousSibling', _wrapFn(fn), all));
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   548
    }, 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   549
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   550
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   551
     * Returns the next matching sibling. 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   552
     * Returns the nearest element node sibling if no method provided.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   553
     * @method next
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   554
     * @param {String | Function} fn A selector or boolean method for testing elements.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   555
     * 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
   556
     * @return {Node} Node instance or null if not found
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   557
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   558
    next: function(node, fn, all) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   559
        return Node.get(Y.DOM.elementByAxis(g_nodes[this[UID]], 'nextSibling', _wrapFn(fn), all));
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   560
    },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   561
        
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   562
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   563
     * Retrieves a Node instance of nodes based on the given CSS selector. 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   564
     * @method query
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   565
     *
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   566
     * @param {string} selector The CSS selector to test against.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   567
     * @return {Node} A Node instance for the matching HTMLElement.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   568
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   569
    query: function(selector) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   570
        return Y.get(Y.Selector.query(selector, g_nodes[this[UID]], true));
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   571
    },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   572
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   573
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   574
     * Retrieves a nodeList based on the given CSS selector. 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   575
     * @method queryAll
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   576
     *
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   577
     * @param {string} selector The CSS selector to test against.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   578
     * @return {NodeList} A NodeList instance for the matching HTMLCollection/Array.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   579
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   580
    queryAll: function(selector) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   581
        return Y.all(Y.Selector.query(selector, g_nodes[this[UID]]));
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
    // TODO: allow fn test
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   585
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   586
     * Test if the supplied node matches the supplied selector.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   587
     * @method test
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   588
     *
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   589
     * @param {string} selector The CSS selector to test against.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   590
     * @return {boolean} Whether or not the node matches the selector.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   591
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   592
    test: function(selector) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   593
        return Y.Selector.test(g_nodes[this[UID]], selector);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   594
    },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   595
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   596
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   597
     * Removes the node from its parent.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   598
     * Shortcut for myNode.get('parentNode').removeChild(myNode);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   599
     * @method remove
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   600
     * @chainable
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   601
     *
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   602
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   603
    remove: function() {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   604
        var node = g_nodes[this[UID]];
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   605
        node.parentNode.removeChild(node);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   606
        return this;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   607
    },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   608
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   609
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   610
     * Invokes a method on the Node instance 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   611
     * @method invoke
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   612
     * @param {String} method The name of the method to invoke
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   613
     * @param {Any}  a, b, c, etc. Arguments to invoke the method with. 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   614
     * @return Whatever the underly method returns. 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   615
     * DOM Nodes and Collections return values
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   616
     * are converted to Node/NodeList instances.
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
    invoke: function(method, a, b, c, d, e) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   620
        var node = g_nodes[this[UID]],
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   621
            ret;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   622
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   623
        if (a && a instanceof Y.Node) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   624
            a = Node.getDOMNode(a);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   625
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   626
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   627
        if (b && b instanceof Y.Node) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   628
            b = Node.getDOMNode(b);
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
        ret = node[method](a, b, c, d, e);    
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   632
        return Y.Node.scrubVal(ret, this);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   633
    },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   634
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   635
    destructor: function() {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   636
        // TODO: What about shared instances?
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   637
        //var uid = this[UID];
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   638
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   639
        //delete g_nodes[uid];
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   640
        //delete g_restrict[uid];
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   641
        //delete Node._instances[uid];
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
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   645
     * Applies the given function to each Node in the NodeList.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   646
     * @method each
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   647
     * @deprecated Use NodeList
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   648
     * @param {Function} fn The function to apply 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   649
     * @param {Object} context optional An optional context to apply the function with
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   650
     * Default context is the NodeList instance
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   651
     * @chainable
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   652
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   653
    each: function(fn, context) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   654
        context = context || this;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   655
        Y.log('each is deprecated on Node', 'warn', 'Node');
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   656
        return fn.call(context, 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
     * Retrieves the Node instance at the given index. 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   661
     * @method item
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   662
     * @deprecated Use NodeList
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   663
     *
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   664
     * @param {Number} index The index of the target Node.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   665
     * @return {Node} The Node instance at the given index.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   666
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   667
    item: function(index) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   668
        Y.log('item is deprecated on Node', 'warn', 'Node');
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   669
        return this;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   670
    },
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
     * Returns the current number of items in the Node.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   674
     * @method size
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   675
     * @deprecated Use NodeList
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   676
     * @return {Int} The number of items in the Node. 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   677
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   678
    size: function() {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   679
        Y.log('size is deprecated on Node', 'warn', 'Node');
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   680
        return g_nodes[this[UID]] ? 1 : 0;
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
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   684
     * Inserts the content before the reference node. 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   685
     * @method insert
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   686
     * @param {String | Y.Node | HTMLElement} content The content to insert 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   687
     * @param {Int | Y.Node | HTMLElement | String} where The position to insert at.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   688
     * @chainable
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   689
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   690
    insert: function(content, where) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   691
        if (content) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   692
            if (typeof where === 'number') { // allow index
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   693
                where = g_nodes[this[UID]].childNodes[where];
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   694
            }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   695
            if (typeof content !== 'string') { // pass the DOM node
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   696
                content = Y.Node.getDOMNode(content);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   697
            }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   698
            if (!where || // only allow inserting into this Node's subtree
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   699
                (!g_restrict[this[UID]] || 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   700
                    (typeof where !== 'string' && this.contains(where)))) { 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   701
                Y.DOM.addHTML(g_nodes[this[UID]], content, where);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   702
            }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   703
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   704
        return this;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   705
    },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   706
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   707
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   708
     * Inserts the content as the firstChild of the node. 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   709
     * @method prepend
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   710
     * @param {String | Y.Node | HTMLElement} content The content to insert 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   711
     * @chainable
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   712
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   713
    prepend: function(content) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   714
        return this.insert(content, 0);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   715
    },
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
     * Inserts the content as the lastChild of the node. 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   719
     * @method append
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   720
     * @param {String | Y.Node | HTMLElement} content The content to insert 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   721
     * @chainable
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   722
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   723
    append: function(content) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   724
        return this.insert(content, null);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   725
    },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   726
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   727
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   728
     * Replaces the node's current content with the content.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   729
     * @method setContent
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   730
     * @param {String | Y.Node | HTMLElement} content The content to insert 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   731
     * @chainable
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   732
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   733
    setContent: function(content) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   734
        Y.DOM.addHTML(g_nodes[this[UID]], content, 'replace');
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   735
        return this;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   736
    },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   737
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   738
    // TODO: need this?
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   739
    hasMethod: function(method) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   740
        var node = g_nodes[this[UID]];
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   741
        return (node && (typeof node === 'function'));
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   742
    }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   743
}, true);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   744
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   745
Y.Node = Node;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   746
Y.get = Y.Node.get;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   747
/**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   748
 * The NodeList module provides support for managing collections of Nodes.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   749
 * @module node
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   750
 * @submodule nodelist
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   751
 */    
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   752
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   753
/**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   754
 * The NodeList class provides a wrapper for manipulating DOM NodeLists.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   755
 * NodeList properties can be accessed via the set/get methods.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   756
 * Use Y.all() to retrieve NodeList instances.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   757
 *
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   758
 * @class NodeList
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   759
 * @constructor
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   760
 */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   761
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   762
Y.Array._diff = function(a, b) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   763
    var removed = [],
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   764
        present = false,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   765
        i, j, lenA, lenB;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   766
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   767
    outer:
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   768
    for (i = 0, lenA = a.length; i < lenA; i++) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   769
        present = false;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   770
        for (j = 0, lenB = b.length; j < lenB; j++) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   771
            if (a[i] === b[j]) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   772
                present = true;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   773
                continue outer;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   774
            }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   775
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   776
        if (!present) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   777
            removed[removed.length] = a[i];
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 removed;
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.Array.diff = function(a, b) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   784
    return {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   785
        added: Y.Array._diff(b, a),
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   786
        removed: Y.Array._diff(a, b)
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
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   790
var NodeList = function(config) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   791
    var doc = config.doc || Y.config.doc,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   792
        nodes = config.nodes || [];
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   793
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   794
    if (typeof nodes === 'string') {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   795
        this._query = nodes;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   796
        nodes = Y.Selector.query(nodes, doc);
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
    Y.stamp(this);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   800
    NodeList._instances[this[UID]] = this;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   801
    g_nodelists[this[UID]] = nodes;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   802
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   803
    if (config.restricted) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   804
        g_restrict = this[UID];
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   805
    }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   806
};
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   807
// end "globals"
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   808
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   809
NodeList.NAME = 'NodeList';
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   810
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   811
/**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   812
 * Retrieves the DOM nodes bound to a NodeList instance
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   813
 * @method NodeList.getDOMNodes
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   814
 * @static
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   815
 *
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   816
 * @param {Y.NodeList} node The NodeList instance
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   817
 * @return {Array} The array of DOM nodes bound to the NodeList
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   818
 */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   819
NodeList.getDOMNodes = function(nodeList) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   820
    return g_nodelists[nodeList[UID]];
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   821
};
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   822
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   823
NodeList._instances = [];
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   824
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   825
NodeList.each = function(instance, fn, context) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   826
    var nodes = g_nodelists[instance[UID]];
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   827
    if (nodes && nodes.length) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   828
        Y.Array.each(nodes, fn, context || instance);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   829
    } else {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   830
        Y.log('no nodes bound to ' + this, 'warn', 'NodeList');
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   831
    }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   832
};
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   833
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   834
NodeList.addMethod = function(name, fn, context) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   835
    var tmp = NodeList._getTempNode();
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   836
    if (name && fn) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   837
        NodeList.prototype[name] = function() {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   838
            var ret = [],
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   839
                args = arguments;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   840
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   841
            Y.Array.each(g_nodelists[this[UID]], function(node) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   842
                var UID = '_yuid',
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   843
                    instance = Y.Node._instances[node[UID]],
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   844
                    ctx,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   845
                    result;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   846
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   847
                if (!instance) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   848
                    g_nodes[tmp[UID]] = node;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   849
                    instance = tmp;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   850
                }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   851
                ctx = context || instance;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   852
                result = fn.apply(ctx, args);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   853
                if (result !== undefined && result !== instance) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   854
                    ret[ret.length] = result;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   855
                }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   856
            });
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   857
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   858
            // TODO: remove tmp pointer
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   859
            return ret.length ? ret : this;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   860
        };
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   861
    } else {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   862
        Y.log('unable to add method: ' + name, 'warn', 'Node');
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   863
    }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   864
};
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   865
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   866
NodeList.importMethod = function(host, name, altName) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   867
    if (typeof name === 'string') {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   868
        altName = altName || name;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   869
        NodeList.addMethod(name, host[name]);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   870
    } else {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   871
        Y.each(name, function(n) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   872
            NodeList.importMethod(host, n);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   873
        });
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   874
    }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   875
};
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   876
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   877
NodeList._getTempNode = function() {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   878
    var tmp = NodeList._tempNode;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   879
        if (!tmp) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   880
            tmp = Y.Node.create('<div></div>');
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   881
            NodeList._tempNode = tmp;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   882
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   883
    return tmp;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   884
};
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   885
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   886
Y.mix(NodeList.prototype, {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   887
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   888
     * Retrieves the Node instance at the given index. 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   889
     * @method item
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   890
     *
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   891
     * @param {Number} index The index of the target Node.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   892
     * @return {Node} The Node instance at the given index.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   893
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   894
    item: function(index) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   895
        return Y.get((g_nodelists[this[UID]] || [])[index]);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   896
    },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   897
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   898
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   899
     * Applies the given function to each Node in the NodeList.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   900
     * @method each
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   901
     * @param {Function} fn The function to apply. It receives 3 arguments:
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   902
     * the current node instance, the node's index, and the NodeList instance
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   903
     * @param {Object} context optional An optional context to apply the function with
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   904
     * Default context is the current Node instance
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   905
     * @chainable
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   906
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   907
    each: function(fn, context) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   908
        var instance = this;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   909
        Y.Array.each(g_nodelists[this[UID]], function(node, index) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   910
            node = Y.get(node);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   911
            return fn.call(context || node, node, index, instance);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   912
        });
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   913
        return instance;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   914
    },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   915
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   916
    batch: function(fn, context) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   917
        var nodelist = this,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   918
            tmp = NodeList._getTempNode();
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   919
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   920
        Y.Array.each(g_nodelists[this[UID]], function(node, index) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   921
            var instance = Y.Node._instances[node[UID]];
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   922
            if (!instance) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   923
                g_nodes[tmp[UID]] = node;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   924
                instance = tmp;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   925
            }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   926
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   927
            return fn.call(context || instance, instance, index, nodelist);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   928
        });
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   929
        return nodelist;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   930
    },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   931
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   932
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   933
     * Executes the function once for each node until a true value is returned.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   934
     * @method some
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   935
     * @param {Function} fn The function to apply. It receives 3 arguments:
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   936
     * the current node instance, the node's index, and the NodeList instance
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   937
     * @param {Object} context optional An optional context to execute the function from.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   938
     * Default context is the current Node instance
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   939
     * @return {Boolean} Whether or not the function returned true for any node.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   940
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   941
    some: function(fn, context) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   942
        var instance = this;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   943
        return Y.Array.some(g_nodelists[this[UID]], function(node, index) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   944
            node = Y.get(node);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   945
            context = context || node;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   946
            return fn.call(context, node, index, instance);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   947
        });
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   948
    },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   949
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   950
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   951
     * Returns the index of the node in the NodeList instance
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   952
     * or -1 if the node isn't found.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   953
     * @method indexOf
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   954
     * @param {Y.Node || DOMNode} node the node to search for
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   955
     * @return {Int} the index of the node value or -1 if not found
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   956
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   957
    indexOf: function(node) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   958
        return Y.Array.indexOf(g_nodelists[this[UID]], Y.Node.getDOMNode(node));
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   959
    },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   960
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   961
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   962
     * Filters the NodeList instance down to only nodes matching the given selector.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   963
     * @method filter
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   964
     * @param {String} selector The selector to filter against
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   965
     * @return {NodeList} NodeList containing the updated collection 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   966
     * @see Selector
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   967
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   968
    filter: function(selector) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   969
        return Y.all(Y.Selector.filter(g_nodelists[this[UID]], selector));
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   970
    },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   971
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   972
    modulus: function(n, r) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   973
        r = r || 0;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   974
        var nodes = [];
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   975
        NodeList.each(this, function(node, i) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   976
            if (i % n === r) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   977
                nodes.push(node);
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
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   981
        return Y.all(nodes);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   982
    },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   983
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   984
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   985
     * Creates a new NodeList containing all nodes at odd indices
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   986
     * (zero-based index).
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   987
     * @method odd
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   988
     * @return {NodeList} NodeList containing the updated collection 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   989
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   990
    odd: function() {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   991
        return this.modulus(2, 1);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   992
    },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   993
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   994
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   995
     * Creates a new NodeList containing all nodes at even indices
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   996
     * (zero-based index), including zero. 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   997
     * @method even
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   998
     * @return {NodeList} NodeList containing the updated collection 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   999
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1000
    even: function() {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1001
        return this.modulus(2);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1002
    },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1003
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1004
    destructor: function() {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1005
        delete NodeList._instances[this[UID]];
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1006
    },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1007
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1008
    refresh: function() {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1009
        var doc,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1010
            diff,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1011
            oldList = g_nodelists[this[UID]];
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1012
        if (this._query) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1013
            if (g_nodelists[this[UID]] &&
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1014
                    g_nodelists[this[UID]][0] && 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1015
                    g_nodelists[this[UID]][0].ownerDocument) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1016
                doc = g_nodelists[this[UID]][0].ownerDocument;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1017
            }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1018
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1019
            g_nodelists[this[UID]] = Y.Selector.query(this._query, doc || Y.config.doc);        
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1020
            diff = Y.Array.diff(oldList, g_nodelists[this[UID]]); 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1021
            diff.added = diff.added ? Y.all(diff.added) : null;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1022
            diff.removed = diff.removed ? Y.all(diff.removed) : null;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1023
            this.fire('refresh', diff);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1024
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1025
        return this;
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
     * Applies an event listens to each Node bound to the NodeList. 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1030
     * @method on
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1031
     * @param {String} type The event being listened for
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1032
     * @param {Function} fn The handler to call when the event fires
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1033
     * @param {Object} context The context to call the handler with.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1034
     * Default is the NodeList instance. 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1035
     * @return {Object} Returns an event handle that can later be use to detach(). 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1036
     * @see Event.on
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1037
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1038
    on: function(type, fn, context) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1039
        context = context || this;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1040
        this.batch(function(node) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1041
            node.on.call(node, type, fn, context);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1042
        });
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1043
    },
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
     * Applies an event listens to each Node bound to the NodeList. 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1047
     * The handler is called only after all on() handlers are called
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1048
     * and the event is not prevented.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1049
     * @method after
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1050
     * @param {String} type The event being listened for
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1051
     * @param {Function} fn The handler to call when the event fires
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1052
     * @param {Object} context The context to call the handler with.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1053
     * Default is the NodeList instance. 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1054
     * @return {Object} Returns an event handle that can later be use to detach(). 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1055
     * @see Event.on
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1056
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1057
    after: function(type, fn, context) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1058
        context = context || this;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1059
        this.batch(function(node) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1060
            node.after.call(node, type, fn, context);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1061
        });
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1062
    },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1063
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1064
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1065
     * Returns the current number of items in the NodeList.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1066
     * @method size
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1067
     * @return {Int} The number of items in the NodeList. 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1068
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1069
    size: function() {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1070
        return g_nodelists[this[UID]].length;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1071
    },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1072
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1073
    /** Called on each Node instance
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1074
      * @get
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1075
      * @see Node
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1076
      */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1077
    // one-off because we cant import from Node due to undefined return values
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1078
    get: function(name) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1079
        var ret = [],
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1080
            tmp = NodeList._getTempNode();
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1081
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1082
        NodeList.each(this, function(node) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1083
            var instance = Y.Node._instances[node[UID]];
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1084
            if (!instance) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1085
                g_nodes[tmp[UID]] = node;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1086
                instance = tmp;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1087
            }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1088
            ret[ret.length] = instance.get(name);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1089
        });
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1090
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1091
        return ret;
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
    toString: function() {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1095
        var str = '',
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1096
            errorMsg = this[UID] + ': not bound to any nodes',
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1097
            nodes = g_nodelists[this[UID]],
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1098
            node;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1099
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1100
        if (nodes && nodes[0]) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1101
            node = nodes[0];
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1102
            str += node[NODE_NAME];
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1103
            if (node.id) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1104
                str += '#' + node.id; 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1105
            }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1106
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1107
            if (node.className) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1108
                str += '.' + node.className.replace(' ', '.'); 
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
            if (nodes.length > 1) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1112
                str += '...[' + nodes.length + ' items]';
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1113
            }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1114
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1115
        return str || errorMsg;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1116
    }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1117
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1118
}, true);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1119
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1120
NodeList.importMethod(Y.Node.prototype, [
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1121
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1122
     * Called on each Node instance
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1123
     * @for NodeList
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1124
     * @method append
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1125
     * @see Node.append
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1126
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1127
    'append',
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
      * Called on each Node instance
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1131
      * @method detach
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1132
      * @see Node.detach
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1133
      */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1134
    'detach',
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1135
    
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1136
    /** Called on each Node instance
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1137
      * @method detachAll
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1138
      * @see Node.detachAll
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1139
      */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1140
    'detachAll',
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1141
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1142
    /** Called on each Node instance
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1143
      * @method insert
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1144
      * @see NodeInsert
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1145
      */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1146
    'insert',
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1147
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1148
    /** Called on each Node instance
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1149
      * @method plug
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1150
      * @see Node.plug
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1151
      */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1152
    'plug',
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1153
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1154
    /** Called on each Node instance
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1155
      * @method prepend
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1156
      * @see Node.prepend
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1157
      */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1158
    'prepend',
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1159
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1160
    /** Called on each Node instance
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1161
      * @method remove
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1162
      * @see Node.remove
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1163
      */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1164
    'remove',
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
      * @method set
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1168
      * @see Node.set
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1169
      */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1170
    'set',
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1171
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1172
    /** Called on each Node instance
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1173
      * @method setContent
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1174
      * @see Node.setContent
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1175
      */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1176
    'setContent',
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1177
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1178
    /** Called on each Node instance
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1179
      * @method unplug
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1180
      * @see Node.unplug
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1181
      */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1182
    'unplug'
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1183
]);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1184
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1185
Y.NodeList = NodeList;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1186
Y.all = function(nodes, doc, restrict) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1187
    // TODO: propagate restricted to nodes?
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1188
    var nodeList = new NodeList({
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1189
        nodes: nodes,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1190
        doc: doc,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1191
        restricted: restrict
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1192
    });
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1193
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1194
    // zero-length result returns null
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1195
    return nodeList;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1196
};
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1197
Y.Node.all = Y.all; // TODO: deprecated
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1198
Y.Array.each([
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1199
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1200
     * Passes through to DOM method.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1201
     * @method replaceChild
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1202
     * @for Node
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1203
     * @param {HTMLElement | Node} node Node to be inserted 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1204
     * @param {HTMLElement | Node} refNode Node to be replaced 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1205
     * @return {Node} The replaced node 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1206
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1207
    'replaceChild',
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1208
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1209
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1210
     * Passes through to DOM method.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1211
     * @method appendChild
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1212
     * @param {HTMLElement | Node} node Node to be appended 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1213
     * @return {Node} The appended node 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1214
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1215
    'appendChild',
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1216
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1217
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1218
     * Passes through to DOM method.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1219
     * @method insertBefore
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1220
     * @param {HTMLElement | Node} newNode Node to be appended 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1221
     * @param {HTMLElement | Node} refNode Node to be inserted before 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1222
     * @return {Node} The inserted 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
    'insertBefore',
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1225
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1226
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1227
     * Passes through to DOM method.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1228
     * @method removeChild
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1229
     * @param {HTMLElement | Node} node Node to be removed 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1230
     * @return {Node} The removed node 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1231
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1232
    'removeChild',
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1233
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1234
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1235
     * Passes through to DOM method.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1236
     * @method hasChildNodes
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1237
     * @return {Boolean} Whether or not the node has any childNodes 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1238
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1239
    'hasChildNodes',
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1240
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1241
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1242
     * Passes through to DOM method.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1243
     * @method cloneNode
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1244
     * @param {HTMLElement | Node} node Node to be cloned 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1245
     * @return {Node} The clone 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1246
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1247
    'cloneNode',
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1248
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1249
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1250
     * Passes through to DOM method.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1251
     * @method hasAttribute
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1252
     * @param {String} attribute The attribute to test for 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1253
     * @return {Boolean} Whether or not the attribute is present 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1254
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1255
    'hasAttribute',
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
     * Passes through to DOM method.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1259
     * @method removeAttribute
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1260
     * @param {String} attribute The attribute to be removed 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1261
     * @chainable
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1262
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1263
    'removeAttribute',
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1264
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1265
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1266
     * Passes through to DOM method.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1267
     * @method scrollIntoView
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1268
     * @chainable
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1269
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1270
    'scrollIntoView',
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1271
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1272
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1273
     * Passes through to DOM method.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1274
     * @method getElementsByTagName
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1275
     * @param {String} tagName The tagName to collect 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1276
     * @return {NodeList} A NodeList representing the HTMLCollection
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1277
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1278
    'getElementsByTagName',
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1279
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1280
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1281
     * Passes through to DOM method.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1282
     * @method focus
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1283
     * @chainable
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1284
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1285
    'focus',
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1286
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1287
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1288
     * Passes through to DOM method.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1289
     * @method blur
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1290
     * @chainable
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1291
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1292
    'blur',
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1293
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1294
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1295
     * Passes through to DOM method.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1296
     * Only valid on FORM elements
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1297
     * @method submit
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1298
     * @chainable
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1299
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1300
    'submit',
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1301
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1302
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1303
     * Passes through to DOM method.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1304
     * Only valid on FORM elements
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1305
     * @method reset
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1306
     * @chainable
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1307
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1308
    'reset',
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1309
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1310
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1311
     * Passes through to DOM method.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1312
     * @method select
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1313
     * @chainable
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1314
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1315
     'select'
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1316
], function(method) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1317
    Y.Node.prototype[method] = function(arg1, arg2, arg3) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1318
        var ret = this.invoke(method, arg1, arg2, arg3);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1319
        return ret;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1320
    };
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1321
});
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1322
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1323
Node.importMethod(Y.DOM, [
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1324
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1325
     * 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
  1326
     * @method contains
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1327
     * @param {Node | HTMLElement} needle The possible node or descendent
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1328
     * @return {Boolean} Whether or not this node is the needle its ancestor
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1329
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1330
    'contains',
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1331
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1332
     * Allows setting attributes on DOM nodes, normalizing in some cases.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1333
     * This passes through to the DOM node, allowing for custom attributes.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1334
     * @method setAttribute
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1335
     * @for Node
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1336
     * @for NodeList
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1337
     * @chainable
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1338
     * @param {string} name The attribute name 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1339
     * @param {string} value The value to set
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1340
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1341
    'setAttribute',
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1342
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1343
     * Allows getting attributes on DOM nodes, normalizing in some cases.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1344
     * This passes through to the DOM node, allowing for custom attributes.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1345
     * @method getAttribute
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1346
     * @for Node
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1347
     * @for NodeList
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1348
     * @param {string} name The attribute name 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1349
     * @return {string} The attribute value 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1350
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1351
    'getAttribute'
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1352
]);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1353
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1354
if (!document.documentElement.hasAttribute) { // IE < 8
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1355
    Y.Node.prototype.hasAttribute = function(attr) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1356
        return Y.DOM.getAttribute(Y.Node.getDOMNode(this), attr) !== '';
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1357
    };
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1358
}
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1359
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1360
/**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1361
 * Allows setting attributes on DOM nodes, normalizing in some cases.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1362
 * This passes through to the DOM node, allowing for custom attributes.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1363
 * @method setAttribute
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1364
 * @see Node
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1365
 * @for NodeList
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
 * @param {string} name The attribute name 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1368
 * @param {string} value The value to set
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
/**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1372
 * Allows getting attributes on DOM nodes, normalizing in some cases.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1373
 * This passes through to the DOM node, allowing for custom attributes.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1374
 * @method getAttribute
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1375
 * @see Node
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1376
 * @for NodeList
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1377
 * @param {string} name The attribute name 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1378
 * @return {string} The attribute value 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1379
 */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1380
Y.NodeList.importMethod(Y.Node.prototype, ['getAttribute', 'setAttribute']);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1381
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1382
(function() { // IE clones expandos; regenerate UID
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1383
    var node = document.createElement('div'),
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1384
        UID = '_yuid';
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1385
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1386
    Y.stamp(node);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1387
    if (node[UID] === node.cloneNode(true)[UID]) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1388
        Y.Node.prototype.cloneNode = function(deep) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1389
            var node = Y.Node.getDOMNode(this).cloneNode(deep);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1390
            node[UID] = Y.guid();
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1391
            return Y.get(node);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1392
        };
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1393
    }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1394
})();
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1395
(function(Y) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1396
    var methods = [
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1397
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1398
     * Determines whether each node has the given className.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1399
     * @method hasClass
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1400
     * @for Node
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1401
     * @param {String} className the class name to search for
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1402
     * @return {Array} An array of booleans for each node bound to the NodeList. 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1403
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1404
     'hasClass',
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1405
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1406
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1407
     * Adds a class name to each node.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1408
     * @method addClass         
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1409
     * @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
  1410
     * @chainable
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1411
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1412
     'addClass',
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1413
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1414
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1415
     * Removes a class name from each node.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1416
     * @method removeClass         
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1417
     * @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
  1418
     * @chainable
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1419
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1420
     'removeClass',
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
     * Replace a class with another class for each node.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1424
     * If no oldClassName is present, the newClassName is simply added.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1425
     * @method replaceClass  
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1426
     * @param {String} oldClassName the class name to be replaced
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1427
     * @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
  1428
     * @chainable
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1429
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1430
     'replaceClass',
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
     * 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
  1434
     * @method toggleClass  
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1435
     * @param {String} className the class name to be toggled
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1436
     * @chainable
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1437
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1438
     'toggleClass'
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1439
    ];
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1440
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1441
    Y.Node.importMethod(Y.DOM, methods);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1442
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1443
     * Determines whether each node has the given className.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1444
     * @method hasClass
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1445
     * @see Node.hasClass
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1446
     * @for NodeList
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1447
     * @param {String} className the class name to search for
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1448
     * @return {Array} An array of booleans for each node bound to the NodeList. 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1449
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1450
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1451
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1452
     * Adds a class name to each node.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1453
     * @method addClass         
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1454
     * @see Node.addClass
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1455
     * @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
  1456
     * @chainable
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1457
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1458
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1459
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1460
     * Removes a class name from each node.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1461
     * @method removeClass         
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1462
     * @see Node.removeClass
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1463
     * @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
  1464
     * @chainable
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1465
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1466
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1467
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1468
     * Replace a class with another class for each node.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1469
     * If no oldClassName is present, the newClassName is simply added.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1470
     * @method replaceClass  
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1471
     * @see Node.replaceClass
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1472
     * @param {String} oldClassName the class name to be replaced
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1473
     * @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
  1474
     * @chainable
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1475
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1476
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1477
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1478
     * 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
  1479
     * @method toggleClass  
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1480
     * @see Node.toggleClass
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1481
     * @param {String} className the class name to be toggled
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1482
     * @chainable
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1483
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1484
    Y.NodeList.importMethod(Y.Node.prototype, methods);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1485
})(Y);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1486
/**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1487
 * Functionality to make the node a delegated event container
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1488
 * @module node
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1489
 * @submodule node-event-delegate
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1490
 */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1491
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1492
/**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1493
 * Functionality to make the node a delegated event container
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1494
 * @method delegate
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1495
 * @param type {String} the event type to delegate
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1496
 * @param fn {Function} the function to execute
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1497
 * @param selector {String} a selector that must match the target of the event.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1498
 * @return {Event.Handle} the detach handle
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1499
 * @for Node
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1500
 */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1501
Y.Node.prototype.delegate = function(type, fn, selector, context) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1502
    context = context || this;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1503
    var args = Array.prototype.slice.call(arguments, 4),
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1504
        a = ['delegate', fn, Y.Node.getDOMNode(this), type, selector, context];
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1505
    a = a.concat(args);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1506
    return Y.on.apply(Y, a);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1507
};
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1508
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1509
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1510
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1511
}, '3.0.0b1' ,{requires:['dom-base', 'base', 'selector']});
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1512
YUI.add('node-style', function(Y) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1513
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1514
(function(Y) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1515
/**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1516
 * Extended Node interface for managing node styles.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1517
 * @module node
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1518
 * @submodule node-style
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1519
 */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1520
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1521
var methods = [
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1522
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1523
     * Returns the style's current value.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1524
     * @method getStyle
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1525
     * @for Node
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1526
     * @param {String} attr The style attribute to retrieve. 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1527
     * @return {String} The current value of the style property for the element.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1528
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1529
    'getStyle',
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1530
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1531
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1532
     * Returns the computed value for the given style property.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1533
     * @method getComputedStyle
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1534
     * @param {String} attr The style attribute to retrieve. 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1535
     * @return {String} The computed value of the style property for the element.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1536
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1537
    'getComputedStyle',
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
     * Sets a style property of the node.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1541
     * @method setStyle
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1542
     * @param {String} attr The style attribute to set. 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1543
     * @param {String|Number} val The value. 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1544
     * @chainable
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1545
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1546
    'setStyle',
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1547
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1548
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1549
     * Sets multiple style properties on the node.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1550
     * @method setStyles
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1551
     * @param {Object} hash An object literal of property:value pairs. 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1552
     * @chainable
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1553
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1554
    'setStyles'
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1555
];
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1556
Y.Node.importMethod(Y.DOM, methods);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1557
/**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1558
 * Returns an array of values for each node.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1559
 * @method getStyle
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1560
 * @for NodeList
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1561
 * @see Node.getStyle
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1562
 * @param {String} attr The style attribute to retrieve. 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1563
 * @return {Array} The current values of the style property for the element.
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
/**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1567
 * Returns an array of the computed value for each node.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1568
 * @method getComputedStyle
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1569
 * @see Node.getComputedStyle
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1570
 * @param {String} attr The style attribute to retrieve. 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1571
 * @return {Array} The computed values for each node.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1572
 */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1573
'getComputedStyle',
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1574
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1575
/**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1576
 * Sets a style property on each node.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1577
 * @method setStyle
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1578
 * @see Node.setStyle
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1579
 * @param {String} attr The style attribute to set. 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1580
 * @param {String|Number} val The value. 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1581
 * @chainable
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1582
 */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1583
'setStyle',
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1584
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1585
/**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1586
 * Sets multiple style properties on each node.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1587
 * @method setStyles
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1588
 * @see Node.setStyles
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1589
 * @param {Object} hash An object literal of property:value pairs. 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1590
 * @chainable
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1591
 */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1592
'setStyles'
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1593
Y.NodeList.importMethod(Y.Node.prototype, methods);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1594
})(Y);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1595
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1596
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1597
}, '3.0.0b1' ,{requires:['dom-style', 'node-base']});
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1598
YUI.add('node-screen', function(Y) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1599
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1600
/**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1601
 * Extended Node interface for managing regions and screen positioning.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1602
 * Adds support for positioning elements and normalizes window size and scroll detection. 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1603
 * @module node
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1604
 * @submodule node-screen
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1605
 */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1606
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1607
// these are all "safe" returns, no wrapping required
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1608
Y.each([
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1609
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1610
     * Returns the inner width of the viewport (exludes scrollbar). 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1611
     * @config winWidth
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1612
     * @for Node
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1613
     * @type {Int}
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1614
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1615
    'winWidth',
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1616
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1617
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1618
     * Returns the inner height of the viewport (exludes scrollbar). 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1619
     * @config winHeight
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1620
     * @type {Int}
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1621
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1622
    'winHeight',
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1623
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1624
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1625
     * Document width 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1626
     * @config winHeight
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1627
     * @type {Int}
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1628
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1629
    'docWidth',
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1630
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1631
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1632
     * Document height 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1633
     * @config docHeight
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1634
     * @type {Int}
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1635
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1636
    'docHeight',
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1637
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1638
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1639
     * Amount page has been scroll vertically 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1640
     * @config docScrollX
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1641
     * @type {Int}
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1642
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1643
    'docScrollX',
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1644
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1645
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1646
     * Amount page has been scroll horizontally 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1647
     * @config docScrollY
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1648
     * @type {Int}
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1649
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1650
    'docScrollY'
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1651
    ],
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1652
    function(name) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1653
        Y.Node.ATTRS[name] = {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1654
            getter: function() {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1655
                var args = Array.prototype.slice.call(arguments);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1656
                args.unshift(Y.Node.getDOMNode(this));
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1657
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1658
                return Y.DOM[name].apply(this, args);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1659
            }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1660
        };
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1661
    }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1662
);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1663
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1664
Y.Node.ATTRS.scrollLeft = {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1665
    getter: function() {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1666
        var node = Y.Node.getDOMNode(this);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1667
        return ('scrollLeft' in node) ? node.scrollLeft : Y.DOM.docScrollX(node);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1668
    },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1669
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1670
    setter: function(val) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1671
        var node = Y.Node.getDOMNode(this);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1672
        if (node) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1673
            if ('scrollLeft' in node) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1674
                node.scrollLeft = val;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1675
            } else if (node.document || node.nodeType === 9) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1676
                Y.DOM._getWin(node).scrollTo(val, Y.DOM.docScrollY(node)); // scroll window if win or doc
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1677
            }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1678
        } else {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1679
            Y.log('unable to set scrollLeft for ' + node, 'error', 'Node');
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1680
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1681
    }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1682
};
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1683
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1684
Y.Node.ATTRS.scrollTop = {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1685
    getter: function() {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1686
        var node = Y.Node.getDOMNode(this);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1687
        return ('scrollTop' in node) ? node.scrollTop : Y.DOM.docScrollY(node);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1688
    },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1689
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1690
    setter: function(val) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1691
        var node = Y.Node.getDOMNode(this);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1692
        if (node) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1693
            if ('scrollTop' in node) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1694
                node.scrollTop = val;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1695
            } else if (node.document || node.nodeType === 9) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1696
                Y.DOM._getWin(node).scrollTo(Y.DOM.docScrollX(node), val); // scroll window if win or doc
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1697
            }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1698
        } else {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1699
            Y.log('unable to set scrollTop for ' + node, 'error', 'Node');
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1700
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1701
    }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1702
};
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1703
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1704
Y.Node.importMethod(Y.DOM, [
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1705
/**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1706
 * Gets the current position of the node in page coordinates. 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1707
 * @method getXY
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1708
 * @for Node
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1709
 * @return {Array} The XY position of the node
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1710
*/
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1711
    'getXY',
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1712
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1713
/**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1714
 * Set the position of the node in page coordinates, regardless of how the node is positioned.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1715
 * @method setXY
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1716
 * @param {Array} xy Contains X & Y values for new position (coordinates are page-based)
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1717
 * @chainable
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1718
 */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1719
    'setXY',
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1720
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1721
/**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1722
 * Gets the current position of the node in page coordinates. 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1723
 * @method getX
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1724
 * @return {Int} The X position of the node
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1725
*/
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1726
    'getX',
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1727
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1728
/**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1729
 * Set the position of the node in page coordinates, regardless of how the node is positioned.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1730
 * @method setX
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1731
 * @param {Int} x X value for new position (coordinates are page-based)
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1732
 * @chainable
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1733
 */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1734
    'setX',
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1735
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1736
/**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1737
 * Gets the current position of the node in page coordinates. 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1738
 * @method getY
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1739
 * @return {Int} The Y position of the node
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1740
*/
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1741
    'getY',
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1742
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1743
/**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1744
 * Set the position of the node in page coordinates, regardless of how the node is positioned.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1745
 * @method setY
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1746
 * @param {Int} y Y value for new position (coordinates are page-based)
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1747
 * @chainable
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1748
 */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1749
    'setY'
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1750
]);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1751
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1752
/**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1753
 * Returns a region object for the node 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1754
 * @config region
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1755
 * @for Node
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1756
 * @type Node
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1757
 */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1758
Y.Node.ATTRS.region = {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1759
    getter: function() {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1760
        var node = Y.Node.getDOMNode(this);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1761
        if (node && !node.tagName) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1762
            if (node.nodeType === 9) { // document
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1763
                node = node.documentElement;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1764
            } else if (node.alert) { // window
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1765
                node = node.document.documentElement;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1766
            }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1767
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1768
        return Y.DOM.region(node);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1769
    }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1770
};
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1771
    
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1772
/**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1773
 * Returns a region object for the node's viewport 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1774
 * @config viewportRegion
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1775
 * @type Node
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1776
 */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1777
Y.Node.ATTRS.viewportRegion = {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1778
    getter: function() {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1779
        return Y.DOM.viewportRegion(Y.Node.getDOMNode(this));
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1780
    }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1781
};
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1782
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1783
Y.Node.importMethod(Y.DOM, 'inViewportRegion');
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1784
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1785
// these need special treatment to extract 2nd node arg
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1786
/**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1787
 * Compares the intersection of the node with another node or region 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1788
 * @method intersect         
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1789
 * @for Node
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1790
 * @param {Node|Object} node2 The node or region to compare with.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1791
 * @param {Object} altRegion An alternate region to use (rather than this node's). 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1792
 * @return {Object} An object representing the intersection of the regions. 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1793
 */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1794
Y.Node.prototype.intersect = function(node2, altRegion) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1795
    var node1 = Y.Node.getDOMNode(this);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1796
    if (node2 instanceof Y.Node) { // might be a region object
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1797
        node2 = Y.Node.getDOMNode(node2);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1798
    }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1799
    return Y.DOM.intersect(node1, node2, altRegion); 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1800
};
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1801
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1802
/**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1803
 * Determines whether or not the node is within the giving region.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1804
 * @method inRegion         
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1805
 * @param {Node|Object} node2 The node or region to compare with.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1806
 * @param {Boolean} all Whether or not all of the node must be in the region. 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1807
 * @param {Object} altRegion An alternate region to use (rather than this node's). 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1808
 * @return {Object} An object representing the intersection of the regions. 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1809
 */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1810
Y.Node.prototype.inRegion = function(node2, all, altRegion) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1811
    var node1 = Y.Node.getDOMNode(this);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1812
    if (node2 instanceof Y.Node) { // might be a region object
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1813
        node2 = Y.Node.getDOMNode(node2);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1814
    }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1815
    return Y.DOM.inRegion(node1, node2, all, altRegion); 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1816
};
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1817
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1818
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1819
}, '3.0.0b1' ,{requires:['dom-screen']});
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1820
YUI.add('node-aria', function(Y) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1821
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1822
/**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1823
 * Aria support for Node
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1824
 * @module node
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1825
 * @submodule node-aria
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1826
 */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1827
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1828
Y.Node.re_aria = /^(?:role$|aria-)/;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1829
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1830
Y.Node.prototype._addAriaAttr = function(name) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1831
    this.addAttr(name, {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1832
        getter: function() {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1833
            return Y.Node.getDOMNode(this).getAttribute(name, 2); 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1834
        },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1835
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1836
        setter: function(val) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1837
            Y.Node.getDOMNode(this).setAttribute(name, val);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1838
            return val; 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1839
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1840
    });
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1841
};
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1842
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1843
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1844
}, '3.0.0b1' ,{requires:['node-base']});
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1845
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1846
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1847
YUI.add('node', function(Y){}, '3.0.0b1' ,{skinnable:false, use:['node-base', 'node-style', 'node-screen', 'node-aria']});
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1848