src/cm/media/js/lib/yui/yui_3.10.3/build/datasource-polling/datasource-polling.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('datasource-polling', 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
 * Extends DataSource with polling functionality.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    12
 *
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    13
 * @module datasource
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    14
 * @submodule datasource-polling
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
/**
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    18
 * Adds polling to the DataSource Utility.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    19
 * @class Pollable
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    20
 * @extends DataSource.Local
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    21
 */    
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    22
function Pollable() {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    23
    this._intervals = {};
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    24
}
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    25
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    26
Pollable.prototype = {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    27
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    28
    /**
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    29
    * @property _intervals
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    30
    * @description Hash of polling interval IDs that have been enabled,
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    31
    * stored here to be able to clear all intervals.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    32
    * @private
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    33
    */
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    34
    _intervals: null,
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    35
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    36
    /**
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    37
     * Sets up a polling mechanism to send requests at set intervals and
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    38
     * forward responses to given callback.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    39
     *
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    40
     * @method setInterval
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    41
     * @param msec {Number} Length of interval in milliseconds.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    42
     * @param [request] {Object} An object literal with the following properties:
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    43
     *     <dl>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    44
     *     <dt><code>request</code></dt>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    45
     *     <dd>The request to send to the live data source, if any.</dd>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    46
     *     <dt><code>callback</code></dt>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    47
     *     <dd>An object literal with the following properties:
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    48
     *         <dl>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    49
     *         <dt><code>success</code></dt>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    50
     *         <dd>The function to call when the data is ready.</dd>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    51
     *         <dt><code>failure</code></dt>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    52
     *         <dd>The function to call upon a response failure condition.</dd>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    53
     *         <dt><code>argument</code></dt>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    54
     *         <dd>Arbitrary data payload that will be passed back to the success and failure handlers.</dd>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    55
     *         </dl>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    56
     *     </dd>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    57
     *     <dt><code>cfg</code></dt>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    58
     *     <dd>Configuration object, if any.</dd>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    59
     *     </dl>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    60
     * @return {Number} Interval ID.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    61
     */
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    62
    setInterval: function(msec, request) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    63
        var x = Y.later(msec, this, this.sendRequest, [ request ], true);
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    64
        this._intervals[x.id] = x;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    65
        // First call happens immediately, but async
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    66
        Y.later(0, this, this.sendRequest, [request]);
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    67
        return x.id;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    68
    },
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
     * Disables polling mechanism associated with the given interval ID.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    72
     *
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    73
     * @method clearInterval
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    74
     * @param id {Number} Interval ID.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    75
     */
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    76
    clearInterval: function(id, key) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    77
        // In case of being called by clearAllIntervals()
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    78
        id = key || id;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    79
        if(this._intervals[id]) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    80
            // Clear the interval
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    81
            this._intervals[id].cancel();
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    82
            // Clear from tracker
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    83
            delete this._intervals[id];
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
     * Clears all intervals.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    89
     *
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    90
     * @method clearAllIntervals
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    91
     */
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    92
    clearAllIntervals: function() {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    93
        Y.each(this._intervals, this.clearInterval, this);
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    94
    }
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    95
};
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    96
    
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    97
Y.augment(Y.DataSource.Local, Pollable);
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
}, '3.10.3', {"requires": ["datasource-local"]});