src/cm/media/js/lib/yui/yui_3.10.3/build/datasource-cache/datasource-cache.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-cache', 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
 * Plugs DataSource with caching 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-cache
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
 * DataSourceCache extension binds Cache to DataSource.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    19
 * @class DataSourceCacheExtension
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    20
 */
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    21
var DataSourceCacheExtension = function() {
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
Y.mix(DataSourceCacheExtension, {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    25
    /**
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    26
     * The namespace for the plugin. This will be the property on the host which
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    27
     * references the plugin instance.
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 NS
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    30
     * @type String
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    31
     * @static
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    32
     * @final
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    33
     * @value "cache"
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    34
     */
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    35
    NS: "cache",
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    36
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    37
    /**
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    38
     * Class name.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    39
     *
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    40
     * @property NAME
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    41
     * @type String
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    42
     * @static
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    43
     * @final
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    44
     * @value "dataSourceCacheExtension"
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    45
     */
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    46
    NAME: "dataSourceCacheExtension"
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
DataSourceCacheExtension.prototype = {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    50
    /**
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    51
    * Internal init() handler.
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 initializer
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    54
    * @param config {Object} Config object.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    55
    * @private
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    56
    */
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    57
    initializer: function(config) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    58
        this.doBefore("_defRequestFn", this._beforeDefRequestFn);
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    59
        this.doBefore("_defResponseFn", this._beforeDefResponseFn);
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    60
    },
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    61
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    62
    /**
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    63
     * First look for cached response, then send request to live data.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    64
     *
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    65
     * @method _beforeDefRequestFn
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    66
     * @param e {Event.Facade} Event Facade with the following properties:
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    67
     * <dl>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    68
     * <dt>tId (Number)</dt> <dd>Unique transaction ID.</dd>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    69
     * <dt>request (Object)</dt> <dd>The request.</dd>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    70
     * <dt>callback (Object)</dt> <dd>The callback object.</dd>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    71
     * <dt>cfg (Object)</dt> <dd>Configuration object.</dd>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    72
     * </dl>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    73
     * @protected
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    74
     */
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    75
    _beforeDefRequestFn: function(e) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    76
        // Is response already in the Cache?
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    77
        var entry = (this.retrieve(e.request)) || null,
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    78
            payload = e.details[0];
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    79
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    80
        if (entry && entry.response) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    81
            payload.cached   = entry.cached;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    82
            payload.response = entry.response;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    83
            payload.data     = entry.data;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    84
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    85
            this.get("host").fire("response", payload);
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    86
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    87
            return new Y.Do.Halt("DataSourceCache extension halted _defRequestFn");
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    88
        }
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
     * Adds data to cache before returning data.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    93
     *
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    94
     * @method _beforeDefResponseFn
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    95
     * @param e {Event.Facade} Event Facade with the following properties:
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    96
     * <dl>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    97
     * <dt>tId (Number)</dt> <dd>Unique transaction ID.</dd>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    98
     * <dt>request (Object)</dt> <dd>The request.</dd>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    99
     * <dt>callback (Object)</dt> <dd>The callback object with the following properties:
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   100
     *     <dl>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   101
     *         <dt>success (Function)</dt> <dd>Success handler.</dd>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   102
     *         <dt>failure (Function)</dt> <dd>Failure handler.</dd>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   103
     *     </dl>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   104
     * </dd>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   105
     * <dt>data (Object)</dt> <dd>Raw data.</dd>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   106
     * <dt>response (Object)</dt> <dd>Normalized response object with the following properties:
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   107
     *     <dl>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   108
     *         <dt>cached (Object)</dt> <dd>True when response is cached.</dd>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   109
     *         <dt>results (Object)</dt> <dd>Parsed results.</dd>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   110
     *         <dt>meta (Object)</dt> <dd>Parsed meta data.</dd>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   111
     *         <dt>error (Object)</dt> <dd>Error object.</dd>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   112
     *     </dl>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   113
     * </dd>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   114
     * <dt>cfg (Object)</dt> <dd>Configuration object.</dd>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   115
     * </dl>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   116
     * @protected
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   117
     */
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   118
     _beforeDefResponseFn: function(e) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   119
        // Add to Cache before returning
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   120
        if(e.response && !e.cached) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   121
            this.add(e.request, e.response);
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
};
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   125
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   126
Y.namespace("Plugin").DataSourceCacheExtension = DataSourceCacheExtension;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   127
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
/**
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   131
 * DataSource plugin adds cache functionality.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   132
 * @class DataSourceCache
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   133
 * @extends Cache
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   134
 * @uses Plugin.Base, DataSourceCachePlugin
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   135
 */
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   136
function DataSourceCache(config) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   137
    var cache = config && config.cache ? config.cache : Y.Cache,
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   138
        tmpclass = Y.Base.create("dataSourceCache", cache, [Y.Plugin.Base, Y.Plugin.DataSourceCacheExtension]),
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   139
        tmpinstance = new tmpclass(config);
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   140
    tmpclass.NS = "tmpClass";
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   141
    return tmpinstance;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   142
}
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   143
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   144
Y.mix(DataSourceCache, {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   145
    /**
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   146
     * The namespace for the plugin. This will be the property on the host which
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   147
     * references the plugin instance.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   148
     *
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   149
     * @property NS
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   150
     * @type String
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   151
     * @static
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   152
     * @final
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   153
     * @value "cache"
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   154
     */
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   155
    NS: "cache",
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   156
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   157
    /**
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   158
     * Class name.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   159
     *
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   160
     * @property NAME
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   161
     * @type String
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   162
     * @static
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   163
     * @final
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   164
     * @value "dataSourceCache"
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   165
     */
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   166
    NAME: "dataSourceCache"
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
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   170
Y.namespace("Plugin").DataSourceCache = DataSourceCache;
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
}, '3.10.3', {"requires": ["datasource-local", "plugin", "cache-base"]});