src/cm/media/js/lib/yui/yui_3.10.3/build/node-screen/node-screen.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
        }
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
Y.Node.ATTRS.scrollTop = {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    94
    getter: function() {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    95
        var node = Y.Node.getDOMNode(this);
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    96
        return ('scrollTop' in node) ? node.scrollTop : Y.DOM.docScrollY(node);
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    97
    },
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    98
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    99
    setter: function(val) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   100
        var node = Y.Node.getDOMNode(this);
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   101
        if (node) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   102
            if ('scrollTop' in node) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   103
                node.scrollTop = val;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   104
            } else if (node.document || node.nodeType === 9) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   105
                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
   106
            }
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   107
        } else {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   108
        }
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   109
    }
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
Y.Node.importMethod(Y.DOM, [
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   113
/**
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   114
 * Gets the current position of the node in page coordinates. 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   115
 * @method getXY
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   116
 * @for Node
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   117
 * @return {Array} The XY position of the node
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   118
*/
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   119
    'getXY',
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   120
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   121
/**
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   122
 * 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
   123
 * @method setXY
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   124
 * @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
   125
 * @chainable
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   126
 */
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   127
    'setXY',
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   128
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   129
/**
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   130
 * Gets the current position of the node in page coordinates. 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   131
 * @method getX
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   132
 * @return {Int} The X position of the node
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   133
*/
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   134
    'getX',
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   135
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   136
/**
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   137
 * 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
   138
 * @method setX
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   139
 * @param {Int} x X value for new position (coordinates are page-based)
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   140
 * @chainable
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   141
 */
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   142
    'setX',
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   143
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   144
/**
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   145
 * Gets the current position of the node in page coordinates. 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   146
 * @method getY
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   147
 * @return {Int} The Y position of the node
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   148
*/
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   149
    'getY',
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   150
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   151
/**
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   152
 * 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
   153
 * @method setY
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   154
 * @param {Int} y Y value for new position (coordinates are page-based)
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   155
 * @chainable
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   156
 */
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   157
    'setY',
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   158
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   159
/**
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   160
 * Swaps the XY position of this node with another node. 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   161
 * @method swapXY
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   162
 * @param {Node | HTMLElement} otherNode The node to swap with.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   163
 * @chainable
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   164
 */
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   165
    'swapXY'
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   166
]);
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   167
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   168
/**
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   169
 * @module node
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   170
 * @submodule node-screen
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   171
 */
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   172
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   173
/**
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   174
 * Returns a region object for the node
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   175
 * @config region
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   176
 * @for Node
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   177
 * @type Node
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   178
 */
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   179
Y.Node.ATTRS.region = {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   180
    getter: function() {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   181
        var node = this.getDOMNode(),
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   182
            region;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   183
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   184
        if (node && !node.tagName) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   185
            if (node.nodeType === 9) { // document
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   186
                node = node.documentElement;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   187
            }
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   188
        }
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   189
        if (Y.DOM.isWindow(node)) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   190
            region = Y.DOM.viewportRegion(node);
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   191
        } else {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   192
            region = Y.DOM.region(node);
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   193
        }
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   194
        return region;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   195
    }
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   196
};
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
 * Returns a region object for the node's viewport
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   200
 * @config viewportRegion
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   201
 * @type Node
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   202
 */
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   203
Y.Node.ATTRS.viewportRegion = {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   204
    getter: function() {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   205
        return Y.DOM.viewportRegion(Y.Node.getDOMNode(this));
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   206
    }
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   207
};
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   208
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   209
Y.Node.importMethod(Y.DOM, 'inViewportRegion');
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   210
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   211
// these need special treatment to extract 2nd node arg
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   212
/**
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   213
 * Compares the intersection of the node with another node or region
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   214
 * @method intersect
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   215
 * @for Node
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   216
 * @param {Node|Object} node2 The node or region to compare with.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   217
 * @param {Object} altRegion An alternate region to use (rather than this node's).
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   218
 * @return {Object} An object representing the intersection of the regions.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   219
 */
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   220
Y.Node.prototype.intersect = function(node2, altRegion) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   221
    var node1 = Y.Node.getDOMNode(this);
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   222
    if (Y.instanceOf(node2, Y.Node)) { // might be a region object
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   223
        node2 = Y.Node.getDOMNode(node2);
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   224
    }
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   225
    return Y.DOM.intersect(node1, node2, altRegion);
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   226
};
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   227
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   228
/**
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   229
 * Determines whether or not the node is within the giving region.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   230
 * @method inRegion
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   231
 * @param {Node|Object} node2 The node or region to compare with.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   232
 * @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
   233
 * @param {Object} altRegion An alternate region to use (rather than this node's).
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   234
 * @return {Boolean} True if in region, false if not.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   235
 */
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   236
Y.Node.prototype.inRegion = function(node2, all, altRegion) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   237
    var node1 = Y.Node.getDOMNode(this);
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   238
    if (Y.instanceOf(node2, Y.Node)) { // might be a region object
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   239
        node2 = Y.Node.getDOMNode(node2);
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   240
    }
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   241
    return Y.DOM.inRegion(node1, node2, all, altRegion);
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   242
};
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   243
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   244
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   245
}, '3.10.3', {"requires": ["dom-screen", "node-base"]});