src/cm/media/js/lib/yui/yui_3.10.3/build/view-node-map/view-node-map-debug.js
author gibus
Tue, 16 Jul 2013 14:29:46 +0200
changeset 525 89ef5ed3c48b
permissions -rw-r--r--
Upgrades to yui 3.10.3
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
525
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
     1
/*
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
     2
YUI 3.10.3 (build 2fb5187)
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
     3
Copyright 2013 Yahoo! Inc. All rights reserved.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
     4
Licensed under the BSD License.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
     5
http://yuilibrary.com/license/
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
     6
*/
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
     7
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
     8
YUI.add('view-node-map', function (Y, NAME) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
     9
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    10
/**
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    11
View extension that adds a static `getByNode()` method that returns the nearest
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    12
View instance associated with the given Node (similar to Widget's `getByNode()`
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    13
method).
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    14
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    15
@module app
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    16
@submodule view-node-map
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    17
@since 3.5.0
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    18
**/
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    19
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    20
var buildCfg  = Y.namespace('View._buildCfg'),
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    21
    instances = {};
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    22
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    23
/**
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    24
View extension that adds a static `getByNode()` method that returns the nearest
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    25
View instance associated with the given Node (similar to Widget's `getByNode()`
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    26
method).
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    27
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    28
Note that it's important to call `destroy()` on a View instance using this
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    29
extension when you plan to stop using it. This ensures that all internal
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    30
references to that View are cleared to prevent memory leaks.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    31
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    32
@class View.NodeMap
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    33
@extensionfor View
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    34
@since 3.5.0
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    35
**/
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    36
function NodeMap() {}
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    37
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    38
// Tells Base.create() to mix the static getByNode method into built classes.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    39
// We're cheating and modifying Y.View here, because right now there's no better
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    40
// way to do it.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    41
buildCfg.aggregates || (buildCfg.aggregates = []);
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    42
buildCfg.aggregates.push('getByNode');
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    43
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    44
/**
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    45
Returns the nearest View instance associated with the given Node. The Node may
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    46
be a View container or any child of a View container.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    47
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    48
Note that only instances of Views that have the Y.View.NodeMap extension mixed
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    49
in will be returned. The base View class doesn't provide this functionality by
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    50
default due to the additional memory management overhead involved in maintaining
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    51
a mapping of Nodes to View instances.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    52
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    53
@method getByNode
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    54
@param {Node|HTMLElement|String} node Node instance, selector string, or
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    55
    HTMLElement.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    56
@return {View} Closest View instance associated with the given Node, or `null`
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    57
    if no associated View instance was found.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    58
@static
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    59
@since 3.5.0
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    60
**/
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    61
NodeMap.getByNode = function (node) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    62
    var view;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    63
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    64
    Y.one(node).ancestor(function (ancestor) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    65
        return (view = instances[Y.stamp(ancestor, true)]) || false;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    66
    }, true);
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    67
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    68
    return view || null;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    69
};
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    70
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    71
// To make this testable.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    72
NodeMap._instances = instances;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    73
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    74
NodeMap.prototype = {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    75
    initializer: function () {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    76
        instances[Y.stamp(this.get('container'))] = this;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    77
    },
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    78
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    79
    destructor: function () {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    80
        var stamp = Y.stamp(this.get('container'), true);
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    81
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    82
        if (stamp in instances) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    83
            delete instances[stamp];
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    84
        }
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    85
    }
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    86
};
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    87
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    88
Y.View.NodeMap = NodeMap;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    89
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    90
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    91
}, '3.10.3', {"requires": ["view"]});