Version 3.17.2

APIs

  • Begin typing in the search box above to see results.
Show:

File: datasource/js/datasource-local.js

/**
 * 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:
 * <dl>
 * <dt>tId (Number)</dt> <dd>Unique transaction ID.</dd>
 * <dt>request (Object)</dt> <dd>The request.</dd>
 * <dt>callback (Object)</dt> <dd>The callback object
 * (deprecated, refer to <strong>on</strong></dd>
 * <dt>on (Object)</dt> <dd>The map of configured callback
 * functions.</dd>
 * <dt>cfg (Object)</dt> <dd>Configuration object.</dd>
 * </dl>
 * @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:
 * <dl>
 * <dt>tId (Number)</dt> <dd>Unique transaction ID.</dd>
 * <dt>request (Object)</dt> <dd>The request.</dd>
 * <dt>callback (Object)</dt> <dd>Deprecated alias for the
 * <strong>on</strong> property</dd>
 * <dt>on (Object)</dt> <dd>The map of configured transaction
 * callbacks. An object with the following properties:
 * <dl>
 * <dt>success (Function)</dt> <dd>Success handler.</dd>
 * <dt>failure (Function)</dt> <dd>Failure handler.</dd>
 * </dl>
 * </dd>
 * <dt>cfg (Object)</dt> <dd>Configuration object.</dd>
 * <dt>data (Object)</dt> <dd>Raw data.</dd>
 * </dl>
 * @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:
 * <dl>
 * <dt>tId (Number)</dt> <dd>Unique transaction ID.</dd>
 * <dt>request (Object)</dt> <dd>The request.</dd>
 * <dt>callback (Object)</dt> <dd>Deprecated alias for the
 * <strong>on</strong> property</dd>
 * <dt>on (Object)</dt> <dd>The map of configured transaction
 * callbacks. An object with the following properties:
 * <dl>
 * <dt>success (Function)</dt> <dd>Success handler.</dd>
 * <dt>failure (Function)</dt> <dd>Failure handler.</dd>
 * </dl>
 * </dd>
 * <dt>cfg (Object)</dt> <dd>Configuration object.</dd>
 * <dt>data (Object)</dt> <dd>Raw data.</dd>
 * <dt>response (Object)</dt>
 * <dd>Normalized response object with the following properties:
 * <dl>
 * <dt>results (Object)</dt> <dd>Parsed results.</dd>
 * <dt>meta (Object)</dt> <dd>Parsed meta data.</dd>
 * <dt>error (Boolean)</dt> <dd>Error flag.</dd>
 * </dl>
 * </dd>
 * <dt>error</dt>
 * <dd>Any error that occurred along the transaction lifecycle.</dd>
 * </dl>
 * @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:
 * <dl>
 * <dt>tId (Number)</dt> <dd>Unique transaction ID.</dd>
 * <dt>request (Object)</dt> <dd>The request.</dd>
 * <dt>callback (Object)</dt> <dd>Deprecated alias for the
 * <strong>on</strong> property</dd>
 * <dt>on (Object)</dt> <dd>The map of configured transaction
 * callbacks. An object with the following properties:
 * <dl>
 * <dt>success (Function)</dt> <dd>Success handler.</dd>
 * <dt>failure (Function)</dt> <dd>Failure handler.</dd>
 * </dl>
 * </dd>
 * <dt>cfg (Object)</dt> <dd>Configuration object.</dd>
 * <dt>data (Object)</dt> <dd>Raw data.</dd>
 * <dt>response (Object)</dt>
 * <dd>Normalized response object with the following properties:
 * <dl>
 * <dt>results (Object)</dt> <dd>Parsed results.</dd>
 * <dt>meta (Object)</dt> <dd>Parsed meta data.</dd>
 * <dt>error (Object)</dt> <dd>Error object.</dd>
 * </dl>
 * </dd>
 * <dt>error</dt>
 * <dd>Any error that occurred along the transaction lifecycle.</dd>
 * </dl>
 */
 },
 /**
 * Manages request/response transaction. Must fire <code>response</code>
 * 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:
 * <dl>
 * <dt>tId (Number)</dt> <dd>Unique transaction ID.</dd>
 * <dt>request (Object)</dt> <dd>The request.</dd>
 * <dt>callback (Object)</dt> <dd>Deprecated alias for the
 * <strong>on</strong> property</dd>
 * <dt>on (Object)</dt> <dd>The map of configured transaction
 * callbacks. An object with the following properties:
 * <dl>
 * <dt>success (Function)</dt> <dd>Success handler.</dd>
 * <dt>failure (Function)</dt> <dd>Failure handler.</dd>
 * </dl>
 * </dd>
 * <dt>cfg (Object)</dt> <dd>Configuration object.</dd>
 * </dl>
 * @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:
 * <dl>
 * <dt>tId (Number)</dt> <dd>Unique transaction ID.</dd>
 * <dt>request (Object)</dt> <dd>The request.</dd>
 * <dt>callback (Object)</dt> <dd>Deprecated alias for the
 * <strong>on</strong> property</dd>
 * <dt>on (Object)</dt> <dd>The map of configured transaction
 * callbacks. An object with the following properties:
 * <dl>
 * <dt>success (Function)</dt> <dd>Success handler.</dd>
 * <dt>failure (Function)</dt> <dd>Failure handler.</dd>
 * </dl>
 * </dd>
 * <dt>cfg (Object)</dt> <dd>Configuration object.</dd>
 * <dt>data (Object)</dt> <dd>Raw data.</dd>
 * </dl>
 * @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:
 * <dl>
 * <dt>tId (Number)</dt> <dd>Unique transaction ID.</dd>
 * <dt>request (Object)</dt> <dd>The request.</dd>
 * <dt>callback (Object)</dt> <dd>Deprecated alias for the
 * <strong>on</strong> property</dd>
 * <dt>on (Object)</dt> <dd>The map of configured transaction
 * callbacks. An object with the following properties:
 * <dl>
 * <dt>success (Function)</dt> <dd>Success handler.</dd>
 * <dt>failure (Function)</dt> <dd>Failure handler.</dd>
 * </dl>
 * </dd>
 * <dt>cfg (Object)</dt> <dd>Configuration object.</dd>
 * <dt>data (Object)</dt> <dd>Raw data.</dd>
 * <dt>response (Object)</dt> <dd>Normalized response object with the following properties:
 * <dl>
 * <dt>results (Object)</dt> <dd>Parsed results.</dd>
 * <dt>meta (Object)</dt> <dd>Parsed meta data.</dd>
 * <dt>error (Boolean)</dt> <dd>Error flag.</dd>
 * </dl>
 * </dd>
 * </dl>
 * @protected
 */
 _defResponseFn: function(e) {
 // Send the response back to the callback
 DSLocal.issueCallback(e, this);
 },
 /**
 * Generates a unique transaction ID and fires <code>request</code> event.
 * <strong>Note</strong>: the property <code>callback</code> is a
 * deprecated alias for the <code>on</code> transaction configuration
 * property described below.
 *
 * @method sendRequest
 * @param [request] {Object} An object literal with the following properties:
 * <dl>
 * <dt><code>request</code></dt>
 * <dd>The request to send to the live data source, if any.</dd>
 * <dt><code>on</code></dt>
 * <dd>An object literal with the following properties:
 * <dl>
 * <dt><code>success</code></dt>
 * <dd>The function to call when the data is ready.</dd>
 * <dt><code>failure</code></dt>
 * <dd>The function to call upon a response failure condition.</dd>
 * <dt><code>argument</code></dt>
 * <dd>Arbitrary data payload that will be passed back to the success and failure handlers.</dd>
 * </dl>
 * </dd>
 * <dt><code>cfg</code></dt>
 * <dd>Configuration object, if any.</dd>
 * </dl>
 * @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;
 

AltStyle によって変換されたページ (->オリジナル) /