UNPKG

next

Version:

The React Framework

109 lines (108 loc) 3.94 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports.default = loader; var _warning = _interopRequireDefault(require("./Warning")); var _error = _interopRequireDefault(require("./Error")); var _utils = require("./utils"); var _loaderUtils = require("next/dist/compiled/loader-utils"); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } async function loader(content, sourceMap, meta) { const loaderSpan = this.currentTraceSpan.traceChild('postcss-loader'); const callback = this.async(); loaderSpan.traceAsyncFn(async ()=>{ const options = (0, _loaderUtils).getOptions(this); const file = this.resourcePath; const useSourceMap = typeof options.sourceMap !== 'undefined' ? options.sourceMap : this.sourceMap; const processOptions = { from: file, to: file }; if (useSourceMap) { processOptions.map = { inline: false, annotation: false, ...processOptions.map }; } if (sourceMap && processOptions.map) { processOptions.map.prev = loaderSpan.traceChild('normalize-source-map').traceFn(()=>(0, _utils).normalizeSourceMap(sourceMap, this.context) ); } let root; // Reuse PostCSS AST from other loaders if (meta && meta.ast && meta.ast.type === 'postcss') { ({ root } = meta.ast); loaderSpan.setAttribute('astUsed', 'true'); } let result; try { result = await loaderSpan.traceChild('postcss-process').traceAsyncFn(()=>options.postcss.process(root || content, processOptions) ); } catch (error) { if (error.file) { this.addDependency(error.file); } if (error.name === 'CssSyntaxError') { throw new _error.default(error); } throw error; } for (const warning of result.warnings()){ this.emitWarning(new _warning.default(warning)); } for (const message of result.messages){ // eslint-disable-next-line default-case switch(message.type){ case 'dependency': this.addDependency(message.file); break; case 'build-dependency': this.addBuildDependency(message.file); break; case 'missing-dependency': this.addMissingDependency(message.file); break; case 'context-dependency': this.addContextDependency(message.file); break; case 'dir-dependency': this.addContextDependency(message.dir); break; case 'asset': if (message.content && message.file) { this.emitFile(message.file, message.content, message.sourceMap, message.info); } } } // eslint-disable-next-line no-undefined let map = result.map ? result.map.toJSON() : undefined; if (map && useSourceMap) { map = (0, _utils).normalizeSourceMapAfterPostcss(map, this.context); } const ast = { type: 'postcss', version: result.processor.version, root: result.root }; return [ result.css, map, { ast } ]; }).then(([css, map, { ast }])=>{ callback === null || callback === void 0 ? void 0 : callback(null, css, map, { ast }); }, (err)=>{ callback === null || callback === void 0 ? void 0 : callback(err); }); } //# sourceMappingURL=index.js.map