src/cm/media/js/lib/yui/yui3-3.15.0/build/datasource-polling/datasource-polling-debug.js
author gibus
Mon, 10 Mar 2014 15:19:48 +0100
changeset 602 e16a97fb364a
permissions -rw-r--r--
Use YUI 3.15
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
602
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
     1
YUI.add('datasource-polling', function (Y, NAME) {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
     2
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
     3
/**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
     4
 * Extends DataSource with polling functionality.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
     5
 *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
     6
 * @module datasource
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
     7
 * @submodule datasource-polling
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
     8
 */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
     9
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    10
/**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    11
 * Adds polling to the DataSource Utility.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    12
 * @class Pollable
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    13
 * @extends DataSource.Local
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    14
 */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    15
function Pollable() {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    16
    this._intervals = {};
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    17
}
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    18
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    19
Pollable.prototype = {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    20
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    21
    /**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    22
    * @property _intervals
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    23
    * @description Hash of polling interval IDs that have been enabled,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    24
    * stored here to be able to clear all intervals.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    25
    * @private
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    26
    */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    27
    _intervals: null,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    28
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    29
    /**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    30
     * Sets up a polling mechanism to send requests at set intervals and
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    31
     * forward responses to given callback.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    32
     *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    33
     * @method setInterval
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    34
     * @param msec {Number} Length of interval in milliseconds.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    35
     * @param [request] {Object} An object literal with the following properties:
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    36
     *     <dl>
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    37
     *     <dt><code>request</code></dt>
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    38
     *     <dd>The request to send to the live data source, if any.</dd>
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    39
     *     <dt><code>callback</code></dt>
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    40
     *     <dd>An object literal with the following properties:
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    41
     *         <dl>
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    42
     *         <dt><code>success</code></dt>
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    43
     *         <dd>The function to call when the data is ready.</dd>
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    44
     *         <dt><code>failure</code></dt>
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    45
     *         <dd>The function to call upon a response failure condition.</dd>
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    46
     *         <dt><code>argument</code></dt>
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    47
     *         <dd>Arbitrary data payload that will be passed back to the success and failure handlers.</dd>
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    48
     *         </dl>
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    49
     *     </dd>
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    50
     *     <dt><code>cfg</code></dt>
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    51
     *     <dd>Configuration object, if any.</dd>
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    52
     *     </dl>
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    53
     * @return {Number} Interval ID.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    54
     */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    55
    setInterval: function(msec, request) {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    56
        var x = Y.later(msec, this, this.sendRequest, [ request ], true);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    57
        this._intervals[x.id] = x;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    58
        // First call happens immediately, but async
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    59
        Y.later(0, this, this.sendRequest, [request]);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    60
        return x.id;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    61
    },
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    62
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    63
    /**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    64
     * Disables polling mechanism associated with the given interval ID.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    65
     *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    66
     * @method clearInterval
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    67
     * @param id {Number} Interval ID.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    68
     */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    69
    clearInterval: function(id, key) {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    70
        // In case of being called by clearAllIntervals()
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    71
        id = key || id;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    72
        if(this._intervals[id]) {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    73
            // Clear the interval
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    74
            this._intervals[id].cancel();
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    75
            // Clear from tracker
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    76
            delete this._intervals[id];
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    77
        }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    78
    },
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    79
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    80
    /**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    81
     * Clears all intervals.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    82
     *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    83
     * @method clearAllIntervals
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    84
     */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    85
    clearAllIntervals: function() {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    86
        Y.each(this._intervals, this.clearInterval, this);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    87
    }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    88
};
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    89
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    90
Y.augment(Y.DataSource.Local, Pollable);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    91
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    92
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    93
}, '@VERSION@', {"requires": ["datasource-local"]});