marko/widgets/index-browser.js
2016-11-02 22:17:56 -06:00

90 lines
2.5 KiB
JavaScript

var dom = require('./dom');
var ready = dom.ready;
var EMPTY_OBJ = {};
var Widget = require('./Widget');
var initWidgets = require('./init-widgets');
var updateManager = require('./update-manager');
var events = require('../runtime/events');
var WidgetsContext = exports.WidgetsContext = require('./WidgetsContext');
exports.getWidgetsContext = WidgetsContext.getWidgetsContext;
exports.Widget = Widget;
exports.ready = ready;
exports.onInitWidget = function(listener) {
events.on('initWidget', listener);
};
exports.attrs = function() {
return EMPTY_OBJ;
};
exports.writeDomEventsEl = function() {
/* Intentionally empty in the browser */
};
function getWidgetForEl(id, document) {
if (!id) {
return undefined;
}
var node = typeof id === 'string' ? (document || window.document).getElementById(id) : id;
return (node && node.__widget) || undefined;
}
exports.get = exports.getWidgetForEl = getWidgetForEl;
exports.initAllWidgets = function() {
initWidgets.initServerRendered(true /* scan DOM */);
};
// Subscribe to DOM manipulate events to handle creating and destroying widgets
events.on('dom/beforeRemove', function(eventArgs) {
var el = eventArgs.el;
var widget = el.id ? getWidgetForEl(el) : null;
if (widget) {
widget.destroy({
removeNode: false,
recursive: true
});
}
})
.on('mountNode', function(eventArgs) {
var out = eventArgs.out;
var widgetsContext = out.global.widgets;
if (widgetsContext) {
widgetsContext.initWidgets(eventArgs.document);
}
});
exports.initWidgets = window.$markoWidgets = function(ids) {
initWidgets.initServerRendered(ids);
};
var JQUERY = 'jquery';
var jquery = window.$;
if (!jquery) {
try {
jquery = require(JQUERY);
}
catch(e) {}
}
exports.$ = jquery;
exports.registerWidget = require('./registry').register;
exports.defineComponent = require('./defineComponent');
exports.defineWidget = require('./defineWidget');
exports.defineRenderer = require('./defineRenderer');
exports.makeRenderable = exports.renderable = require('./renderable');
exports.c = function(component, template) {
component.template = template;
return exports.defineComponent(component);
};
exports.batchUpdate = updateManager.batchUpdate;
exports.onAfterUpdate = updateManager.onAfterUpdate;
window.$MARKO_WIDGETS = exports; // Helpful when debugging... WARNING: DO NOT USE IN REAL CODE!