UNPKG

can

Version:

MIT-licensed, client-side, JavaScript framework that makes building rich web applications easy.

92 lines (91 loc) 3.22 kB
/*! * CanJS - 2.3.34 * http://canjs.com/ * Copyright (c) 2018 Bitovi * Mon, 30 Apr 2018 20:56:51 GMT * Licensed MIT */ /*can@2.3.34#view/autorender/autorender*/ 'format steal'; define([ 'can/util/library', 'can/map/app', 'can/util/view_model' ], function (can) { var deferred = new can.Deferred(), ignoreAttributesRegExp = /^(dataViewId|class|id|type|src)$/i; var typeMatch = /\s*text\/(mustache|stache|ejs)\s*/; function isIn(element, type) { while (element.parentNode) { element = element.parentNode; if (element.nodeName.toLowerCase() === type.toLowerCase()) { return true; } } } function setAttr(el, attr, scope) { var camelized = can.camelize(attr); if (!ignoreAttributesRegExp.test(camelized)) { scope.attr(camelized, el.getAttribute(attr)); } } function insertAfter(ref, element) { if (ref.nextSibling) { can.insertBefore(ref.parentNode, element, ref.nextSibling); } else { can.appendChild(ref.parentNode, element); } } function render(renderer, scope, el) { var frag = renderer(scope); if (isIn(el, 'head')) { can.appendChild(document.body, frag); } else if (el.nodeName.toLowerCase() === 'script') { insertAfter(el, frag); } else { insertAfter(el, frag); el.parentNode.removeChild(el); } } function setupScope(el) { var scope = can.viewModel(el); can.each(el.attributes || [], function (attr) { setAttr(el, attr.name, scope); }); can.bind.call(el, 'attributes', function (ev) { setAttr(el, ev.attributeName, scope); }); return scope; } function autoload() { var promises = []; can.each(can.$('[can-autorender]'), function (el, i) { el.style.display = 'none'; var text = el.innerHTML || el.text, typeAttr = el.getAttribute('type'), typeInfo = typeAttr.match(typeMatch), type = typeInfo && typeInfo[1], typeModule = 'can/view/' + type; if (window.System || !(window.define && window.define.amd)) { typeModule += '/' + type; } promises.push(can['import'](typeModule).then(function (engine) { engine = can[type] || engine; if (engine.async) { return engine.async(text).then(function (renderer) { render(renderer, setupScope(el), el); }); } else { var renderer = engine(text); render(renderer, setupScope(el), el); } })); }); can.when.apply(can, promises).then(can.proxy(deferred.resolve, deferred), can.proxy(deferred.reject, deferred)); } if (document.readyState === 'complete') { autoload(); } else { can.bind.call(window, 'load', autoload); } var promise = deferred.promise(); can.autorender = function (success, error) { return promise.then(success, error); }; return can.autorender; });