src/cm/media/js/lib/yui/yui3.0.0/build/datasource/datasource.js
author raph
Tue, 20 Apr 2010 11:14:21 +0200
branchpreserve_html
changeset 259 0371caf8bcc6
parent 0 40c8f766c9b8
permissions -rw-r--r--
always use pandoc but in raw mode for html->html convert
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
0
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
     1
/*
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
     2
Copyright (c) 2009, Yahoo! Inc. All rights reserved.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
     3
Code licensed under the BSD License:
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
     4
http://developer.yahoo.net/yui/license.txt
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
     5
version: 3.0.0
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
     6
build: 1549
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
     7
*/
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
     8
YUI.add('datasource-local', function(Y) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
     9
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    10
/**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    11
 * The DataSource utility provides a common configurable interface for widgets to
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    12
 * access a variety of data, from JavaScript arrays to online database servers.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    13
 *
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    14
 * @module datasource
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    15
 */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    16
    
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    17
/**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    18
 * Provides the base DataSource implementation, which can be extended to
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    19
 * create DataSources for specific data protocols, such as the IO Utility, the
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    20
 * Get Utility, or custom functions.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    21
 *
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    22
 * @module datasource
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    23
 * @submodule datasource-local
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    24
 */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    25
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    26
/**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    27
 * Base class for the DataSource Utility.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    28
 * @class DataSource.Local
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    29
 * @extends Base
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    30
 * @constructor
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    31
 */    
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    32
var LANG = Y.Lang,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    33
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    34
DSLocal = function() {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    35
    DSLocal.superclass.constructor.apply(this, arguments);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    36
};
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    37
    
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    38
    /////////////////////////////////////////////////////////////////////////////
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    39
    //
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    40
    // DataSource static properties
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    41
    //
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    42
    /////////////////////////////////////////////////////////////////////////////
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    43
Y.mix(DSLocal, {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    44
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    45
     * Class name.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    46
     *
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    47
     * @property NAME
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    48
     * @type String
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    49
     * @static     
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    50
     * @final
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    51
     * @value "dataSourceLocal"
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    52
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    53
    NAME: "dataSourceLocal",
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    54
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    55
    /////////////////////////////////////////////////////////////////////////////
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    56
    //
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    57
    // DataSource Attributes
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    58
    //
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    59
    /////////////////////////////////////////////////////////////////////////////
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    60
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    61
    ATTRS: {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    62
        /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    63
        * @attribute source
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    64
        * @description Pointer to live data.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    65
        * @type MIXED
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    66
        * @default null        
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    67
        */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    68
        source: {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    69
            value: null
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    70
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    71
    },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    72
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    73
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    74
     * Global transaction counter.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    75
     *
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    76
     * @property DataSource._tId
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    77
     * @type Number
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    78
     * @static
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    79
     * @private
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    80
     * @default 0
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    81
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    82
    _tId: 0,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    83
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    84
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    85
     * Executes a given callback.  The third param determines whether to execute
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    86
     *
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    87
     * @method DataSource.issueCallback
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    88
     * @param callback {Object} The callback object.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    89
     * @param params {Array} params to be passed to the callback method
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    90
     * @param error {Boolean} whether an error occurred
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    91
     * @static
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    92
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    93
    issueCallback: function (e) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    94
        if(e.callback) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    95
            var callbackFunc = (e.error && e.callback.failure) || e.callback.success;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    96
            if (callbackFunc) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    97
                callbackFunc(e);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    98
            }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    99
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   100
    }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   101
});
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   102
    
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   103
Y.extend(DSLocal, Y.Base, {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   104
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   105
    * Internal init() handler.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   106
    *
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   107
    * @method initializer
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   108
    * @param config {Object} Config object.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   109
    * @private        
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   110
    */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   111
    initializer: function(config) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   112
        this._initEvents();
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   113
    },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   114
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   115
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   116
    * This method creates all the events for this module.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   117
    * @method _initEvents
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   118
    * @private        
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   119
    */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   120
    _initEvents: function() {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   121
        /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   122
         * Fired when a data request is received.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   123
         *
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   124
         * @event request
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   125
         * @param e {Event.Facade} Event Facade with the following properties:
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   126
         * <dl>                          
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   127
         * <dt>tId (Number)</dt> <dd>Unique transaction ID.</dd>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   128
         * <dt>request (Object)</dt> <dd>The request.</dd>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   129
         * <dt>callback (Object)</dt> <dd>The callback object.</dd>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   130
         * <dt>cfg (Object)</dt> <dd>Configuration object.</dd>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   131
         * </dl>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   132
         * @preventable _defRequestFn
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   133
         */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   134
        this.publish("request", {defaultFn: Y.bind("_defRequestFn", this), queuable:true});
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   135
         
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   136
        /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   137
         * Fired when raw data is received.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   138
         *
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   139
         * @event data
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   140
         * @param e {Event.Facade} Event Facade with the following properties:
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   141
         * <dl>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   142
         * <dt>tId (Number)</dt> <dd>Unique transaction ID.</dd>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   143
         * <dt>request (Object)</dt> <dd>The request.</dd>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   144
         * <dt>callback (Object)</dt> <dd>The callback object with the following properties:
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   145
         *     <dl>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   146
         *         <dt>success (Function)</dt> <dd>Success handler.</dd>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   147
         *         <dt>failure (Function)</dt> <dd>Failure handler.</dd>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   148
         *     </dl>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   149
         * </dd>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   150
         * <dt>cfg (Object)</dt> <dd>Configuration object.</dd>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   151
         * <dt>data (Object)</dt> <dd>Raw data.</dd>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   152
         * </dl>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   153
         * @preventable _defDataFn
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   154
         */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   155
        this.publish("data", {defaultFn: Y.bind("_defDataFn", this), queuable:true});
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   156
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   157
        /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   158
         * Fired when response is returned.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   159
         *
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   160
         * @event response
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   161
         * @param e {Event.Facade} Event Facade with the following properties:
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   162
         * <dl>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   163
         * <dt>tId (Number)</dt> <dd>Unique transaction ID.</dd>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   164
         * <dt>request (Object)</dt> <dd>The request.</dd>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   165
         * <dt>callback (Object)</dt> <dd>The callback object with the following properties:
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   166
         *     <dl>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   167
         *         <dt>success (Function)</dt> <dd>Success handler.</dd>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   168
         *         <dt>failure (Function)</dt> <dd>Failure handler.</dd>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   169
         *     </dl>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   170
         * </dd>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   171
         * <dt>cfg (Object)</dt> <dd>Configuration object.</dd>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   172
         * <dt>data (Object)</dt> <dd>Raw data.</dd>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   173
         * <dt>response (Object)</dt> <dd>Normalized response object with the following properties:
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   174
         *     <dl>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   175
         *         <dt>results (Object)</dt> <dd>Parsed results.</dd>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   176
         *         <dt>meta (Object)</dt> <dd>Parsed meta data.</dd>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   177
         *         <dt>error (Boolean)</dt> <dd>Error flag.</dd>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   178
         *     </dl>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   179
         * </dd>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   180
         * </dl>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   181
         * @preventable _defResponseFn
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   182
         */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   183
         this.publish("response", {defaultFn: Y.bind("_defResponseFn", this), queuable:true});
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   184
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   185
        /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   186
         * Fired when an error is encountered.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   187
         *
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   188
         * @event error
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   189
         * @param e {Event.Facade} Event Facade with the following properties:
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   190
         * <dl>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   191
         * <dt>tId (Number)</dt> <dd>Unique transaction ID.</dd>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   192
         * <dt>request (Object)</dt> <dd>The request.</dd>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   193
         * <dt>callback (Object)</dt> <dd>The callback object with the following properties:
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   194
         *     <dl>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   195
         *         <dt>success (Function)</dt> <dd>Success handler.</dd>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   196
         *         <dt>failure (Function)</dt> <dd>Failure handler.</dd>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   197
         *     </dl>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   198
         * </dd>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   199
         * <dt>cfg (Object)</dt> <dd>Configuration object.</dd>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   200
         * <dt>data (Object)</dt> <dd>Raw data.</dd>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   201
         * <dt>response (Object)</dt> <dd>Normalized response object with the following properties:
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   202
         *     <dl>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   203
         *         <dt>results (Object)</dt> <dd>Parsed results.</dd>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   204
         *         <dt>meta (Object)</dt> <dd>Parsed meta data.</dd>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   205
         *         <dt>error (Object)</dt> <dd>Error object.</dd>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   206
         *     </dl>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   207
         * </dd>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   208
         * </dl>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   209
         */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   210
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   211
    },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   212
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   213
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   214
     * Manages request/response transaction. Must fire <code>response</code>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   215
     * event when response is received. This method should be implemented by
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   216
     * subclasses to achieve more complex behavior such as accessing remote data.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   217
     *
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   218
     * @method _defRequestFn
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   219
     * @param e {Event.Facade} Event Facadewith the following properties:
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   220
     * <dl>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   221
     * <dt>tId (Number)</dt> <dd>Unique transaction ID.</dd>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   222
     * <dt>request (Object)</dt> <dd>The request.</dd>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   223
     * <dt>callback (Object)</dt> <dd>The callback object with the following properties:
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   224
     *     <dl>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   225
     *         <dt>success (Function)</dt> <dd>Success handler.</dd>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   226
     *         <dt>failure (Function)</dt> <dd>Failure handler.</dd>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   227
     *     </dl>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   228
     * </dd>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   229
     * <dt>cfg (Object)</dt> <dd>Configuration object.</dd>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   230
     * </dl>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   231
     * @protected
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   232
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   233
    _defRequestFn: function(e) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   234
        var data = this.get("source");
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   235
        
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   236
        // Problematic data
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   237
        if(LANG.isUndefined(data)) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   238
            e.error = new Error("Local source undefined");
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   239
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   240
        if(e.error) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   241
            this.fire("error", e);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   242
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   243
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   244
        this.fire("data", Y.mix({data:data}, e));
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   245
    },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   246
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   247
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   248
     * Normalizes raw data into a response that includes results and meta properties.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   249
     *
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   250
     * @method _defDataFn
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   251
     * @param e {Event.Facade} Event Facade with the following properties:
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   252
     * <dl>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   253
     * <dt>tId (Number)</dt> <dd>Unique transaction ID.</dd>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   254
     * <dt>request (Object)</dt> <dd>The request.</dd>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   255
     * <dt>callback (Object)</dt> <dd>The callback object with the following properties:
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   256
     *     <dl>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   257
     *         <dt>success (Function)</dt> <dd>Success handler.</dd>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   258
     *         <dt>failure (Function)</dt> <dd>Failure handler.</dd>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   259
     *     </dl>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   260
     * </dd>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   261
     * <dt>cfg (Object)</dt> <dd>Configuration object.</dd>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   262
     * <dt>data (Object)</dt> <dd>Raw data.</dd>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   263
     * </dl>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   264
     * @protected
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   265
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   266
    _defDataFn: function(e) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   267
        var data = e.data,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   268
            meta = e.meta,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   269
            response = {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   270
                results: (LANG.isArray(data)) ? data : [data],
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   271
                meta: (meta) ? meta : {}
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   272
            };
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   273
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   274
        this.fire("response", Y.mix({response: response}, e));
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   275
    },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   276
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   277
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   278
     * Sends data as a normalized response to callback.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   279
     *
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   280
     * @method _defResponseFn
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   281
     * @param e {Event.Facade} Event Facade with the following properties:
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   282
     * <dl>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   283
     * <dt>tId (Number)</dt> <dd>Unique transaction ID.</dd>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   284
     * <dt>request (Object)</dt> <dd>The request.</dd>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   285
     * <dt>callback (Object)</dt> <dd>The callback object with the following properties:
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   286
     *     <dl>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   287
     *         <dt>success (Function)</dt> <dd>Success handler.</dd>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   288
     *         <dt>failure (Function)</dt> <dd>Failure handler.</dd>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   289
     *     </dl>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   290
     * </dd>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   291
     * <dt>cfg (Object)</dt> <dd>Configuration object.</dd>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   292
     * <dt>data (Object)</dt> <dd>Raw data.</dd>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   293
     * <dt>response (Object)</dt> <dd>Normalized response object with the following properties:
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   294
     *     <dl>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   295
     *         <dt>results (Object)</dt> <dd>Parsed results.</dd>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   296
     *         <dt>meta (Object)</dt> <dd>Parsed meta data.</dd>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   297
     *         <dt>error (Boolean)</dt> <dd>Error flag.</dd>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   298
     *     </dl>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   299
     * </dd>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   300
     * </dl>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   301
     * @protected
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   302
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   303
    _defResponseFn: function(e) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   304
        // Send the response back to the callback
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   305
        DSLocal.issueCallback(e);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   306
    },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   307
    
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   308
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   309
     * Generates a unique transaction ID and fires <code>request</code> event.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   310
     *
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   311
     * @method sendRequest
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   312
     * @param request {Object} Request.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   313
     * @param callback {Object} An object literal with the following properties:
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   314
     *     <dl>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   315
     *     <dt><code>success</code></dt>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   316
     *     <dd>The function to call when the data is ready.</dd>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   317
     *     <dt><code>failure</code></dt>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   318
     *     <dd>The function to call upon a response failure condition.</dd>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   319
     *     <dt><code>argument</code></dt>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   320
     *     <dd>Arbitrary data payload that will be passed back to the success and failure handlers.</dd>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   321
     *     </dl>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   322
     * @param cfg {Object} Configuration object
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   323
     * @return {Number} Transaction ID.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   324
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   325
    sendRequest: function(request, callback, cfg) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   326
        var tId = DSLocal._tId++;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   327
        this.fire("request", {tId:tId, request:request, callback:callback, cfg:cfg || {}});
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   328
        return tId;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   329
    }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   330
});
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   331
    
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   332
Y.namespace("DataSource").Local = DSLocal;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   333
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   334
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   335
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   336
}, '3.0.0' ,{requires:['base']});
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   337
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   338
YUI.add('datasource-io', function(Y) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   339
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   340
/**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   341
 * Provides a DataSource implementation which can be used to retrieve data via the IO Utility.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   342
 *
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   343
 * @module datasource
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   344
 * @submodule datasource-io
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   345
 */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   346
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   347
/**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   348
 * IO subclass for the DataSource Utility.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   349
 * @class DataSource.IO
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   350
 * @extends DataSource.Local
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   351
 * @constructor
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   352
 */    
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   353
var DSIO = function() {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   354
    DSIO.superclass.constructor.apply(this, arguments);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   355
};
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   356
    
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   357
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   358
    /////////////////////////////////////////////////////////////////////////////
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   359
    //
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   360
    // DataSource.IO static properties
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   361
    //
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   362
    /////////////////////////////////////////////////////////////////////////////
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   363
Y.mix(DSIO, {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   364
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   365
     * Class name.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   366
     *
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   367
     * @property NAME
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   368
     * @type String
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   369
     * @static     
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   370
     * @final
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   371
     * @value "dataSourceIO"
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   372
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   373
    NAME: "dataSourceIO",
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   374
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   375
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   376
    /////////////////////////////////////////////////////////////////////////////
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   377
    //
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   378
    // DataSource.IO Attributes
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   379
    //
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   380
    /////////////////////////////////////////////////////////////////////////////
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   381
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   382
    ATTRS: {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   383
        /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   384
         * Pointer to IO Utility.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   385
         *
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   386
         * @attribute io
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   387
         * @type Y.io
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   388
         * @default Y.io
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   389
         */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   390
        io: {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   391
            value: Y.io,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   392
            cloneDefaultValue: false
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   393
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   394
    }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   395
});
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   396
    
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   397
Y.extend(DSIO, Y.DataSource.Local, {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   398
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   399
    * Internal init() handler.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   400
    *
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   401
    * @method initializer
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   402
    * @param config {Object} Config object.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   403
    * @private
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   404
    */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   405
    initializer: function(config) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   406
        this._queue = {interval:null, conn:null, requests:[]};
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   407
    },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   408
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   409
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   410
    * @property _queue
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   411
    * @description Object literal to manage asynchronous request/response
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   412
    * cycles enabled if queue needs to be managed (asyncMode/ioConnMode):
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   413
    * <dl>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   414
    *     <dt>interval {Number}</dt>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   415
    *         <dd>Interval ID of in-progress queue.</dd>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   416
    *     <dt>conn</dt>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   417
    *         <dd>In-progress connection identifier (if applicable).</dd>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   418
    *     <dt>requests {Object[]}</dt>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   419
    *         <dd>Array of queued request objects: {request:request, callback:callback}.</dd>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   420
    * </dl>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   421
    * @type Object
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   422
    * @default {interval:null, conn:null, requests:[]}
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   423
    * @private
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   424
    */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   425
    _queue: null,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   426
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   427
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   428
     * Passes query string to IO. Fires <code>response</code> event when
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   429
     * response is received asynchronously.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   430
     *
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   431
     * @method _defRequestFn
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   432
     * @param e {Event.Facade} Event Facade with the following properties:
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   433
     * <dl>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   434
     * <dt>tId (Number)</dt> <dd>Unique transaction ID.</dd>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   435
     * <dt>request (Object)</dt> <dd>The request.</dd>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   436
     * <dt>callback (Object)</dt> <dd>The callback object with the following properties:
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   437
     *     <dl>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   438
     *         <dt>success (Function)</dt> <dd>Success handler.</dd>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   439
     *         <dt>failure (Function)</dt> <dd>Failure handler.</dd>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   440
     *     </dl>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   441
     * </dd>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   442
     * <dt>cfg (Object)</dt> <dd>Configuration object.</dd>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   443
     * </dl>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   444
     * @protected
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   445
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   446
    _defRequestFn: function(e) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   447
        var uri = this.get("source"),
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   448
            io = this.get("io"),
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   449
            request = e.request,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   450
            cfg = Y.mix(e.cfg, {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   451
                on: {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   452
                    success: function (id, response, e) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   453
                        this.fire("data", Y.mix({data:response}, e));
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   454
                    },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   455
                    failure: function (id, response, e) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   456
                        e.error = new Error("IO data failure");
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   457
                        this.fire("error", Y.mix({data:response}, e));
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   458
                        this.fire("data", Y.mix({data:response}, e));
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   459
                    }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   460
                },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   461
                context: this,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   462
                arguments: e
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   463
            });
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   464
        
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   465
        // Support for POST transactions
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   466
        if(Y.Lang.isString(request)) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   467
            if(cfg.method && (cfg.method.toUpperCase() === "POST")) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   468
                cfg.data = cfg.data ? cfg.data+request : request;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   469
            }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   470
            else {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   471
                uri += request;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   472
            }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   473
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   474
        io(uri, cfg);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   475
        return e.tId;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   476
    }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   477
});
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   478
  
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   479
Y.DataSource.IO = DSIO;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   480
    
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   481
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   482
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   483
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   484
}, '3.0.0' ,{requires:['datasource-local', 'io']});
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   485
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   486
YUI.add('datasource-get', function(Y) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   487
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   488
/**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   489
 * Provides a DataSource implementation which can be used to retrieve data via the Get Utility.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   490
 *
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   491
 * @module datasource
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   492
 * @submodule datasource-get
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   493
 */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   494
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   495
/**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   496
 * Get Utility subclass for the DataSource Utility.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   497
 * @class DataSource.Get
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   498
 * @extends DataSource.Local
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   499
 * @constructor
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   500
 */    
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   501
var DSGet = function() {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   502
    DSGet.superclass.constructor.apply(this, arguments);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   503
};
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   504
    
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   505
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   506
    /////////////////////////////////////////////////////////////////////////////
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   507
    //
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   508
    // DataSource.Get static properties
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   509
    //
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   510
    /////////////////////////////////////////////////////////////////////////////
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   511
Y.mix(DSGet, {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   512
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   513
     * Class name.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   514
     *
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   515
     * @property NAME
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   516
     * @type String
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   517
     * @static     
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   518
     * @final
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   519
     * @value "dataSourceGet"
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   520
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   521
    NAME: "dataSourceGet",
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   522
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   523
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   524
    /////////////////////////////////////////////////////////////////////////////
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   525
    //
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   526
    // DataSource.Get Attributes
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   527
    //
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   528
    /////////////////////////////////////////////////////////////////////////////
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   529
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   530
    ATTRS: {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   531
        /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   532
         * Pointer to Get Utility.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   533
         *
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   534
         * @attribute get
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   535
         * @type Y.Get
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   536
         * @default Y.Get
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   537
         */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   538
        get: {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   539
            value: Y.Get,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   540
            cloneDefaultValue: false
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   541
        },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   542
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   543
/**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   544
 * Defines request/response management in the following manner:
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   545
 * <dl>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   546
 *     <!--<dt>queueRequests</dt>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   547
 *     <dd>If a request is already in progress, wait until response is returned before sending the next request.</dd>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   548
 *     <dt>cancelStaleRequests</dt>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   549
 *     <dd>If a request is already in progress, cancel it before sending the next request.</dd>-->
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   550
 *     <dt>ignoreStaleResponses</dt>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   551
 *     <dd>Send all requests, but handle only the response for the most recently sent request.</dd>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   552
 *     <dt>allowAll</dt>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   553
 *     <dd>Send all requests and handle all responses.</dd>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   554
 * </dl>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   555
 *
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   556
 * @attribute asyncMode
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   557
 * @type String
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   558
 * @default "allowAll"
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   559
 */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   560
asyncMode: {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   561
    value: "allowAll"
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   562
},
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   563
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   564
/**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   565
 * Callback string parameter name sent to the remote script. By default,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   566
 * requests are sent to
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   567
 * &#60;URI&#62;?&#60;scriptCallbackParam&#62;=callbackFunction
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   568
 *
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   569
 * @attribute scriptCallbackParam
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   570
 * @type String
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   571
 * @default "callback"
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   572
 */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   573
scriptCallbackParam : {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   574
    value: "callback"
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   575
},
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   576
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   577
/**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   578
 * Accepts the DataSource instance and a callback ID, and returns a callback
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   579
 * param/value string that gets appended to the script URI. Implementers
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   580
 * can customize this string to match their server's query syntax.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   581
 *
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   582
 * @attribute generateRequestCallback
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   583
 * @type Function
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   584
 */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   585
generateRequestCallback : {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   586
    value: function(self, id) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   587
        return "&" + self.get("scriptCallbackParam") + "=YUI.Env.DataSource.callbacks["+id+"]" ;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   588
    }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   589
}
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   590
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   591
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   592
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   593
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   594
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   595
    },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   596
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   597
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   598
     * Global array of callback functions, one for each request sent.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   599
     *
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   600
     * @property callbacks
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   601
     * @type Function[]
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   602
     * @static
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   603
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   604
    callbacks : [],
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   605
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   606
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   607
     * Unique ID to track requests.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   608
     *
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   609
     * @property _tId
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   610
     * @type Number
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   611
     * @private
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   612
     * @static
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   613
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   614
    _tId : 0
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   615
});
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   616
    
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   617
Y.extend(DSGet, Y.DataSource.Local, {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   618
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   619
     * Passes query string to Get Utility. Fires <code>response</code> event when
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   620
     * response is received asynchronously.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   621
     *
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   622
     * @method _defRequestFn
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   623
     * @param e {Event.Facade} Event Facade with the following properties:
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   624
     * <dl>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   625
     * <dt>tId (Number)</dt> <dd>Unique transaction ID.</dd>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   626
     * <dt>request (Object)</dt> <dd>The request.</dd>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   627
     * <dt>callback (Object)</dt> <dd>The callback object with the following properties:
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   628
     *     <dl>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   629
     *         <dt>success (Function)</dt> <dd>Success handler.</dd>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   630
     *         <dt>failure (Function)</dt> <dd>Failure handler.</dd>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   631
     *     </dl>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   632
     * </dd>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   633
     * <dt>cfg (Object)</dt> <dd>Configuration object.</dd>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   634
     * </dl>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   635
     * @protected
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   636
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   637
    _defRequestFn: function(e) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   638
        var uri = this.get("source"),
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   639
            get = this.get("get"),
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   640
            id = DSGet._tId++,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   641
            self = this;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   642
            
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   643
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   644
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   645
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   646
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   647
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   648
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   649
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   650
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   651
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   652
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   653
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   654
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   655
    // Dynamically add handler function with a closure to the callback stack
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   656
    YUI.Env.DataSource.callbacks[id] = Y.rbind(function(response) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   657
        if((self.get("asyncMode") !== "ignoreStaleResponses")||
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   658
                (id === DSGet.callbacks.length-1)) { // Must ignore stale responses
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   659
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   660
            self.fire("data", Y.mix({data:response}, e));
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   661
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   662
        else {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   663
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   664
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   665
        delete DSGet.callbacks[id];
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   666
    }, this, id);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   667
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   668
    // We are now creating a request
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   669
    uri += e.request + this.get("generateRequestCallback")(this, id);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   670
    //uri = this.doBefore(sUri);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   671
    get.script(uri, {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   672
        autopurge: true,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   673
        // Works in Firefox only....
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   674
        onFailure: Y.bind(function(e) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   675
            e.error = new Error("Script node data failure");
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   676
            this.fire("error", e);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   677
        }, this, e)
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   678
    });
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   679
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   680
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   681
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   682
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   683
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   684
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   685
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   686
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   687
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   688
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   689
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   690
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   691
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   692
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   693
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   694
        return e.tId;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   695
    }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   696
});
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   697
  
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   698
Y.DataSource.Get = DSGet;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   699
YUI.namespace("Env.DataSource.callbacks");
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   700
    
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   701
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   702
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   703
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   704
}, '3.0.0' ,{requires:['datasource-local', 'get']});
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   705
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   706
YUI.add('datasource-function', function(Y) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   707
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   708
/**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   709
 * Provides a DataSource implementation which can be used to retrieve data from a custom function.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   710
 *
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   711
 * @module datasource
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   712
 * @submodule datasource-function
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   713
 */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   714
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   715
/**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   716
 * Function subclass for the DataSource Utility.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   717
 * @class DataSource.Function
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   718
 * @extends DataSource.Local
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   719
 * @constructor
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   720
 */    
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   721
var LANG = Y.Lang,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   722
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   723
    DSFn = function() {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   724
        DSFn.superclass.constructor.apply(this, arguments);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   725
    };
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   726
    
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   727
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   728
    /////////////////////////////////////////////////////////////////////////////
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   729
    //
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   730
    // DataSource.Function static properties
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   731
    //
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   732
    /////////////////////////////////////////////////////////////////////////////
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   733
Y.mix(DSFn, {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   734
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   735
     * Class name.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   736
     *
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   737
     * @property NAME
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   738
     * @type String
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   739
     * @static     
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   740
     * @final
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   741
     * @value "dataSourceFunction"
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   742
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   743
    NAME: "dataSourceFunction",
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   744
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   745
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   746
    /////////////////////////////////////////////////////////////////////////////
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   747
    //
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   748
    // DataSource.Function Attributes
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   749
    //
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   750
    /////////////////////////////////////////////////////////////////////////////
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   751
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   752
    ATTRS: {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   753
        /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   754
        * @attribute source
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   755
        * @description Pointer to live data.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   756
        * @type MIXED
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   757
        * @default null
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   758
        */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   759
        source: {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   760
            validator: LANG.isFunction
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   761
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   762
    }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   763
});
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   764
    
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   765
Y.extend(DSFn, Y.DataSource.Local, {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   766
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   767
     * Passes query string to IO. Fires <code>response</code> event when
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   768
     * response is received asynchronously.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   769
     *
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   770
     * @method _defRequestFn
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   771
     * @param e {Event.Facade} Event Facade with the following properties:
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   772
     * <dl>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   773
     * <dt>tId (Number)</dt> <dd>Unique transaction ID.</dd>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   774
     * <dt>request (Object)</dt> <dd>The request.</dd>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   775
     * <dt>callback (Object)</dt> <dd>The callback object with the following properties:
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   776
     *     <dl>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   777
     *         <dt>success (Function)</dt> <dd>Success handler.</dd>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   778
     *         <dt>failure (Function)</dt> <dd>Failure handler.</dd>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   779
     *     </dl>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   780
     * </dd>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   781
     * <dt>cfg (Object)</dt> <dd>Configuration object.</dd>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   782
     * </dl>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   783
     * @protected
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   784
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   785
    _defRequestFn: function(e) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   786
        var fn = this.get("source"),
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   787
            response;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   788
            
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   789
            if(fn) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   790
                try {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   791
                    response = fn(e.request, this, e);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   792
                    this.fire("data", Y.mix({data:response}, e));
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   793
                }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   794
                catch(error) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   795
                    e.error = error;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   796
                    this.fire("error", e);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   797
                }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   798
            }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   799
            else {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   800
                e.error = new Error("Function data failure");
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   801
                this.fire("error", e);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   802
            }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   803
            
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   804
        return e.tId;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   805
    }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   806
});
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   807
  
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   808
Y.DataSource.Function = DSFn;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   809
    
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   810
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   811
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   812
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   813
}, '3.0.0' ,{requires:['datasource-local']});
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   814
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   815
YUI.add('datasource-cache', function(Y) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   816
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   817
/**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   818
 * Extends DataSource with caching functionality.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   819
 *
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   820
 * @module datasource
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   821
 * @submodule datasource-cache
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   822
 */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   823
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   824
/**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   825
 * Adds cacheability to the DataSource Utility.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   826
 * @class DataSourceCache
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   827
 * @extends Cache
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   828
 */    
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   829
var DataSourceCache = function() {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   830
    DataSourceCache.superclass.constructor.apply(this, arguments);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   831
};
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   832
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   833
Y.mix(DataSourceCache, {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   834
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   835
     * The namespace for the plugin. This will be the property on the host which
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   836
     * references the plugin instance.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   837
     *
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   838
     * @property NS
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   839
     * @type String
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   840
     * @static
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   841
     * @final
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   842
     * @value "cache"
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   843
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   844
    NS: "cache",
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   845
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   846
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   847
     * Class name.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   848
     *
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   849
     * @property NAME
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   850
     * @type String
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   851
     * @static
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   852
     * @final
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   853
     * @value "dataSourceCache"
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   854
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   855
    NAME: "dataSourceCache",
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   856
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   857
    /////////////////////////////////////////////////////////////////////////////
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   858
    //
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   859
    // DataSourceCache Attributes
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   860
    //
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   861
    /////////////////////////////////////////////////////////////////////////////
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   862
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   863
    ATTRS: {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   864
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   865
    }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   866
});
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   867
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   868
Y.extend(DataSourceCache, Y.Cache, {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   869
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   870
    * Internal init() handler.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   871
    *
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   872
    * @method initializer
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   873
    * @param config {Object} Config object.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   874
    * @private
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   875
    */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   876
    initializer: function(config) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   877
        this.doBefore("_defRequestFn", this._beforeDefRequestFn);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   878
        this.doBefore("_defResponseFn", this._beforeDefResponseFn);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   879
    },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   880
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   881
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   882
     * First look for cached response, then send request to live data.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   883
     *
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   884
     * @method _beforeDefRequestFn
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   885
     * @param e {Event.Facade} Event Facade with the following properties:
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   886
     * <dl>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   887
     * <dt>tId (Number)</dt> <dd>Unique transaction ID.</dd>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   888
     * <dt>request (Object)</dt> <dd>The request.</dd>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   889
     * <dt>callback (Object)</dt> <dd>The callback object.</dd>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   890
     * <dt>cfg (Object)</dt> <dd>Configuration object.</dd>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   891
     * </dl>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   892
     * @protected
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   893
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   894
    _beforeDefRequestFn: function(e) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   895
        // Is response already in the Cache?
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   896
        var entry = (this.retrieve(e.request)) || null;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   897
        if(entry && entry.response) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   898
            this.get("host").fire("response", Y.mix({response: entry.response}, e));
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   899
            return new Y.Do.Halt("DataSourceCache plugin halted _defRequestFn");
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   900
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   901
    },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   902
    
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   903
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   904
     * Adds data to cache before returning data.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   905
     *
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   906
     * @method _beforeDefResponseFn
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   907
     * @param e {Event.Facade} Event Facade with the following properties:
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   908
     * <dl>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   909
     * <dt>tId (Number)</dt> <dd>Unique transaction ID.</dd>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   910
     * <dt>request (Object)</dt> <dd>The request.</dd>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   911
     * <dt>callback (Object)</dt> <dd>The callback object with the following properties:
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   912
     *     <dl>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   913
     *         <dt>success (Function)</dt> <dd>Success handler.</dd>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   914
     *         <dt>failure (Function)</dt> <dd>Failure handler.</dd>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   915
     *     </dl>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   916
     * </dd>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   917
     * <dt>data (Object)</dt> <dd>Raw data.</dd>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   918
     * <dt>response (Object)</dt> <dd>Normalized response object with the following properties:
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   919
     *     <dl>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   920
     *         <dt>cached (Object)</dt> <dd>True when response is cached.</dd>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   921
     *         <dt>results (Object)</dt> <dd>Parsed results.</dd>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   922
     *         <dt>meta (Object)</dt> <dd>Parsed meta data.</dd>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   923
     *         <dt>error (Object)</dt> <dd>Error object.</dd>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   924
     *     </dl>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   925
     * </dd>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   926
     * <dt>cfg (Object)</dt> <dd>Configuration object.</dd>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   927
     * </dl>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   928
     * @protected
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   929
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   930
     _beforeDefResponseFn: function(e) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   931
        // Add to Cache before returning
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   932
        if(e.response && !e.response.cached) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   933
            e.response.cached = true;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   934
            this.add(e.request, e.response, (e.callback && e.callback.argument));
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   935
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   936
     }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   937
});
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   938
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   939
Y.namespace('Plugin').DataSourceCache = DataSourceCache;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   940
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   941
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   942
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   943
}, '3.0.0' ,{requires:['datasource-local', 'cache']});
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   944
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   945
YUI.add('datasource-jsonschema', function(Y) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   946
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   947
/**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   948
 * Extends DataSource with schema-parsing on JSON data.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   949
 *
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   950
 * @module datasource
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   951
 * @submodule datasource-jsonschema
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   952
 */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   953
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   954
/**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   955
 * Adds schema-parsing to the DataSource Utility.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   956
 * @class DataSourceJSONSchema
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   957
 * @extends Plugin.Base
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   958
 */    
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   959
var DataSourceJSONSchema = function() {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   960
    DataSourceJSONSchema.superclass.constructor.apply(this, arguments);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   961
};
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   962
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   963
Y.mix(DataSourceJSONSchema, {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   964
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   965
     * The namespace for the plugin. This will be the property on the host which
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   966
     * references the plugin instance.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   967
     *
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   968
     * @property NS
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   969
     * @type String
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   970
     * @static
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   971
     * @final
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   972
     * @value "schema"
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   973
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   974
    NS: "schema",
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   975
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   976
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   977
     * Class name.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   978
     *
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   979
     * @property NAME
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   980
     * @type String
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   981
     * @static
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   982
     * @final
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   983
     * @value "dataSourceJSONSchema"
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   984
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   985
    NAME: "dataSourceJSONSchema",
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   986
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   987
    /////////////////////////////////////////////////////////////////////////////
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   988
    //
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   989
    // DataSourceJSONSchema Attributes
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   990
    //
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   991
    /////////////////////////////////////////////////////////////////////////////
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   992
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   993
    ATTRS: {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   994
        schema: {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   995
            //value: {}
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   996
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   997
    }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   998
});
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   999
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1000
Y.extend(DataSourceJSONSchema, Y.Plugin.Base, {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1001
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1002
    * Internal init() handler.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1003
    *
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1004
    * @method initializer
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1005
    * @param config {Object} Config object.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1006
    * @private
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1007
    */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1008
    initializer: function(config) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1009
        this.doBefore("_defDataFn", this._beforeDefDataFn);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1010
    },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1011
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1012
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1013
     * Parses raw data into a normalized response.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1014
     *
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1015
     * @method _beforeDefDataFn
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1016
     * <dl>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1017
     * <dt>tId (Number)</dt> <dd>Unique transaction ID.</dd>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1018
     * <dt>request (Object)</dt> <dd>The request.</dd>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1019
     * <dt>callback (Object)</dt> <dd>The callback object with the following properties:
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1020
     *     <dl>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1021
     *         <dt>success (Function)</dt> <dd>Success handler.</dd>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1022
     *         <dt>failure (Function)</dt> <dd>Failure handler.</dd>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1023
     *     </dl>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1024
     * </dd>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1025
     * <dt>data (Object)</dt> <dd>Raw data.</dd>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1026
     * </dl>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1027
     * @protected
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1028
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1029
    _beforeDefDataFn: function(e) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1030
        var data = (Y.DataSource.IO && (this.get("host") instanceof Y.DataSource.IO) && Y.Lang.isString(e.data.responseText)) ? e.data.responseText : e.data,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1031
            response = Y.DataSchema.JSON.apply(this.get("schema"), data);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1032
            
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1033
        // Default
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1034
        if(!response) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1035
            response = {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1036
                meta: {},
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1037
                results: data
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1038
            };
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1039
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1040
        
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1041
        this.get("host").fire("response", Y.mix({response:response}, e));
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1042
        return new Y.Do.Halt("DataSourceJSONSchema plugin halted _defDataFn");
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1043
    }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1044
});
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1045
    
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1046
Y.namespace('Plugin').DataSourceJSONSchema = DataSourceJSONSchema;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1047
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1048
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1049
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1050
}, '3.0.0' ,{requires:['plugin', 'datasource-local', 'dataschema-json']});
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1051
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1052
YUI.add('datasource-xmlschema', function(Y) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1053
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1054
/**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1055
 * Extends DataSource with schema-parsing on XML data.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1056
 *
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1057
 * @module datasource
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1058
 * @submodule datasource-xmlschema
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1059
 */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1060
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1061
/**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1062
 * Adds schema-parsing to the DataSource Utility.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1063
 * @class DataSourceXMLSchema
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1064
 * @extends Plugin.Base
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1065
 */    
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1066
var DataSourceXMLSchema = function() {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1067
    DataSourceXMLSchema.superclass.constructor.apply(this, arguments);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1068
};
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1069
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1070
Y.mix(DataSourceXMLSchema, {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1071
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1072
     * The namespace for the plugin. This will be the property on the host which
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1073
     * references the plugin instance.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1074
     *
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1075
     * @property NS
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1076
     * @type String
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1077
     * @static
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1078
     * @final
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1079
     * @value "schema"
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1080
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1081
    NS: "schema",
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1082
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1083
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1084
     * Class name.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1085
     *
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1086
     * @property NAME
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1087
     * @type String
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1088
     * @static
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1089
     * @final
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1090
     * @value "dataSourceXMLSchema"
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1091
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1092
    NAME: "dataSourceXMLSchema",
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1093
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1094
    /////////////////////////////////////////////////////////////////////////////
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1095
    //
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1096
    // DataSourceXMLSchema Attributes
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1097
    //
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1098
    /////////////////////////////////////////////////////////////////////////////
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1099
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1100
    ATTRS: {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1101
        schema: {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1102
            //value: {}
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1103
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1104
    }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1105
});
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1106
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1107
Y.extend(DataSourceXMLSchema, Y.Plugin.Base, {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1108
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1109
    * Internal init() handler.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1110
    *
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1111
    * @method initializer
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1112
    * @param config {Object} Config object.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1113
    * @private
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1114
    */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1115
    initializer: function(config) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1116
        this.doBefore("_defDataFn", this._beforeDefDataFn);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1117
    },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1118
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1119
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1120
     * Parses raw data into a normalized response.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1121
     *
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1122
     * @method _beforeDefDataFn
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1123
     * <dl>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1124
     * <dt>tId (Number)</dt> <dd>Unique transaction ID.</dd>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1125
     * <dt>request (Object)</dt> <dd>The request.</dd>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1126
     * <dt>callback (Object)</dt> <dd>The callback object with the following properties:
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1127
     *     <dl>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1128
     *         <dt>success (Function)</dt> <dd>Success handler.</dd>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1129
     *         <dt>failure (Function)</dt> <dd>Failure handler.</dd>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1130
     *     </dl>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1131
     * </dd>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1132
     * <dt>data (Object)</dt> <dd>Raw data.</dd>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1133
     * </dl>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1134
     * @protected
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1135
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1136
    _beforeDefDataFn: function(e) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1137
        var data = (Y.DataSource.IO && (this.get("host") instanceof Y.DataSource.IO) && e.data.responseXML && (e.data.responseXML.nodeType === 9)) ? e.data.responseXML : e.data,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1138
            response = Y.DataSchema.XML.apply(this.get("schema"), data);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1139
            
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1140
        // Default
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1141
        if(!response) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1142
            response = {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1143
                meta: {},
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1144
                results: data
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1145
            };
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1146
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1147
        
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1148
        this.get("host").fire("response", Y.mix({response:response}, e));
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1149
        return new Y.Do.Halt("DataSourceXMLSchema plugin halted _defDataFn");
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1150
    }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1151
});
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1152
    
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1153
Y.namespace('Plugin').DataSourceXMLSchema = DataSourceXMLSchema;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1154
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1155
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1156
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1157
}, '3.0.0' ,{requires:['plugin', 'datasource-local', 'dataschema-xml']});
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1158
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1159
YUI.add('datasource-arrayschema', function(Y) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1160
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1161
/**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1162
 * Extends DataSource with schema-parsing on array data.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1163
 *
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1164
 * @module datasource
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1165
 * @submodule datasource-arrayschema
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1166
 */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1167
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1168
/**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1169
 * Adds schema-parsing to the DataSource Utility.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1170
 * @class DataSourceArraySchema
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1171
 * @extends Plugin.Base
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1172
 */    
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1173
var DataSourceArraySchema = function() {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1174
    DataSourceArraySchema.superclass.constructor.apply(this, arguments);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1175
};
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1176
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1177
Y.mix(DataSourceArraySchema, {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1178
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1179
     * The namespace for the plugin. This will be the property on the host which
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1180
     * references the plugin instance.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1181
     *
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1182
     * @property NS
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1183
     * @type String
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1184
     * @static
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1185
     * @final
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1186
     * @value "schema"
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1187
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1188
    NS: "schema",
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1189
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1190
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1191
     * Class name.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1192
     *
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1193
     * @property NAME
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1194
     * @type String
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1195
     * @static
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1196
     * @final
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1197
     * @value "dataSourceArraySchema"
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1198
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1199
    NAME: "dataSourceArraySchema",
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1200
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1201
    /////////////////////////////////////////////////////////////////////////////
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1202
    //
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1203
    // DataSourceArraySchema Attributes
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1204
    //
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1205
    /////////////////////////////////////////////////////////////////////////////
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1206
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1207
    ATTRS: {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1208
        schema: {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1209
            //value: {}
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1210
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1211
    }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1212
});
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1213
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1214
Y.extend(DataSourceArraySchema, Y.Plugin.Base, {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1215
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1216
    * Internal init() handler.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1217
    *
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1218
    * @method initializer
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1219
    * @param config {Object} Config object.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1220
    * @private
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1221
    */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1222
    initializer: function(config) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1223
        this.doBefore("_defDataFn", this._beforeDefDataFn);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1224
    },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1225
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1226
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1227
     * Parses raw data into a normalized response.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1228
     *
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1229
     * @method _beforeDefDataFn
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1230
     * <dl>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1231
     * <dt>tId (Number)</dt> <dd>Unique transaction ID.</dd>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1232
     * <dt>request (Object)</dt> <dd>The request.</dd>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1233
     * <dt>callback (Object)</dt> <dd>The callback object with the following properties:
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1234
     *     <dl>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1235
     *         <dt>success (Function)</dt> <dd>Success handler.</dd>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1236
     *         <dt>failure (Function)</dt> <dd>Failure handler.</dd>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1237
     *     </dl>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1238
     * </dd>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1239
     * <dt>data (Object)</dt> <dd>Raw data.</dd>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1240
     * </dl>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1241
     * @protected
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1242
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1243
    _beforeDefDataFn: function(e) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1244
        var data = (Y.DataSource.IO && (this.get("host") instanceof Y.DataSource.IO) && Y.Lang.isString(e.data.responseText)) ? e.data.responseText : e.data,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1245
            response = Y.DataSchema.Array.apply(this.get("schema"), data);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1246
            
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1247
        // Default
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1248
        if(!response) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1249
            response = {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1250
                meta: {},
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1251
                results: data
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1252
            };
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1253
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1254
        
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1255
        this.get("host").fire("response", Y.mix({response:response}, e));
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1256
        return new Y.Do.Halt("DataSourceArraySchema plugin halted _defDataFn");
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1257
    }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1258
});
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1259
    
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1260
Y.namespace('Plugin').DataSourceArraySchema = DataSourceArraySchema;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1261
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1262
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1263
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1264
}, '3.0.0' ,{requires:['plugin', 'datasource-local', 'dataschema-array']});
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1265
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1266
YUI.add('datasource-textschema', function(Y) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1267
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1268
/**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1269
 * Extends DataSource with schema-parsing on text data.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1270
 *
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1271
 * @module datasource
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1272
 * @submodule datasource-textschema
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1273
 */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1274
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1275
/**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1276
 * Adds schema-parsing to the DataSource Utility.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1277
 * @class DataSourceTextSchema
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1278
 * @extends Plugin.Base
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1279
 */    
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1280
var DataSourceTextSchema = function() {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1281
    DataSourceTextSchema.superclass.constructor.apply(this, arguments);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1282
};
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1283
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1284
Y.mix(DataSourceTextSchema, {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1285
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1286
     * The namespace for the plugin. This will be the property on the host which
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1287
     * references the plugin instance.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1288
     *
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1289
     * @property NS
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1290
     * @type String
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1291
     * @static
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1292
     * @final
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1293
     * @value "schema"
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1294
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1295
    NS: "schema",
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1296
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1297
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1298
     * Class name.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1299
     *
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1300
     * @property NAME
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1301
     * @type String
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1302
     * @static
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1303
     * @final
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1304
     * @value "dataSourceTextSchema"
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1305
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1306
    NAME: "dataSourceTextSchema",
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1307
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1308
    /////////////////////////////////////////////////////////////////////////////
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1309
    //
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1310
    // DataSourceTextSchema Attributes
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1311
    //
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1312
    /////////////////////////////////////////////////////////////////////////////
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1313
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1314
    ATTRS: {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1315
        schema: {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1316
            //value: {}
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1317
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1318
    }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1319
});
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1320
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1321
Y.extend(DataSourceTextSchema, Y.Plugin.Base, {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1322
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1323
    * Internal init() handler.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1324
    *
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1325
    * @method initializer
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1326
    * @param config {Object} Config object.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1327
    * @private
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1328
    */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1329
    initializer: function(config) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1330
        this.doBefore("_defDataFn", this._beforeDefDataFn);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1331
    },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1332
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1333
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1334
     * Parses raw data into a normalized response.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1335
     *
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1336
     * @method _beforeDefDataFn
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1337
     * <dl>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1338
     * <dt>tId (Number)</dt> <dd>Unique transaction ID.</dd>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1339
     * <dt>request (Object)</dt> <dd>The request.</dd>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1340
     * <dt>callback (Object)</dt> <dd>The callback object with the following properties:
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1341
     *     <dl>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1342
     *         <dt>success (Function)</dt> <dd>Success handler.</dd>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1343
     *         <dt>failure (Function)</dt> <dd>Failure handler.</dd>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1344
     *     </dl>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1345
     * </dd>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1346
     * <dt>data (Object)</dt> <dd>Raw data.</dd>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1347
     * </dl>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1348
     * @protected
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1349
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1350
    _beforeDefDataFn: function(e) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1351
        var data = (Y.DataSource.IO && (this.get("host") instanceof Y.DataSource.IO) && Y.Lang.isString(e.data.responseText)) ? e.data.responseText : e.data,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1352
            response = Y.DataSchema.Text.apply(this.get("schema"), data);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1353
            
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1354
        // Default
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1355
        if(!response) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1356
            response = {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1357
                meta: {},
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1358
                results: data
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1359
            };
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1360
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1361
        
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1362
        this.get("host").fire("response", Y.mix({response:response}, e));
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1363
        return new Y.Do.Halt("DataSourceTextSchema plugin halted _defDataFn");
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1364
    }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1365
});
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1366
    
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1367
Y.namespace('Plugin').DataSourceTextSchema = DataSourceTextSchema;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1368
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1369
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1370
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1371
}, '3.0.0' ,{requires:['plugin', 'datasource-local', 'dataschema-text']});
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1372
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1373
YUI.add('datasource-polling', function(Y) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1374
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1375
/**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1376
 * Extends DataSource with polling functionality.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1377
 *
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1378
 * @module datasource
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1379
 * @submodule datasource-polling
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1380
 */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1381
    
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1382
/**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1383
 * Adds polling to the DataSource Utility.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1384
 * @class Pollable
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1385
 * @extends DataSource.Local
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1386
 */    
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1387
var LANG = Y.Lang,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1388
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1389
    Pollable = function() {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1390
        this._intervals = {};
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1391
    };
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1392
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1393
Pollable.prototype = {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1394
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1395
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1396
    * @property _intervals
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1397
    * @description Hash of polling interval IDs that have been enabled,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1398
    * stored here to be able to clear all intervals.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1399
    * @private
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1400
    */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1401
    _intervals: null,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1402
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1403
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1404
     * Sets up a polling mechanism to send requests at set intervals and forward
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1405
     * responses to given callback.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1406
     *
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1407
     * @method setInterval
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1408
     * @param msec {Number} Length of interval in milliseconds.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1409
     * @param request {Object} Request object.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1410
     * @param callback {Object} An object literal with the following properties:
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1411
     *     <dl>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1412
     *     <dt><code>success</code></dt>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1413
     *     <dd>The function to call when the data is ready.</dd>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1414
     *     <dt><code>failure</code></dt>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1415
     *     <dd>The function to call upon a response failure condition.</dd>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1416
     *     <dt><code>argument</code></dt>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1417
     *     <dd>Arbitrary data that will be passed back to the success and failure handlers.</dd>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1418
     *     </dl>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1419
     * @return {Number} Interval ID.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1420
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1421
    setInterval: function(msec, request, callback) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1422
        var x = Y.later(msec, this, this.sendRequest, [request, callback], true);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1423
        this._intervals[x.id] = x;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1424
        return x.id;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1425
    },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1426
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1427
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1428
     * Disables polling mechanism associated with the given interval ID.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1429
     *
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1430
     * @method clearInterval
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1431
     * @param id {Number} Interval ID.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1432
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1433
    clearInterval: function(id, key) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1434
        // In case of being called by clearAllIntervals()
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1435
        id = key || id;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1436
        if(this._intervals[id]) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1437
            // Clear the interval
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1438
            this._intervals[id].cancel();
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1439
            // Clear from tracker
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1440
            delete this._intervals[id];
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1441
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1442
    },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1443
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1444
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1445
     * Clears all intervals.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1446
     *
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1447
     * @method clearAllIntervals
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1448
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1449
    clearAllIntervals: function() {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1450
        Y.each(this._intervals, this.clearInterval, this);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1451
    }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1452
};
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1453
    
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1454
Y.augment(Y.DataSource.Local, Pollable);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1455
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1456
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1457
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1458
}, '3.0.0' ,{requires:['datasource-local']});
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1459
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1460
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1461
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1462
YUI.add('datasource', function(Y){}, '3.0.0' ,{use:['datasource-local','datasource-io','datasource-get','datasource-function','datasource-cache','datasource-jsonschema','datasource-xmlschema','datasource-arrayschema','datasource-textschema','datasource-polling']});
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1463