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