| /* This loader renders the template with underscore if no other loader was found */ |
| 'use strict'; |
| |
| const _ = require('lodash'); |
| const loaderUtils = require('loader-utils'); |
| |
| module.exports = function (source) { |
| if (this.cacheable) { |
| this.cacheable(); |
| } |
| const allLoadersButThisOne = this.loaders.filter(function (loader) { |
| // Loader API changed from `loader.module` to `loader.normal` in Webpack 2. |
| return (loader.module || loader.normal) !== module.exports; |
| }); |
| // This loader shouldn't kick in if there is any other loader |
| if (allLoadersButThisOne.length > 0) { |
| return source; |
| } |
| // Skip .js files |
| if (/\.js$/.test(this.resourcePath)) { |
| return source; |
| } |
| |
| // The following part renders the tempalte with lodash as aminimalistic loader |
| // |
| // Get templating options |
| const options = this.query !== '' ? loaderUtils.parseQuery(this.query) : {}; |
| const template = _.template(source, _.defaults(options, { variable: 'data' })); |
| // Require !!lodash - using !! will disable all loaders (e.g. babel) |
| return 'var _ = require(' + loaderUtils.stringifyRequest(this, '!!' + require.resolve('lodash')) + ');' + |
| 'module.exports = function (templateParams) { with(templateParams) {' + |
| // Execute the lodash template |
| 'return (' + template.source + ')();' + |
| '}}'; |
| }; |