widget-uievents-debug.js revision 7522e66ba1f6dde079cdff7082765ccc33472bb3
/**
* Support for Widget UI Events (Custom Events fired by the widget, which wrap the underlying DOM events - e.g. widget:click, widget:mousedown)
*
* @module widget
* @submodule widget-uievents
*/
var BOUNDING_BOX = "boundingBox",
RENDER = "render",
L = Y.Lang,
EVENT_PREFIX_DELIMITER = ":",
// Map of Node instances serving as a delegation containers for a specific
// event type to Widget instances using that delegation container.
/**
* Destructor logic for UI event infrastructure,
* invoked during Widget destruction.
*
* @method _destroyUIEvents
* @for Widget
* @private
*/
_destroyUIEvents: function() {
var widgetGuid = Y.stamp(this, true);
// Unregister this Widget instance as needing this delegated
// event listener.
// There are no more Widget instances using this delegated
// event listener, so detach it.
}
}
}
});
},
/**
* Map of DOM events that should be fired as Custom Events by the
* Widget instance.
*
* @property UI_EVENTS
* @for Widget
* @type Object
*/
/**
* Returns the node on which to bind delegate listeners.
*
* @method _getUIEventNode
* @for Widget
* @protected
*/
_getUIEventNode: function () {
return this.get(BOUNDING_BOX);
},
/**
* Binds a delegated DOM event listener of the specified type to the
* Widget's outtermost DOM element to facilitate the firing of a Custom
* Event of the same type for the Widget instance.
*
* @private
* @for Widget
* @method _createUIEvent
* @param type {String} String representing the name of the event
*/
_createUIEvent: function (type) {
var uiEvtNode = this._getUIEventNode(),
// For each Node instance: Ensure that there is only one delegated
// event listener used to fire Widget UI events.
if (!info) {
// Make the DOM event a property of the custom event
// so that developers still have access to it.
// Quick workaround, until I figure out the multi instance
// issue. Theoretically, we should always get a widget
if (widget) {
}
}
// Register this Widget as using this Node as a delegation container.
},
/**
* Determines if the specified event is a UI event.
*
* @private
* @method _isUIEvent
* @for Widget
* @param type {String} String representing the name of the event
* @return {String} Event Returns the name of the UI Event, otherwise
* undefined.
*/
_getUIEvent: function (type) {
if (sType) {
// TODO: Get delimiter from ET, or have ET support this.
if (iDelim > -1) {
}
}
}
return returnVal;
}
},
/**
* Sets up infrastructure required to fire a UI event.
*
* @private
* @method _initUIEvent
* @for Widget
* @param type {String} String representing the name of the event
* @return {String}
*/
_initUIEvent: function (type) {
queue = this._uiEvtsInitQueue || {};
this._createUIEvent(sType);
delete this._uiEvtsInitQueue[sType];
});
}
},
// Override of "on" from Base to facilitate the firing of Widget events
// Temporary solution until we have the ability to listen to when
// someone adds an event listener (bug 2528230)
this._initUIEvent(type);
},
// Override of "publish" from Base to facilitate the firing of Widget events
// Temporary solution until we have the ability to listen to when
// someone publishes an event (bug 2528230)
this._initUIEvent(sType);
}
}
}, true); // overwrite existing EventTarget methods