1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677 |
- 'use strict';
- Object.defineProperty(exports, '__esModule', { value: true });
- var compilerDom = require('@vue/compiler-dom');
- var runtimeDom = require('@vue/runtime-dom');
- var shared = require('@vue/shared');
- function _interopNamespace(e) {
- if (e && e.__esModule) return e;
- var n = Object.create(null);
- if (e) {
- Object.keys(e).forEach(function (k) {
- n[k] = e[k];
- });
- }
- n['default'] = e;
- return Object.freeze(n);
- }
- var runtimeDom__namespace = /*#__PURE__*/_interopNamespace(runtimeDom);
- // This entry is the "full-build" that includes both the runtime
- const compileCache = Object.create(null);
- function compileToFunction(template, options) {
- if (!shared.isString(template)) {
- if (template.nodeType) {
- template = template.innerHTML;
- }
- else {
- runtimeDom.warn(`invalid template option: `, template);
- return shared.NOOP;
- }
- }
- const key = template;
- const cached = compileCache[key];
- if (cached) {
- return cached;
- }
- if (template[0] === '#') {
- const el = document.querySelector(template);
- if (!el) {
- runtimeDom.warn(`Template element not found or is empty: ${template}`);
- }
- // __UNSAFE__
- // Reason: potential execution of JS expressions in in-DOM template.
- // The user must make sure the in-DOM template is trusted. If it's rendered
- // by the server, the template should not contain any user data.
- template = el ? el.innerHTML : ``;
- }
- const { code } = compilerDom.compile(template, shared.extend({
- hoistStatic: true,
- onError: onError ,
- onWarn: e => onError(e, true)
- }, options));
- function onError(err, asWarning = false) {
- const message = asWarning
- ? err.message
- : `Template compilation error: ${err.message}`;
- const codeFrame = err.loc &&
- shared.generateCodeFrame(template, err.loc.start.offset, err.loc.end.offset);
- runtimeDom.warn(codeFrame ? `${message}\n${codeFrame}` : message);
- }
- // The wildcard import results in a huge object with every export
- // with keys that cannot be mangled, and can be quite heavy size-wise.
- // In the global build we know `Vue` is available globally so we can avoid
- // the wildcard object.
- const render = (new Function('Vue', code)(runtimeDom__namespace));
- render._rc = true;
- return (compileCache[key] = render);
- }
- runtimeDom.registerRuntimeCompiler(compileToFunction);
- Object.keys(runtimeDom).forEach(function (k) {
- if (k !== 'default') exports[k] = runtimeDom[k];
- });
- exports.compile = compileToFunction;
|