@angular/pwa
Advanced tools
+8
-7
| { | ||
| "name": "@angular/pwa", | ||
| "version": "0.8.1", | ||
| "version": "0.9.0-beta.0", | ||
| "description": "PWA schematics for Angular", | ||
@@ -17,6 +17,7 @@ "keywords": [ | ||
| "dependencies": { | ||
| "@angular-devkit/core": "0.8.1", | ||
| "@angular-devkit/schematics": "0.8.1", | ||
| "@schematics/angular": "0.8.1", | ||
| "typescript": "~2.6.2" | ||
| "@angular-devkit/core": "0.9.0-beta.0", | ||
| "@angular-devkit/schematics": "0.9.0-beta.0", | ||
| "@schematics/angular": "0.9.0-beta.0", | ||
| "parse5-html-rewriting-stream": "^5.1.0", | ||
| "rxjs": "^6.0.0" | ||
| }, | ||
@@ -28,4 +29,4 @@ "repository": { | ||
| "engines": { | ||
| "node": ">= 8.9.0", | ||
| "npm": ">= 5.5.1" | ||
| "node": ">=10.3.0 <11.0.0", | ||
| "yarn": ">=1.6.0 <2.0.0" | ||
| }, | ||
@@ -32,0 +33,0 @@ "author": "Angular Authors", |
+123
-88
@@ -12,35 +12,20 @@ "use strict"; | ||
| const schematics_1 = require("@angular-devkit/schematics"); | ||
| const config_1 = require("../utility/config"); | ||
| function addServiceWorker(options) { | ||
| return (host, context) => { | ||
| context.logger.debug('Adding service worker...'); | ||
| const swOptions = Object.assign({}, options); | ||
| delete swOptions.title; | ||
| return schematics_1.externalSchematic('@schematics/angular', 'service-worker', swOptions); | ||
| const rxjs_1 = require("rxjs"); | ||
| const stream_1 = require("stream"); | ||
| const RewritingStream = require('parse5-html-rewriting-stream'); | ||
| function getWorkspace(host) { | ||
| const possibleFiles = ['/angular.json', '/.angular.json']; | ||
| const path = possibleFiles.filter(path => host.exists(path))[0]; | ||
| const configBuffer = host.read(path); | ||
| if (configBuffer === null) { | ||
| throw new schematics_1.SchematicsException(`Could not find (${path})`); | ||
| } | ||
| const content = configBuffer.toString(); | ||
| return { | ||
| path, | ||
| workspace: core_1.parseJson(content, core_1.JsonParseMode.Loose), | ||
| }; | ||
| } | ||
| function getIndent(text) { | ||
| let indent = ''; | ||
| for (const char of text) { | ||
| if (char === ' ' || char === '\t') { | ||
| indent += char; | ||
| } | ||
| else { | ||
| break; | ||
| } | ||
| } | ||
| return indent; | ||
| } | ||
| function updateIndexFile(options) { | ||
| return (host, context) => { | ||
| const workspace = config_1.getWorkspace(host); | ||
| const project = workspace.projects[options.project]; | ||
| let path; | ||
| const projectTargets = project.targets || project.architect; | ||
| if (project && projectTargets && projectTargets.build && projectTargets.build.options.index) { | ||
| path = projectTargets.build.options.index; | ||
| } | ||
| else { | ||
| throw new schematics_1.SchematicsException('Could not find index file for the project'); | ||
| } | ||
| function updateIndexFile(path) { | ||
| return (host) => { | ||
| const buffer = host.read(path); | ||
@@ -50,54 +35,44 @@ if (buffer === null) { | ||
| } | ||
| const content = buffer.toString(); | ||
| const lines = content.split('\n'); | ||
| let closingHeadTagLineIndex = -1; | ||
| let closingBodyTagLineIndex = -1; | ||
| lines.forEach((line, index) => { | ||
| if (closingHeadTagLineIndex === -1 && /<\/head>/.test(line)) { | ||
| closingHeadTagLineIndex = index; | ||
| const rewriter = new RewritingStream(); | ||
| let needsNoScript = true; | ||
| rewriter.on('startTag', (startTag) => { | ||
| if (startTag.tagName === 'noscript') { | ||
| needsNoScript = false; | ||
| } | ||
| else if (closingBodyTagLineIndex === -1 && /<\/body>/.test(line)) { | ||
| closingBodyTagLineIndex = index; | ||
| rewriter.emitStartTag(startTag); | ||
| }); | ||
| rewriter.on('endTag', (endTag) => { | ||
| if (endTag.tagName === 'head') { | ||
| rewriter.emitRaw(' <link rel="manifest" href="manifest.json">\n'); | ||
| rewriter.emitRaw(' <meta name="theme-color" content="#1976d2">\n'); | ||
| } | ||
| else if (endTag.tagName === 'body' && needsNoScript) { | ||
| rewriter.emitRaw(' <noscript>Please enable JavaScript to continue using this application.</noscript>\n'); | ||
| } | ||
| rewriter.emitEndTag(endTag); | ||
| }); | ||
| const headIndent = getIndent(lines[closingHeadTagLineIndex]) + ' '; | ||
| const itemsToAddToHead = [ | ||
| '<link rel="manifest" href="manifest.json">', | ||
| '<meta name="theme-color" content="#1976d2">', | ||
| ]; | ||
| const bodyIndent = getIndent(lines[closingBodyTagLineIndex]) + ' '; | ||
| const itemsToAddToBody = [ | ||
| '<noscript>Please enable JavaScript to continue using this application.</noscript>', | ||
| ]; | ||
| const updatedIndex = [ | ||
| ...lines.slice(0, closingHeadTagLineIndex), | ||
| ...itemsToAddToHead.map(line => headIndent + line), | ||
| ...lines.slice(closingHeadTagLineIndex, closingBodyTagLineIndex), | ||
| ...itemsToAddToBody.map(line => bodyIndent + line), | ||
| ...lines.slice(closingBodyTagLineIndex), | ||
| ].join('\n'); | ||
| host.overwrite(path, updatedIndex); | ||
| return host; | ||
| }; | ||
| } | ||
| function addManifestToAssetsConfig(options) { | ||
| return (host, context) => { | ||
| const workspacePath = config_1.getWorkspacePath(host); | ||
| const workspace = config_1.getWorkspace(host); | ||
| const project = workspace.projects[options.project]; | ||
| if (!project) { | ||
| throw new Error(`Project is not defined in this workspace.`); | ||
| } | ||
| const assetEntry = core_1.join(core_1.normalize(project.root), 'src', 'manifest.json'); | ||
| const projectTargets = project.targets || project.architect; | ||
| if (!projectTargets) { | ||
| throw new Error(`Targets are not defined for this project.`); | ||
| } | ||
| ['build', 'test'].forEach((target) => { | ||
| const applyTo = projectTargets[target].options; | ||
| const assets = applyTo.assets || (applyTo.assets = []); | ||
| assets.push(assetEntry); | ||
| return new rxjs_1.Observable(obs => { | ||
| const input = new stream_1.Readable({ | ||
| encoding: 'utf8', | ||
| read() { | ||
| this.push(buffer); | ||
| this.push(null); | ||
| }, | ||
| }); | ||
| const chunks = []; | ||
| const output = new stream_1.Writable({ | ||
| write(chunk, encoding, callback) { | ||
| chunks.push(typeof chunk === 'string' ? Buffer.from(chunk, encoding) : chunk); | ||
| callback(); | ||
| }, | ||
| final(callback) { | ||
| const full = Buffer.concat(chunks); | ||
| host.overwrite(path, full.toString()); | ||
| callback(); | ||
| obs.next(host); | ||
| obs.complete(); | ||
| }, | ||
| }); | ||
| input.pipe(rewriter).pipe(output); | ||
| }); | ||
| host.overwrite(workspacePath, JSON.stringify(workspace, null, 2)); | ||
| return host; | ||
| }; | ||
@@ -107,3 +82,6 @@ } | ||
| return (host, context) => { | ||
| const workspace = config_1.getWorkspace(host); | ||
| if (!options.title) { | ||
| options.title = options.project; | ||
| } | ||
| const { path: workspacePath, workspace } = getWorkspace(host); | ||
| if (!options.project) { | ||
@@ -113,22 +91,79 @@ throw new schematics_1.SchematicsException('Option "project" is required.'); | ||
| const project = workspace.projects[options.project]; | ||
| if (!project) { | ||
| throw new schematics_1.SchematicsException(`Project is not defined in this workspace.`); | ||
| } | ||
| if (project.projectType !== 'application') { | ||
| throw new schematics_1.SchematicsException(`PWA requires a project type of "application".`); | ||
| } | ||
| const sourcePath = core_1.join(project.root, 'src'); | ||
| // Find all the relevant targets for the project | ||
| const projectTargets = project.targets || project.architect; | ||
| if (!projectTargets || Object.keys(projectTargets).length === 0) { | ||
| throw new schematics_1.SchematicsException(`Targets are not defined for this project.`); | ||
| } | ||
| const buildTargets = []; | ||
| const testTargets = []; | ||
| for (const targetName in projectTargets) { | ||
| const target = projectTargets[targetName]; | ||
| if (!target) { | ||
| continue; | ||
| } | ||
| if (target.builder === '@angular-devkit/build-angular:browser') { | ||
| buildTargets.push(target); | ||
| } | ||
| else if (target.builder === '@angular-devkit/build-angular:karma') { | ||
| testTargets.push(target); | ||
| } | ||
| } | ||
| // Add manifest to asset configuration | ||
| const assetEntry = core_1.join(core_1.normalize(project.root), 'src', 'manifest.json'); | ||
| for (const target of [...buildTargets, ...testTargets]) { | ||
| if (target.options) { | ||
| if (target.options.assets) { | ||
| target.options.assets.push(assetEntry); | ||
| } | ||
| else { | ||
| target.options.assets = [assetEntry]; | ||
| } | ||
| } | ||
| else { | ||
| target.options = { assets: [assetEntry] }; | ||
| } | ||
| } | ||
| host.overwrite(workspacePath, JSON.stringify(workspace, null, 2)); | ||
| // Find all index.html files in build targets | ||
| const indexFiles = new Set(); | ||
| for (const target of buildTargets) { | ||
| if (target.options && target.options.index) { | ||
| indexFiles.add(target.options.index); | ||
| } | ||
| if (!target.configurations) { | ||
| continue; | ||
| } | ||
| for (const configName in target.configurations) { | ||
| const configuration = target.configurations[configName]; | ||
| if (configuration && configuration.index) { | ||
| indexFiles.add(configuration.index); | ||
| } | ||
| } | ||
| } | ||
| // Setup sources for the assets files to add to the project | ||
| const sourcePath = core_1.join(core_1.normalize(project.root), 'src'); | ||
| const assetsPath = core_1.join(sourcePath, 'assets'); | ||
| options.title = options.title || options.project; | ||
| const rootTemplateSource = schematics_1.apply(schematics_1.url('./files/root'), [ | ||
| schematics_1.template(Object.assign({}, options)), | ||
| schematics_1.move(sourcePath), | ||
| schematics_1.move(core_1.getSystemPath(sourcePath)), | ||
| ]); | ||
| const assetsTemplateSource = schematics_1.apply(schematics_1.url('./files/assets'), [ | ||
| schematics_1.template(Object.assign({}, options)), | ||
| schematics_1.move(assetsPath), | ||
| schematics_1.move(core_1.getSystemPath(assetsPath)), | ||
| ]); | ||
| // Setup service worker schematic options | ||
| const swOptions = Object.assign({}, options); | ||
| delete swOptions.title; | ||
| // Chain the rules and return | ||
| return schematics_1.chain([ | ||
| addServiceWorker(options), | ||
| schematics_1.externalSchematic('@schematics/angular', 'service-worker', swOptions), | ||
| schematics_1.mergeWith(rootTemplateSource), | ||
| schematics_1.mergeWith(assetsTemplateSource), | ||
| updateIndexFile(options), | ||
| addManifestToAssetsConfig(options), | ||
| ...[...indexFiles].map(path => updateIndexFile(path)), | ||
| ])(host, context); | ||
@@ -138,2 +173,2 @@ }; | ||
| exports.default = default_1; | ||
| //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"./","sources":["packages/angular/pwa/pwa/index.ts"],"names":[],"mappings":"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","sourcesContent":["/**\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 { Path, join, normalize } from '@angular-devkit/core';\nimport {\n  Rule,\n  SchematicContext,\n  SchematicsException,\n  Tree,\n  apply,\n  chain,\n  externalSchematic,\n  mergeWith,\n  move,\n  template,\n  url,\n} from '@angular-devkit/schematics';\nimport { getWorkspace, getWorkspacePath } from '../utility/config';\nimport { Schema as PwaOptions } from './schema';\n\n\nfunction addServiceWorker(options: PwaOptions): Rule {\n  return (host: Tree, context: SchematicContext) => {\n    context.logger.debug('Adding service worker...');\n\n    const swOptions = {\n      ...options,\n    };\n    delete swOptions.title;\n\n    return externalSchematic('@schematics/angular', 'service-worker', swOptions);\n  };\n}\n\nfunction getIndent(text: string): string {\n  let indent = '';\n\n  for (const char of text) {\n    if (char === ' ' || char === '\\t') {\n      indent += char;\n    } else {\n      break;\n    }\n  }\n\n  return indent;\n}\n\nfunction updateIndexFile(options: PwaOptions): Rule {\n  return (host: Tree, context: SchematicContext) => {\n    const workspace = getWorkspace(host);\n    const project = workspace.projects[options.project as string];\n    let path: string;\n    const projectTargets = project.targets || project.architect;\n    if (project && projectTargets && projectTargets.build && projectTargets.build.options.index) {\n      path = projectTargets.build.options.index;\n    } else {\n      throw new SchematicsException('Could not find index file for the project');\n    }\n    const buffer = host.read(path);\n    if (buffer === null) {\n      throw new SchematicsException(`Could not read index file: ${path}`);\n    }\n    const content = buffer.toString();\n    const lines = content.split('\\n');\n    let closingHeadTagLineIndex = -1;\n    let closingBodyTagLineIndex = -1;\n    lines.forEach((line, index) => {\n      if (closingHeadTagLineIndex === -1 && /<\\/head>/.test(line)) {\n        closingHeadTagLineIndex = index;\n      } else if (closingBodyTagLineIndex === -1 && /<\\/body>/.test(line)) {\n        closingBodyTagLineIndex = index;\n      }\n    });\n\n    const headIndent = getIndent(lines[closingHeadTagLineIndex]) + '  ';\n    const itemsToAddToHead = [\n      '<link rel=\"manifest\" href=\"manifest.json\">',\n      '<meta name=\"theme-color\" content=\"#1976d2\">',\n    ];\n\n    const bodyIndent = getIndent(lines[closingBodyTagLineIndex]) + '  ';\n    const itemsToAddToBody = [\n      '<noscript>Please enable JavaScript to continue using this application.</noscript>',\n    ];\n\n    const updatedIndex = [\n      ...lines.slice(0, closingHeadTagLineIndex),\n      ...itemsToAddToHead.map(line => headIndent + line),\n      ...lines.slice(closingHeadTagLineIndex, closingBodyTagLineIndex),\n      ...itemsToAddToBody.map(line => bodyIndent + line),\n      ...lines.slice(closingBodyTagLineIndex),\n    ].join('\\n');\n\n    host.overwrite(path, updatedIndex);\n\n    return host;\n  };\n}\n\nfunction addManifestToAssetsConfig(options: PwaOptions) {\n  return (host: Tree, context: SchematicContext) => {\n\n    const workspacePath = getWorkspacePath(host);\n    const workspace = getWorkspace(host);\n    const project = workspace.projects[options.project as string];\n\n    if (!project) {\n      throw new Error(`Project is not defined in this workspace.`);\n    }\n\n    const assetEntry = join(normalize(project.root), 'src', 'manifest.json');\n\n    const projectTargets = project.targets || project.architect;\n    if (!projectTargets) {\n      throw new Error(`Targets are not defined for this project.`);\n    }\n\n    ['build', 'test'].forEach((target) => {\n\n      const applyTo = projectTargets[target].options;\n      const assets = applyTo.assets || (applyTo.assets = []);\n\n      assets.push(assetEntry);\n\n    });\n\n    host.overwrite(workspacePath, JSON.stringify(workspace, null, 2));\n\n    return host;\n  };\n}\n\nexport default function (options: PwaOptions): Rule {\n  return (host: Tree, context: SchematicContext) => {\n    const workspace = getWorkspace(host);\n    if (!options.project) {\n      throw new SchematicsException('Option \"project\" is required.');\n    }\n    const project = workspace.projects[options.project];\n    if (project.projectType !== 'application') {\n      throw new SchematicsException(`PWA requires a project type of \"application\".`);\n    }\n\n    const sourcePath = join(project.root as Path, 'src');\n    const assetsPath = join(sourcePath, 'assets');\n\n    options.title = options.title || options.project;\n\n    const rootTemplateSource = apply(url('./files/root'), [\n      template({ ...options }),\n      move(sourcePath),\n    ]);\n    const assetsTemplateSource = apply(url('./files/assets'), [\n      template({ ...options }),\n      move(assetsPath),\n    ]);\n\n    return chain([\n      addServiceWorker(options),\n      mergeWith(rootTemplateSource),\n      mergeWith(assetsTemplateSource),\n      updateIndexFile(options),\n      addManifestToAssetsConfig(options),\n    ])(host, context);\n  };\n}\n"]} | ||
| //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"./","sources":["packages/angular/pwa/pwa/index.ts"],"names":[],"mappings":"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","sourcesContent":["/**\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 {\n  JsonParseMode,\n  experimental,\n  getSystemPath,\n  join,\n  normalize,\n  parseJson,\n} from '@angular-devkit/core';\nimport {\n  Rule,\n  SchematicContext,\n  SchematicsException,\n  Tree,\n  apply,\n  chain,\n  externalSchematic,\n  mergeWith,\n  move,\n  template,\n  url,\n} from '@angular-devkit/schematics';\nimport { Observable } from 'rxjs';\nimport { Readable, Writable } from 'stream';\nimport { Schema as PwaOptions } from './schema';\n\nconst RewritingStream = require('parse5-html-rewriting-stream');\n\n\nfunction getWorkspace(\n  host: Tree,\n): { path: string, workspace: experimental.workspace.WorkspaceSchema } {\n  const possibleFiles = [ '/angular.json', '/.angular.json' ];\n  const path = possibleFiles.filter(path => host.exists(path))[0];\n\n  const configBuffer = host.read(path);\n  if (configBuffer === null) {\n    throw new SchematicsException(`Could not find (${path})`);\n  }\n  const content = configBuffer.toString();\n\n  return {\n    path,\n    workspace: parseJson(\n      content,\n      JsonParseMode.Loose,\n    ) as {} as experimental.workspace.WorkspaceSchema,\n  };\n}\n\nfunction updateIndexFile(path: string): Rule {\n  return (host: Tree) => {\n    const buffer = host.read(path);\n    if (buffer === null) {\n      throw new SchematicsException(`Could not read index file: ${path}`);\n    }\n\n    const rewriter = new RewritingStream();\n\n    let needsNoScript = true;\n    rewriter.on('startTag', (startTag: { tagName: string }) => {\n      if (startTag.tagName === 'noscript') {\n        needsNoScript = false;\n      }\n\n      rewriter.emitStartTag(startTag);\n    });\n\n    rewriter.on('endTag', (endTag: { tagName: string }) => {\n      if (endTag.tagName === 'head') {\n        rewriter.emitRaw('  <link rel=\"manifest\" href=\"manifest.json\">\\n');\n        rewriter.emitRaw('  <meta name=\"theme-color\" content=\"#1976d2\">\\n');\n      } else if (endTag.tagName === 'body' && needsNoScript) {\n        rewriter.emitRaw(\n          '  <noscript>Please enable JavaScript to continue using this application.</noscript>\\n',\n        );\n      }\n\n      rewriter.emitEndTag(endTag);\n    });\n\n    return new Observable<Tree>(obs => {\n      const input = new Readable({\n        encoding: 'utf8',\n        read(): void {\n          this.push(buffer);\n          this.push(null);\n        },\n      });\n\n      const chunks: Array<Buffer> = [];\n      const output = new Writable({\n        write(chunk: string | Buffer, encoding: string, callback: Function): void {\n          chunks.push(typeof chunk === 'string' ? Buffer.from(chunk, encoding) : chunk);\n          callback();\n        },\n        final(callback: (error?: Error) => void): void {\n          const full = Buffer.concat(chunks);\n          host.overwrite(path, full.toString());\n          callback();\n          obs.next(host);\n          obs.complete();\n        },\n      });\n\n      input.pipe(rewriter).pipe(output);\n    });\n  };\n}\n\nexport default function (options: PwaOptions): Rule {\n  return (host: Tree, context: SchematicContext) => {\n    if (!options.title) {\n      options.title = options.project;\n    }\n    const {path: workspacePath, workspace } = getWorkspace(host);\n\n    if (!options.project) {\n      throw new SchematicsException('Option \"project\" is required.');\n    }\n\n    const project = workspace.projects[options.project];\n    if (!project) {\n      throw new SchematicsException(`Project is not defined in this workspace.`);\n    }\n\n    if (project.projectType !== 'application') {\n      throw new SchematicsException(`PWA requires a project type of \"application\".`);\n    }\n\n    // Find all the relevant targets for the project\n    const projectTargets = project.targets || project.architect;\n    if (!projectTargets || Object.keys(projectTargets).length === 0) {\n      throw new SchematicsException(`Targets are not defined for this project.`);\n    }\n\n    const buildTargets = [];\n    const testTargets = [];\n    for (const targetName in projectTargets) {\n      const target = projectTargets[targetName];\n      if (!target) {\n        continue;\n      }\n\n      if (target.builder === '@angular-devkit/build-angular:browser') {\n        buildTargets.push(target);\n      } else if (target.builder === '@angular-devkit/build-angular:karma') {\n        testTargets.push(target);\n      }\n    }\n\n    // Add manifest to asset configuration\n    const assetEntry = join(normalize(project.root), 'src', 'manifest.json');\n    for (const target of [...buildTargets, ...testTargets]) {\n      if (target.options) {\n        if (target.options.assets) {\n          target.options.assets.push(assetEntry);\n        } else {\n          target.options.assets = [ assetEntry ];\n        }\n      } else {\n        target.options = { assets: [ assetEntry ] };\n      }\n    }\n    host.overwrite(workspacePath, JSON.stringify(workspace, null, 2));\n\n    // Find all index.html files in build targets\n    const indexFiles = new Set<string>();\n    for (const target of buildTargets) {\n      if (target.options && target.options.index) {\n        indexFiles.add(target.options.index);\n      }\n\n      if (!target.configurations) {\n        continue;\n      }\n      for (const configName in target.configurations) {\n        const configuration = target.configurations[configName];\n        if (configuration && configuration.index) {\n          indexFiles.add(configuration.index);\n        }\n      }\n    }\n\n    // Setup sources for the assets files to add to the project\n    const sourcePath = join(normalize(project.root), 'src');\n    const assetsPath = join(sourcePath, 'assets');\n    const rootTemplateSource = apply(url('./files/root'), [\n      template({ ...options }),\n      move(getSystemPath(sourcePath)),\n    ]);\n    const assetsTemplateSource = apply(url('./files/assets'), [\n      template({ ...options }),\n      move(getSystemPath(assetsPath)),\n    ]);\n\n    // Setup service worker schematic options\n    const swOptions = { ...options };\n    delete swOptions.title;\n\n    // Chain the rules and return\n    return chain([\n      externalSchematic('@schematics/angular', 'service-worker', swOptions),\n      mergeWith(rootTemplateSource),\n      mergeWith(assetsTemplateSource),\n      ...[...indexFiles].map(path => updateIndexFile(path)),\n    ])(host, context);\n  };\n}\n"]} |
| /** | ||
| * @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 | ||
| */ | ||
| import { experimental } from '@angular-devkit/core'; | ||
| import { Tree } from '@angular-devkit/schematics'; | ||
| export declare type WorkspaceSchema = experimental.workspace.WorkspaceSchema; | ||
| export declare function getWorkspacePath(host: Tree): string; | ||
| export declare function getWorkspace(host: Tree): WorkspaceSchema; |
| "use strict"; | ||
| 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 core_1 = require("@angular-devkit/core"); | ||
| const schematics_1 = require("@angular-devkit/schematics"); | ||
| function getWorkspacePath(host) { | ||
| const possibleFiles = ['/angular.json', '/.angular.json']; | ||
| const path = possibleFiles.filter(path => host.exists(path))[0]; | ||
| return path; | ||
| } | ||
| exports.getWorkspacePath = getWorkspacePath; | ||
| function getWorkspace(host) { | ||
| const path = getWorkspacePath(host); | ||
| const configBuffer = host.read(path); | ||
| if (configBuffer === null) { | ||
| throw new schematics_1.SchematicsException(`Could not find (${path})`); | ||
| } | ||
| const content = configBuffer.toString(); | ||
| return core_1.parseJson(content, core_1.JsonParseMode.Loose); | ||
| } | ||
| exports.getWorkspace = getWorkspace; | ||
| //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29uZmlnLmpzIiwic291cmNlUm9vdCI6Ii4vIiwic291cmNlcyI6WyJwYWNrYWdlcy9hbmd1bGFyL3B3YS91dGlsaXR5L2NvbmZpZy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOztBQUFBOzs7Ozs7R0FNRztBQUNILCtDQUE4RTtBQUM5RSwyREFBdUU7QUFLdkUsMEJBQWlDLElBQVU7SUFDekMsTUFBTSxhQUFhLEdBQUcsQ0FBRSxlQUFlLEVBQUUsZ0JBQWdCLENBQUUsQ0FBQztJQUM1RCxNQUFNLElBQUksR0FBRyxhQUFhLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQyxFQUFFLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDO0lBRWhFLE9BQU8sSUFBSSxDQUFDO0FBQ2QsQ0FBQztBQUxELDRDQUtDO0FBRUQsc0JBQTZCLElBQVU7SUFDckMsTUFBTSxJQUFJLEdBQUcsZ0JBQWdCLENBQUMsSUFBSSxDQUFDLENBQUM7SUFDcEMsTUFBTSxZQUFZLEdBQUcsSUFBSSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsQ0FBQztJQUNyQyxJQUFJLFlBQVksS0FBSyxJQUFJLEVBQUU7UUFDekIsTUFBTSxJQUFJLGdDQUFtQixDQUFDLG1CQUFtQixJQUFJLEdBQUcsQ0FBQyxDQUFDO0tBQzNEO0lBQ0QsTUFBTSxPQUFPLEdBQUcsWUFBWSxDQUFDLFFBQVEsRUFBRSxDQUFDO0lBRXhDLE9BQU8sZ0JBQVMsQ0FBQyxPQUFPLEVBQUUsb0JBQWEsQ0FBQyxLQUFLLENBQTBCLENBQUM7QUFDMUUsQ0FBQztBQVRELG9DQVNDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBAbGljZW5zZVxuICogQ29weXJpZ2h0IEdvb2dsZSBJbmMuIEFsbCBSaWdodHMgUmVzZXJ2ZWQuXG4gKlxuICogVXNlIG9mIHRoaXMgc291cmNlIGNvZGUgaXMgZ292ZXJuZWQgYnkgYW4gTUlULXN0eWxlIGxpY2Vuc2UgdGhhdCBjYW4gYmVcbiAqIGZvdW5kIGluIHRoZSBMSUNFTlNFIGZpbGUgYXQgaHR0cHM6Ly9hbmd1bGFyLmlvL2xpY2Vuc2VcbiAqL1xuaW1wb3J0IHsgSnNvblBhcnNlTW9kZSwgZXhwZXJpbWVudGFsLCBwYXJzZUpzb24gfSBmcm9tICdAYW5ndWxhci1kZXZraXQvY29yZSc7XG5pbXBvcnQgeyBTY2hlbWF0aWNzRXhjZXB0aW9uLCBUcmVlIH0gZnJvbSAnQGFuZ3VsYXItZGV2a2l0L3NjaGVtYXRpY3MnO1xuXG5cbmV4cG9ydCB0eXBlIFdvcmtzcGFjZVNjaGVtYSA9IGV4cGVyaW1lbnRhbC53b3Jrc3BhY2UuV29ya3NwYWNlU2NoZW1hO1xuXG5leHBvcnQgZnVuY3Rpb24gZ2V0V29ya3NwYWNlUGF0aChob3N0OiBUcmVlKTogc3RyaW5nIHtcbiAgY29uc3QgcG9zc2libGVGaWxlcyA9IFsgJy9hbmd1bGFyLmpzb24nLCAnLy5hbmd1bGFyLmpzb24nIF07XG4gIGNvbnN0IHBhdGggPSBwb3NzaWJsZUZpbGVzLmZpbHRlcihwYXRoID0+IGhvc3QuZXhpc3RzKHBhdGgpKVswXTtcblxuICByZXR1cm4gcGF0aDtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGdldFdvcmtzcGFjZShob3N0OiBUcmVlKTogV29ya3NwYWNlU2NoZW1hIHtcbiAgY29uc3QgcGF0aCA9IGdldFdvcmtzcGFjZVBhdGgoaG9zdCk7XG4gIGNvbnN0IGNvbmZpZ0J1ZmZlciA9IGhvc3QucmVhZChwYXRoKTtcbiAgaWYgKGNvbmZpZ0J1ZmZlciA9PT0gbnVsbCkge1xuICAgIHRocm93IG5ldyBTY2hlbWF0aWNzRXhjZXB0aW9uKGBDb3VsZCBub3QgZmluZCAoJHtwYXRofSlgKTtcbiAgfVxuICBjb25zdCBjb250ZW50ID0gY29uZmlnQnVmZmVyLnRvU3RyaW5nKCk7XG5cbiAgcmV0dXJuIHBhcnNlSnNvbihjb250ZW50LCBKc29uUGFyc2VNb2RlLkxvb3NlKSBhcyB7fSBhcyBXb3Jrc3BhY2VTY2hlbWE7XG59XG4iXX0= |
Major refactor
Supply chain riskPackage has recently undergone a major refactor. It may be unstable or indicate significant internal changes. Use caution when updating to versions that include significant changes.
Found 1 instance in 1 package
43995
1.83%5
25%16
-11.11%286
-1.38%1
Infinity%+ Added
+ Added
+ Added
+ Added
+ Added
+ Added
+ Added
+ Added
+ Added
- Removed
- Removed
- Removed
- Removed
- Removed