UNPKG

@farris/build-angular

Version:

Angular Webpack Build Facade

142 lines 18.5 kB
"use strict"; // tslint:disable // TODO: cleanup this file, it's copied as is from Angular CLI. var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) { return new (P || (P = Promise))(function (resolve, reject) { function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } } function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } } function step(result) { result.done ? resolve(result.value) : new P(function (resolve) { resolve(result.value); }).then(fulfilled, rejected); } step((generator = generator.apply(thisArg, _arguments || [])).next()); }); }; Object.defineProperty(exports, "__esModule", { value: true }); /** * @license * Copyright Google Inc. All Rights Reserved. * * Use of this source code is governed by an MIT-style license that can be * found in the LICENSE file at https://angular.io/license */ const loader_utils_1 = require("loader-utils"); const postcss = require("postcss"); const url = require("url"); function wrapUrl(url) { let wrappedUrl; const hasSingleQuotes = url.indexOf('\'') >= 0; if (hasSingleQuotes) { wrappedUrl = `"${url}"`; } else { wrappedUrl = `'${url}'`; } return `url(${wrappedUrl})`; } function resolve(file, base, resolver) { return __awaiter(this, void 0, void 0, function* () { try { return yield resolver('./' + file, base); } catch (err) { return resolver(file, base); } }); } exports.default = postcss.plugin('postcss-cli-resources', (options) => { const { deployUrl, filename, loader } = options; const process = (inputUrl, resourceCache) => __awaiter(this, void 0, void 0, function* () { // If root-relative or absolute, leave as is if (inputUrl.match(/^(?:\w+:\/\/|data:|chrome:|#|\/)/)) { return inputUrl; } // If starts with a caret, remove and return remainder // this supports bypassing asset processing if (inputUrl.startsWith('^')) { return inputUrl.substr(1); } const cachedUrl = resourceCache.get(inputUrl); if (cachedUrl) { return cachedUrl; } const { pathname, hash, search } = url.parse(inputUrl.replace(/\\/g, '/')); const resolver = (file, base) => new Promise((resolve, reject) => { loader.resolve(base, file, (err, result) => { if (err) { reject(err); return; } resolve(result); }); }); const result = yield resolve(pathname, loader.context, resolver); return new Promise((resolve, reject) => { loader.fs.readFile(result, (err, content) => { if (err) { reject(err); return; } const outputPath = loader_utils_1.interpolateName({ resourcePath: result }, filename, { content }); loader.addDependency(result); loader.emitFile(outputPath, content, undefined); let outputUrl = outputPath.replace(/\\/g, '/'); if (hash || search) { outputUrl = url.format({ pathname: outputUrl, hash, search }); } if (deployUrl) { outputUrl = url.resolve(deployUrl, outputUrl); } resourceCache.set(inputUrl, outputUrl); resolve(outputUrl); }); }); }); return (root) => { const urlDeclarations = []; root.walkDecls(decl => { if (decl.value && decl.value.includes('url')) { urlDeclarations.push(decl); } }); if (urlDeclarations.length === 0) { return; } const resourceCache = new Map(); return Promise.all(urlDeclarations.map((decl) => __awaiter(this, void 0, void 0, function* () { const value = decl.value; const urlRegex = /url\(\s*(?:"([^"]+)"|'([^']+)'|(.+?))\s*\)/g; const segments = []; let match; let lastIndex = 0; let modified = false; // tslint:disable-next-line:no-conditional-assignment while (match = urlRegex.exec(value)) { const originalUrl = match[1] || match[2] || match[3]; let processedUrl; try { processedUrl = yield process(originalUrl, resourceCache); } catch (err) { loader.emitError(decl.error(err.message, { word: originalUrl }).toString()); continue; } if (lastIndex < match.index) { segments.push(value.slice(lastIndex, match.index)); } if (!processedUrl || originalUrl === processedUrl) { segments.push(match[0]); } else { segments.push(wrapUrl(processedUrl)); modified = true; } lastIndex = match.index + match[0].length; } if (lastIndex < value.length) { segments.push(value.slice(lastIndex)); } if (modified) { decl.value = segments.join(''); } }))); }; }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"postcss-cli-resources.js","sourceRoot":"./","sources":["packages/farris_devkit/build_angular/src/angular-cli-files/plugins/postcss-cli-resources.ts"],"names":[],"mappings":"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","sourcesContent":["// tslint:disable\n// TODO: cleanup this file, it's copied as is from Angular CLI.\n\n\n/**\n * @license\n * Copyright Google Inc. All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\nimport { interpolateName } from 'loader-utils';\nimport * as postcss from 'postcss';\nimport * as url from 'url';\nimport * as webpack from 'webpack';\n\nfunction wrapUrl(url: string): string {\n  let wrappedUrl;\n  const hasSingleQuotes = url.indexOf('\\'') >= 0;\n\n  if (hasSingleQuotes) {\n    wrappedUrl = `\"${url}\"`;\n  } else {\n    wrappedUrl = `'${url}'`;\n  }\n\n  return `url(${wrappedUrl})`;\n}\n\nexport interface PostcssCliResourcesOptions {\n  deployUrl?: string;\n  filename: string;\n  loader: webpack.loader.LoaderContext;\n}\n\nasync function resolve(\n  file: string,\n  base: string,\n  resolver: (file: string, base: string) => Promise<string>\n): Promise<string> {\n  try {\n    return await resolver('./' + file, base);\n  } catch (err) {\n    return resolver(file, base);\n  }\n}\n\nexport default postcss.plugin('postcss-cli-resources', (options: PostcssCliResourcesOptions) => {\n  const { deployUrl, filename, loader } = options;\n\n  const process = async (inputUrl: string, resourceCache: Map<string, string>) => {\n    // If root-relative or absolute, leave as is\n    if (inputUrl.match(/^(?:\\w+:\\/\\/|data:|chrome:|#|\\/)/)) {\n      return inputUrl;\n    }\n    // If starts with a caret, remove and return remainder\n    // this supports bypassing asset processing\n    if (inputUrl.startsWith('^')) {\n      return inputUrl.substr(1);\n    }\n\n    const cachedUrl = resourceCache.get(inputUrl);\n    if (cachedUrl) {\n      return cachedUrl;\n    }\n\n    const { pathname, hash, search } = url.parse(inputUrl.replace(/\\\\/g, '/'));\n    const resolver = (file: string, base: string) => new Promise<string>((resolve, reject) => {\n      loader.resolve(base, file, (err, result) => {\n        if (err) {\n          reject(err);\n          return;\n        }\n        resolve(result);\n      });\n    });\n\n    const result = await resolve(pathname as string, loader.context, resolver);\n\n    return new Promise<string>((resolve, reject) => {\n      loader.fs.readFile(result, (err: Error, content: Buffer) => {\n        if (err) {\n          reject(err);\n          return;\n        }\n\n        const outputPath = interpolateName(\n          { resourcePath: result } as webpack.loader.LoaderContext,\n          filename,\n          { content },\n        );\n\n        loader.addDependency(result);\n        loader.emitFile(outputPath, content, undefined);\n\n        let outputUrl = outputPath.replace(/\\\\/g, '/');\n        if (hash || search) {\n          outputUrl = url.format({ pathname: outputUrl, hash, search });\n        }\n\n        if (deployUrl) {\n          outputUrl = url.resolve(deployUrl, outputUrl);\n        }\n\n        resourceCache.set(inputUrl, outputUrl);\n\n        resolve(outputUrl);\n      });\n    });\n  };\n\n  return (root) => {\n    const urlDeclarations: Array<postcss.Declaration> = [];\n    root.walkDecls(decl => {\n      if (decl.value && decl.value.includes('url')) {\n        urlDeclarations.push(decl);\n      }\n    });\n\n    if (urlDeclarations.length === 0) {\n      return;\n    }\n\n    const resourceCache = new Map<string, string>();\n\n    return Promise.all(urlDeclarations.map(async decl => {\n      const value = decl.value;\n      const urlRegex = /url\\(\\s*(?:\"([^\"]+)\"|'([^']+)'|(.+?))\\s*\\)/g;\n      const segments: string[] = [];\n\n      let match;\n      let lastIndex = 0;\n      let modified = false;\n      // tslint:disable-next-line:no-conditional-assignment\n      while (match = urlRegex.exec(value)) {\n        const originalUrl = match[1] || match[2] || match[3];\n        let processedUrl;\n        try {\n          processedUrl = await process(originalUrl, resourceCache);\n        } catch (err) {\n          loader.emitError(decl.error(err.message, { word: originalUrl }).toString());\n          continue;\n        }\n\n        if (lastIndex < match.index) {\n          segments.push(value.slice(lastIndex, match.index));\n        }\n\n        if (!processedUrl || originalUrl === processedUrl) {\n          segments.push(match[0]);\n        } else {\n          segments.push(wrapUrl(processedUrl));\n          modified = true;\n        }\n\n        lastIndex = match.index + match[0].length;\n      }\n\n      if (lastIndex < value.length) {\n        segments.push(value.slice(lastIndex));\n      }\n\n      if (modified) {\n        decl.value = segments.join('');\n      }\n    }));\n  };\n});\n"]}