12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455 |
- /* This loader renders the template with underscore if no other loader was found */
- // @ts-nocheck
- "use strict";
- const _template = require("lodash/template");
- module.exports = function (source) {
- // Get templating options
- const options = this.getOptions();
- const force = options.force || false;
- const allLoadersButThisOne = this.loaders.filter(
- (loader) => loader.normal !== module.exports,
- );
- // This loader shouldn't kick in if there is any other loader (unless it's explicitly enforced)
- if (allLoadersButThisOne.length > 0 && !force) {
- return source;
- }
- // Allow only one html-webpack-plugin loader to allow loader options in the webpack config
- const htmlWebpackPluginLoaders = this.loaders.filter(
- (loader) => loader.normal === module.exports,
- );
- const lastHtmlWebpackPluginLoader =
- htmlWebpackPluginLoaders[htmlWebpackPluginLoaders.length - 1];
- if (this.loaders[this.loaderIndex] !== lastHtmlWebpackPluginLoader) {
- return source;
- }
- // Skip .js files (unless it's explicitly enforced)
- if (/\.(c|m)?js$/.test(this.resourcePath) && !force) {
- return source;
- }
- // The following part renders the template with lodash as a minimalistic loader
- //
- const template = _template(source, {
- interpolate: /<%=([\s\S]+?)%>/g,
- variable: "data",
- ...options,
- });
- // Use `eval("require")("lodash")` to enforce using the native nodejs require
- // during template execution
- return (
- 'var _ = eval("require")(' +
- JSON.stringify(require.resolve("lodash")) +
- ");" +
- "module.exports = function (templateParams) { with(templateParams) {" +
- // Execute the lodash template
- "return (" +
- template.source +
- ")();" +
- "}}"
- );
- };
|