/* YUI 3.17.2 (build 9c3c78e) Copyright 2014 Yahoo! Inc. All rights reserved. Licensed under the BSD License. http://yuilibrary.com/license/ */ YUI.add('datasource-local', function (Y, NAME) { /** * The DataSource utility provides a common configurable interface for widgets to * access a variety of data, from JavaScript arrays to online database servers. * * @module datasource * @main datasource */ /** * Provides the base DataSource implementation, which can be extended to * create DataSources for specific data protocols, such as the IO Utility, the * Get Utility, or custom functions. * * @module datasource * @submodule datasource-local */ /** * Base class for the DataSource Utility. * @class DataSource.Local * @extends Base * @constructor */ var LANG = Y.Lang, DSLocal = function() { DSLocal.superclass.constructor.apply(this, arguments); }; ///////////////////////////////////////////////////////////////////////////// // // DataSource static properties // ///////////////////////////////////////////////////////////////////////////// Y.mix(DSLocal, { /** * Class name. * * @property NAME * @type String * @static * @final * @value "dataSourceLocal" */ NAME: "dataSourceLocal", ///////////////////////////////////////////////////////////////////////////// // // DataSource Attributes // ///////////////////////////////////////////////////////////////////////////// ATTRS: { /** * @attribute source * @description Pointer to live data. * @type MIXED * @default null */ source: { value: null } }, /** * Global transaction counter. * * @property _tId * @type Number * @static * @private * @default 0 */ _tId: 0, /** * Global in-progress transaction objects. * * @property transactions * @type Object * @static */ transactions: {}, /** * Returns data to callback. * * @method issueCallback * @param e {EventFacade} Event Facade. * @param caller {DataSource} Calling DataSource instance. * @static */ issueCallback: function (e, caller) { var callbacks = e.on || e.callback, callback = callbacks && callbacks.success, payload = e.details[0]; payload.error = (e.error || e.response.error); if (payload.error) { caller.fire("error", payload); callback = callbacks && callbacks.failure; } if (callback) { //TODO: this should be executed from a specific context callback(payload); } } }); Y.extend(DSLocal, Y.Base, { /** * Internal init() handler. * * @method initializer * @param config {Object} Config object. * @private */ initializer: function(config) { this._initEvents(); }, /** * This method creates all the events for this module. * @method _initEvents * @private */ _initEvents: function() { /** * Fired when a data request is received. * * @event request * @param e {EventFacade} Event Facade with the following properties: *
*
tId (Number)
Unique transaction ID.
*
request (Object)
The request.
*
callback (Object)
The callback object * (deprecated, refer to on
*
on (Object)
The map of configured callback * functions.
*
cfg (Object)
Configuration object.
*
* @preventable _defRequestFn */ this.publish("request", {defaultFn: Y.bind("_defRequestFn", this), queuable:true}); /** * Fired when raw data is received. * * @event data * @param e {EventFacade} Event Facade with the following properties: *
*
tId (Number)
Unique transaction ID.
*
request (Object)
The request.
*
callback (Object)
Deprecated alias for the * on property
*
on (Object)
The map of configured transaction * callbacks. An object with the following properties: *
*
success (Function)
Success handler.
*
failure (Function)
Failure handler.
*
*
*
cfg (Object)
Configuration object.
*
data (Object)
Raw data.
*
* @preventable _defDataFn */ this.publish("data", {defaultFn: Y.bind("_defDataFn", this), queuable:true}); /** * Fired when response is returned. * * @event response * @param e {EventFacade} Event Facade with the following properties: *
*
tId (Number)
Unique transaction ID.
*
request (Object)
The request.
*
callback (Object)
Deprecated alias for the * on property
*
on (Object)
The map of configured transaction * callbacks. An object with the following properties: *
*
success (Function)
Success handler.
*
failure (Function)
Failure handler.
*
*
*
cfg (Object)
Configuration object.
*
data (Object)
Raw data.
*
response (Object)
*
Normalized response object with the following properties: *
*
results (Object)
Parsed results.
*
meta (Object)
Parsed meta data.
*
error (Boolean)
Error flag.
*
*
*
error
*
Any error that occurred along the transaction lifecycle.
*
* @preventable _defResponseFn */ this.publish("response", {defaultFn: Y.bind("_defResponseFn", this), queuable:true}); /** * Fired when an error is encountered. * * @event error * @param e {EventFacade} Event Facade with the following properties: *
*
tId (Number)
Unique transaction ID.
*
request (Object)
The request.
*
callback (Object)
Deprecated alias for the * on property
*
on (Object)
The map of configured transaction * callbacks. An object with the following properties: *
*
success (Function)
Success handler.
*
failure (Function)
Failure handler.
*
*
*
cfg (Object)
Configuration object.
*
data (Object)
Raw data.
*
response (Object)
*
Normalized response object with the following properties: *
*
results (Object)
Parsed results.
*
meta (Object)
Parsed meta data.
*
error (Object)
Error object.
*
*
*
error
*
Any error that occurred along the transaction lifecycle.
*
*/ }, /** * Manages request/response transaction. Must fire response * event when response is received. This method should be implemented by * subclasses to achieve more complex behavior such as accessing remote data. * * @method _defRequestFn * @param e {EventFacade} Event Facadewith the following properties: *
*
tId (Number)
Unique transaction ID.
*
request (Object)
The request.
*
callback (Object)
Deprecated alias for the * on property
*
on (Object)
The map of configured transaction * callbacks. An object with the following properties: *
*
success (Function)
Success handler.
*
failure (Function)
Failure handler.
*
*
*
cfg (Object)
Configuration object.
*
* @protected */ _defRequestFn: function(e) { var data = this.get("source"), payload = e.details[0]; // Problematic data if(LANG.isUndefined(data)) { payload.error = new Error("Local source undefined"); Y.log("Local source undefined", "error", "datasource-local"); } payload.data = data; this.fire("data", payload); Y.log("Transaction " + e.tId + " complete. Request: " + Y.dump(e.request) + " . Response: " + Y.dump(e.response), "info", "datasource-local"); }, /** * Normalizes raw data into a response that includes results and meta properties. * * @method _defDataFn * @param e {EventFacade} Event Facade with the following properties: *
*
tId (Number)
Unique transaction ID.
*
request (Object)
The request.
*
callback (Object)
Deprecated alias for the * on property
*
on (Object)
The map of configured transaction * callbacks. An object with the following properties: *
*
success (Function)
Success handler.
*
failure (Function)
Failure handler.
*
*
*
cfg (Object)
Configuration object.
*
data (Object)
Raw data.
*
* @protected */ _defDataFn: function(e) { var data = e.data, meta = e.meta, response = { results: (LANG.isArray(data)) ? data : [data], meta: (meta) ? meta : {} }, payload = e.details[0]; payload.response = response; this.fire("response", payload); }, /** * Sends data as a normalized response to callback. * * @method _defResponseFn * @param e {EventFacade} Event Facade with the following properties: *
*
tId (Number)
Unique transaction ID.
*
request (Object)
The request.
*
callback (Object)
Deprecated alias for the * on property
*
on (Object)
The map of configured transaction * callbacks. An object with the following properties: *
*
success (Function)
Success handler.
*
failure (Function)
Failure handler.
*
*
*
cfg (Object)
Configuration object.
*
data (Object)
Raw data.
*
response (Object)
Normalized response object with the following properties: *
*
results (Object)
Parsed results.
*
meta (Object)
Parsed meta data.
*
error (Boolean)
Error flag.
*
*
*
* @protected */ _defResponseFn: function(e) { // Send the response back to the callback DSLocal.issueCallback(e, this); }, /** * Generates a unique transaction ID and fires request event. * Note: the property callback is a * deprecated alias for the on transaction configuration * property described below. * * @method sendRequest * @param [request] {Object} An object literal with the following properties: *
*
request
*
The request to send to the live data source, if any.
*
on
*
An object literal with the following properties: *
*
success
*
The function to call when the data is ready.
*
failure
*
The function to call upon a response failure condition.
*
argument
*
Arbitrary data payload that will be passed back to the success and failure handlers.
*
*
*
cfg
*
Configuration object, if any.
*
* @return {Number} Transaction ID. */ sendRequest: function(request) { var tId = DSLocal._tId++, callbacks; request = request || {}; callbacks = request.on || request.callback; this.fire("request", { tId: tId, request: request.request, on: callbacks, callback: callbacks, cfg: request.cfg || {} }); Y.log("Transaction " + tId + " sent request: " + Y.dump(request.request), "info", "datasource-local"); return tId; } }); Y.namespace("DataSource").Local = DSLocal; }, '3.17.2', {"requires": ["base"]});