src/cm/media/js/lib/yui/yui_3.10.3/build/node-screen/node-screen-debug.js
author Yves-Marie Haussonne <ymh.work+github@gmail.com>
Fri, 09 May 2014 18:35:26 +0200
changeset 656 a84519031134
parent 525 89ef5ed3c48b
permissions -rw-r--r--
add link to "privacy policy" in the header test
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('node-screen', 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
 * Extended Node interface for managing regions and screen positioning.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    12
 * Adds support for positioning elements and normalizes window size and scroll detection. 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    13
 * @module node
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    14
 * @submodule node-screen
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    15
 */
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    16
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    17
// these are all "safe" returns, no wrapping required
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    18
Y.each([
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    19
    /**
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    20
     * Returns the inner width of the viewport (exludes scrollbar). 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    21
     * @config winWidth
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    22
     * @for Node
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    23
     * @type {Int}
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    24
     */
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    25
    'winWidth',
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    26
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    27
    /**
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    28
     * Returns the inner height of the viewport (exludes scrollbar). 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    29
     * @config winHeight
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    30
     * @type {Int}
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    31
     */
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    32
    'winHeight',
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    33
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    34
    /**
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    35
     * Document width 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    36
     * @config docWidth
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    37
     * @type {Int}
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    38
     */
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    39
    'docWidth',
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    40
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    41
    /**
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    42
     * Document height 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    43
     * @config docHeight
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    44
     * @type {Int}
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    45
     */
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    46
    'docHeight',
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    47
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    48
    /**
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    49
     * Pixel distance the page has been scrolled horizontally 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    50
     * @config docScrollX
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    51
     * @type {Int}
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    52
     */
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    53
    'docScrollX',
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    54
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    55
    /**
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    56
     * Pixel distance the page has been scrolled vertically 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    57
     * @config docScrollY
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    58
     * @type {Int}
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    59
     */
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    60
    'docScrollY'
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    61
    ],
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    62
    function(name) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    63
        Y.Node.ATTRS[name] = {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    64
            getter: function() {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    65
                var args = Array.prototype.slice.call(arguments);
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    66
                args.unshift(Y.Node.getDOMNode(this));
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 Y.DOM[name].apply(this, args);
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
    }
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    72
);
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    73
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    74
Y.Node.ATTRS.scrollLeft = {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    75
    getter: function() {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    76
        var node = Y.Node.getDOMNode(this);
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    77
        return ('scrollLeft' in node) ? node.scrollLeft : Y.DOM.docScrollX(node);
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    78
    },
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    79
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    80
    setter: function(val) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    81
        var node = Y.Node.getDOMNode(this);
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    82
        if (node) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    83
            if ('scrollLeft' in node) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    84
                node.scrollLeft = val;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    85
            } else if (node.document || node.nodeType === 9) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    86
                Y.DOM._getWin(node).scrollTo(val, Y.DOM.docScrollY(node)); // scroll window if win or doc
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    87
            }
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    88
        } else {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    89
            Y.log('unable to set scrollLeft for ' + node, 'error', 'Node');
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    90
        }
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    91
    }
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    92
};
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    93
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    94
Y.Node.ATTRS.scrollTop = {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    95
    getter: function() {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    96
        var node = Y.Node.getDOMNode(this);
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    97
        return ('scrollTop' in node) ? node.scrollTop : Y.DOM.docScrollY(node);
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    98
    },
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    99
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   100
    setter: function(val) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   101
        var node = Y.Node.getDOMNode(this);
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   102
        if (node) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   103
            if ('scrollTop' in node) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   104
                node.scrollTop = val;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   105
            } else if (node.document || node.nodeType === 9) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   106
                Y.DOM._getWin(node).scrollTo(Y.DOM.docScrollX(node), val); // scroll window if win or doc
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   107
            }
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   108
        } else {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   109
            Y.log('unable to set scrollTop for ' + node, 'error', 'Node');
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   110
        }
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   111
    }
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   112
};
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   113
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   114
Y.Node.importMethod(Y.DOM, [
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   115
/**
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   116
 * Gets the current position of the node in page coordinates. 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   117
 * @method getXY
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   118
 * @for Node
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   119
 * @return {Array} The XY position of the node
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   120
*/
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   121
    'getXY',
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   122
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   123
/**
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   124
 * Set the position of the node in page coordinates, regardless of how the node is positioned.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   125
 * @method setXY
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   126
 * @param {Array} xy Contains X & Y values for new position (coordinates are page-based)
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   127
 * @chainable
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   128
 */
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   129
    'setXY',
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   130
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   131
/**
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   132
 * Gets the current position of the node in page coordinates. 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   133
 * @method getX
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   134
 * @return {Int} The X position of the node
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   135
*/
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   136
    'getX',
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   137
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   138
/**
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   139
 * Set the position of the node in page coordinates, regardless of how the node is positioned.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   140
 * @method setX
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   141
 * @param {Int} x X value for new position (coordinates are page-based)
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   142
 * @chainable
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   143
 */
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   144
    'setX',
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   145
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   146
/**
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   147
 * Gets the current position of the node in page coordinates. 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   148
 * @method getY
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   149
 * @return {Int} The Y position of the node
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   150
*/
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   151
    'getY',
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   152
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   153
/**
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   154
 * Set the position of the node in page coordinates, regardless of how the node is positioned.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   155
 * @method setY
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   156
 * @param {Int} y Y value for new position (coordinates are page-based)
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   157
 * @chainable
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   158
 */
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   159
    'setY',
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   160
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   161
/**
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   162
 * Swaps the XY position of this node with another node. 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   163
 * @method swapXY
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   164
 * @param {Node | HTMLElement} otherNode The node to swap with.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   165
 * @chainable
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   166
 */
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   167
    'swapXY'
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   168
]);
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   169
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   170
/**
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   171
 * @module node
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   172
 * @submodule node-screen
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   173
 */
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   174
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   175
/**
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   176
 * Returns a region object for the node
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   177
 * @config region
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   178
 * @for Node
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   179
 * @type Node
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   180
 */
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   181
Y.Node.ATTRS.region = {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   182
    getter: function() {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   183
        var node = this.getDOMNode(),
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   184
            region;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   185
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   186
        if (node && !node.tagName) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   187
            if (node.nodeType === 9) { // document
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   188
                node = node.documentElement;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   189
            }
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   190
        }
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   191
        if (Y.DOM.isWindow(node)) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   192
            region = Y.DOM.viewportRegion(node);
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   193
        } else {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   194
            region = Y.DOM.region(node);
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   195
        }
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   196
        return region;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   197
    }
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   198
};
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   199
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   200
/**
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   201
 * Returns a region object for the node's viewport
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   202
 * @config viewportRegion
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   203
 * @type Node
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   204
 */
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   205
Y.Node.ATTRS.viewportRegion = {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   206
    getter: function() {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   207
        return Y.DOM.viewportRegion(Y.Node.getDOMNode(this));
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   208
    }
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   209
};
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   210
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   211
Y.Node.importMethod(Y.DOM, 'inViewportRegion');
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   212
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   213
// these need special treatment to extract 2nd node arg
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   214
/**
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   215
 * Compares the intersection of the node with another node or region
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   216
 * @method intersect
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   217
 * @for Node
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   218
 * @param {Node|Object} node2 The node or region to compare with.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   219
 * @param {Object} altRegion An alternate region to use (rather than this node's).
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   220
 * @return {Object} An object representing the intersection of the regions.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   221
 */
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   222
Y.Node.prototype.intersect = function(node2, altRegion) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   223
    var node1 = Y.Node.getDOMNode(this);
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   224
    if (Y.instanceOf(node2, Y.Node)) { // might be a region object
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   225
        node2 = Y.Node.getDOMNode(node2);
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   226
    }
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   227
    return Y.DOM.intersect(node1, node2, altRegion);
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   228
};
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   229
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   230
/**
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   231
 * Determines whether or not the node is within the giving region.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   232
 * @method inRegion
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   233
 * @param {Node|Object} node2 The node or region to compare with.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   234
 * @param {Boolean} all Whether or not all of the node must be in the region.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   235
 * @param {Object} altRegion An alternate region to use (rather than this node's).
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   236
 * @return {Boolean} True if in region, false if not.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   237
 */
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   238
Y.Node.prototype.inRegion = function(node2, all, altRegion) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   239
    var node1 = Y.Node.getDOMNode(this);
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   240
    if (Y.instanceOf(node2, Y.Node)) { // might be a region object
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   241
        node2 = Y.Node.getDOMNode(node2);
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   242
    }
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   243
    return Y.DOM.inRegion(node1, node2, all, altRegion);
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   244
};
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   245
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   246
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   247
}, '3.10.3', {"requires": ["dom-screen", "node-base"]});