"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); const qs = require("querystring"); const loaderUtils = require("loader-utils"); const formatError_1 = require("./formatError"); const descriptorCache_1 = require("./descriptorCache"); const resolveScript_1 = require("./resolveScript"); const util_1 = require("./util"); const compiler_1 = require("./compiler"); // Loader that compiles raw template into JavaScript functions. // This is injected by the global pitcher (../pitch) for template // selection requests initiated from vue files. const TemplateLoader = function (source, inMap) { var _a; source = String(source); const loaderContext = this; // although this is not the main vue-loader, we can get access to the same // vue-loader options because we've set an ident in the plugin and used that // ident to create the request for this loader in the pitcher. const options = (loaderUtils.getOptions(loaderContext) || {}); const isServer = (_a = options.isServerBuild) !== null && _a !== void 0 ? _a : loaderContext.target === 'node'; const isProd = loaderContext.mode === 'production' || process.env.NODE_ENV === 'production'; const query = qs.parse(loaderContext.resourceQuery.slice(1)); const scopeId = query.id; const descriptor = (0, descriptorCache_1.getDescriptor)(loaderContext.resourcePath); const script = (0, resolveScript_1.resolveScript)(descriptor, query.id, options, loaderContext); let templateCompiler; if (typeof options.compiler === 'string') { templateCompiler = require(options.compiler); } else { templateCompiler = options.compiler; } const compiled = compiler_1.compiler.compileTemplate({ source, filename: loaderContext.resourcePath, inMap, id: scopeId, scoped: !!query.scoped, slotted: descriptor.slotted, isProd, ssr: isServer, ssrCssVars: descriptor.cssVars, compiler: templateCompiler, compilerOptions: Object.assign(Object.assign(Object.assign({}, options.compilerOptions), { scopeId: query.scoped ? `data-v-${scopeId}` : undefined, bindingMetadata: script ? script.bindings : undefined }), (0, util_1.resolveTemplateTSOptions)(descriptor, options)), transformAssetUrls: options.transformAssetUrls || true, }); // tips if (compiled.tips.length) { compiled.tips.forEach((tip) => { loaderContext.emitWarning(tip); }); } // errors if (compiled.errors && compiled.errors.length) { compiled.errors.forEach((err) => { if (typeof err === 'string') { loaderContext.emitError(err); } else { (0, formatError_1.formatError)(err, inMap ? inMap.sourcesContent[0] : source, loaderContext.resourcePath); loaderContext.emitError(err); } }); } const { code, map } = compiled; loaderContext.callback(null, code, map); }; exports.default = TemplateLoader;