@schematics/angular 16.1.0-next.2 → 16.1.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/application/schema.js +3 -3
- package/component/schema.js +4 -4
- package/config/schema.js +2 -2
- package/guard/schema.js +2 -2
- package/module/schema.js +2 -2
- package/ng-new/schema.js +4 -4
- package/package.json +3 -3
- package/private/standalone.d.ts +13 -1
- package/private/standalone.js +14 -2
- package/third_party/github.com/Microsoft/TypeScript/lib/typescript.d.ts +61 -20
- package/third_party/github.com/Microsoft/TypeScript/lib/typescript.js +28277 -27446
- package/universal/index.js +1 -1
- package/utility/ast-utils.d.ts +16 -6
- package/utility/ast-utils.js +57 -27
- package/utility/dependencies.js +2 -2
- package/utility/dependency.js +4 -4
- package/utility/index.d.ts +1 -0
- package/utility/index.js +16 -1
- package/utility/latest-versions/package.json +3 -3
- package/utility/latest-versions.js +2 -2
- package/utility/standalone/app_config.d.ts +23 -0
- package/utility/standalone/app_config.js +93 -0
- package/utility/standalone/code_block.d.ts +53 -0
- package/utility/standalone/code_block.js +83 -0
- package/utility/standalone/index.d.ts +9 -0
- package/utility/standalone/index.js +14 -0
- package/utility/standalone/rules.d.ts +45 -0
- package/utility/standalone/rules.js +190 -0
- package/utility/standalone/util.d.ts +35 -0
- package/utility/standalone/util.js +134 -0
- package/utility/workspace-models.js +3 -3
- package/workspace/schema.js +2 -2
package/universal/index.js
CHANGED
|
@@ -138,4 +138,4 @@ function default_1(options) {
|
|
|
138
138
|
};
|
|
139
139
|
}
|
|
140
140
|
exports.default = default_1;
|
|
141
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../../../packages/schematics/angular/universal/index.ts"],"names":[],"mappings":";AAAA;;;;;;GAMG;;AAEH,+CAA2F;AAC3F,2DAaoC;AACpC,4DAA0E;AAC1E,0DAIiC;AACjC,gEAA4D;AAC5D,0DAA0D;AAC1D,4CAA+D;AAC/D,gEAAsE;AACtE,oDAAqE;AACrE,kEAA8E;AAG9E,SAAS,gBAAgB,CAAC,OAAyB,EAAE,iBAAuB;IAC1E,OAAO,IAAA,2BAAe,EAAC,CAAC,SAAS,EAAE,EAAE;QACnC,MAAM,aAAa,GAAG,SAAS,CAAC,QAAQ,CAAC,GAAG,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC;QAE9D,IAAI,aAAa,EAAE;YACjB,gDAAgD;YAChD,oDAAoD;YACpD,uDAAuD;YACvD,2FAA2F;YAC3F,MAAM,gBAAgB,GAAG,CAAC,UAAiD,EAAE,EAAM,EAAE;gBACnF,OAAO;oBACL,cAAc,EAAE,OAAO,EAAE,cAAc;oBACvC,aAAa,EAAE,OAAO,EAAE,aAAa,KAAK,KAAK,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,OAAO,EAAE,aAAa;oBAClF,gBAAgB,EAAE,OAAO,EAAE,gBAAgB;oBAC3C,YAAY,EAAE,OAAO,EAAE,YAAY,KAAK,SAAS,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC,OAAO,EAAE,YAAY;oBACvF,SAAS,EAAE,OAAO,EAAE,SAAS;oBAC7B,YAAY,EAAE,OAAO,EAAE,YAAY;oBACnC,wBAAwB,EAAE,OAAO,EAAE,wBAAwB;oBAC3D,mBAAmB,EAAE,OAAO,EAAE,mBAAmB;oBACjD,SAAS,EAAE,OAAO,EAAE,SAAS;oBAC7B,sBAAsB,EAAE,OAAO,EAAE,sBAAsB;oBACvD,gBAAgB,EAAE,OAAO,EAAE,gBAAgB;oBAC3C,eAAe,EAAE,OAAO,EAAE,eAAe;oBACzC,mBAAmB,EAAE,OAAO,EAAE,mBAAmB;oBACjD,WAAW,EAAE,OAAO,EAAE,WAAW;iBAClC,CAAC;YACJ,CAAC,CAAC;YAEF,MAAM,WAAW,GAAG,aAAa,CAAC,OAAO,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC;YACvD,IAAI,WAAW,EAAE,OAAO,EAAE;gBACxB,WAAW,CAAC,OAAO,CAAC,UAAU,GAAG,QAAQ,OAAO,CAAC,OAAO,UAAU,CAAC;aACpE;YAED,MAAM,mBAAmB,GAAG,WAAW,EAAE,cAAc,CAAC;YACxD,MAAM,cAAc,GAAuB,EAAE,CAAC;YAC9C,IAAI,mBAAmB,EAAE;gBACvB,KAAK,MAAM,CAAC,GAAG,EAAE,OAAO,CAAC,IAAI,MAAM,CAAC,OAAO,CAAC,mBAAmB,CAAC,EAAE;oBAChE,cAAc,CAAC,GAAG,CAAC,GAAG,gBAAgB,CAAC,OAAO,CAAC,CAAC;iBACjD;aACF;YAED,MAAM,QAAQ,GAAG,OAAO,CAAC,IAAc,CAAC;YACxC,MAAM,UAAU,GAAG,aAAa,CAAC,UAAU,IAAI,IAAA,WAAI,EAAC,IAAA,gBAAS,EAAC,aAAa,CAAC,IAAI,CAAC,EAAE,KAAK,CAAC,CAAC;YAC1F,MAAM,cAAc,GAAG,IAAA,WAAI,EAAC,iBAAiB,EAAE,sBAAsB,CAAC,CAAC;YACvE,aAAa,CAAC,OAAO,CAAC,GAAG,CAAC;gBACxB,IAAI,EAAE,QAAQ;gBACd,OAAO,EAAE,2BAAQ,CAAC,MAAM;gBACxB,oBAAoB,EAAE,YAAY;gBAClC,OAAO,EAAE;oBACP,UAAU,EAAE,QAAQ,OAAO,CAAC,OAAO,SAAS;oBAC5C,IAAI,EAAE,IAAA,WAAI,EAAC,IAAA,gBAAS,EAAC,UAAU,CAAC,EAAE,QAAQ,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,QAAQ,GAAG,KAAK,CAAC;oBACzF,QAAQ,EAAE,cAAc;oBACxB,GAAG,CAAC,WAAW,EAAE,OAAO,CAAC,CAAC,CAAC,gBAAgB,CAAC,WAAW,EAAE,OAAO,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC;iBACxE;gBACD,cAAc;aACf,CAAC,CAAC;SACJ;IACH,CAAC,CAAC,CAAC;AACL,CAAC;AAED,SAAS,eAAe;IACtB,OAAO,CAAC,IAAU,EAAE,EAAE;QACpB,MAAM,OAAO,GAAG,IAAA,uCAAwB,EAAC,IAAI,EAAE,eAAe,CAAC,CAAC;QAChE,IAAI,OAAO,KAAK,IAAI,EAAE;YACpB,MAAM,IAAI,gCAAmB,CAAC,yBAAyB,CAAC,CAAC;SAC1D;QACD,MAAM,iBAAiB,GAAG;YACxB,GAAG,OAAO;YACV,IAAI,EAAE,0BAA0B;SACjC,CAAC;QACF,IAAA,uCAAwB,EAAC,IAAI,EAAE,iBAAiB,CAAC,CAAC;QAElD,IAAA,uCAAwB,EAAC,IAAI,EAAE;YAC7B,IAAI,EAAE,iCAAkB,CAAC,GAAG;YAC5B,IAAI,EAAE,aAAa;YACnB,OAAO,EAAE,gCAAc,CAAC,aAAa,CAAC;SACvC,CAAC,CAAC;IACL,CAAC,CAAC;AACJ,CAAC;AAED,mBAAyB,OAAyB;IAChD,OAAO,KAAK,EAAE,IAAU,EAAE,OAAyB,EAAE,EAAE;QACrD,MAAM,SAAS,GAAG,MAAM,IAAA,wBAAY,EAAC,IAAI,CAAC,CAAC;QAE3C,MAAM,aAAa,GAAG,SAAS,CAAC,QAAQ,CAAC,GAAG,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC;QAC9D,IAAI,CAAC,aAAa,IAAI,aAAa,CAAC,UAAU,CAAC,WAAW,KAAK,aAAa,EAAE;YAC5E,MAAM,IAAI,gCAAmB,CAAC,qDAAqD,CAAC,CAAC;SACtF;QAED,MAAM,iBAAiB,GAAG,aAAa,CAAC,OAAO,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC;QAC7D,IAAI,CAAC,iBAAiB,EAAE;YACtB,MAAM,IAAA,0CAAwB,GAAE,CAAC;SAClC;QAED,MAAM,kBAAkB,GAAG,CAAC,iBAAiB,CAAC,OAAO;YACnD,EAAE,CAAqC,CAAC;QAE1C,IAAI,CAAC,OAAO,CAAC,WAAW,EAAE;YACxB,OAAO,CAAC,OAAO,CAAC,IAAI,8BAAsB,EAAE,CAAC,CAAC;SAC/C;QAED,MAAM,YAAY,GAAG,IAAA,8BAAe,EAAC,IAAI,EAAE,kBAAkB,CAAC,IAAI,CAAC,CAAC;QAEpE,MAAM,cAAc,GAAG,IAAA,kBAAK,EAAC,IAAA,gBAAG,EAAC,YAAY,CAAC,CAAC,CAAC,wBAAwB,CAAC,CAAC,CAAC,aAAa,CAAC,EAAE;YACzF,IAAA,2BAAc,EAAC;gBACb,GAAG,oBAAO;gBACV,GAAG,OAAO;gBACV,gBAAgB,EAAE,CAAC,CAAS,EAAE,EAAE,CAAC,CAAC,CAAC,OAAO,CAAC,OAAO,EAAE,EAAE,CAAC;aACxD,CAAC;YACF,IAAA,iBAAI,EAAC,IAAA,WAAI,EAAC,IAAA,gBAAS,EAAC,aAAa,CAAC,IAAI,CAAC,EAAE,KAAK,CAAC,CAAC;SACjD,CAAC,CAAC;QAEH,MAAM,cAAc,GAAG,IAAA,gBAAS,EAAC,kBAAkB,CAAC,QAAQ,CAAC,CAAC;QAC9D,MAAM,eAAe,GAAG,IAAA,eAAQ,EAAC,cAAc,CAAC,CAAC;QACjD,MAAM,iBAAiB,GAAG,IAAA,cAAO,EAAC,cAAc,CAAC,CAAC;QAElD,MAAM,UAAU,GAAG,IAAA,kBAAK,EAAC,IAAA,gBAAG,EAAC,cAAc,CAAC,EAAE;YAC5C,IAAA,2BAAc,EAAC;gBACb,GAAG,oBAAO;gBACV,GAAG,OAAO;gBACV,gBAAgB,EAAE,CAAC,CAAS,EAAE,EAAE,CAAC,CAAC,CAAC,OAAO,CAAC,OAAO,EAAE,EAAE,CAAC;gBACvD,eAAe;gBACf,kBAAkB,EAAE,CAAC,CAAC,IAAA,uCAAwB,EAAC,IAAI,EAAE,mBAAmB,CAAC;gBACzE,2BAA2B,EAAE,IAAA,mCAA2B,EAAC,iBAAiB,CAAC;aAC5E,CAAC;YACF,IAAA,iBAAI,EAAC,iBAAiB,CAAC;SACxB,CAAC,CAAC;QAEH,OAAO,IAAA,kBAAK,EAAC;YACX,IAAA,sBAAS,EAAC,cAAc,CAAC;YACzB,IAAA,sBAAS,EAAC,UAAU,CAAC;YACrB,eAAe,EAAE;YACjB,gBAAgB,CAAC,OAAO,EAAE,iBAAiB,CAAC;SAC7C,CAAC,CAAC;IACL,CAAC,CAAC;AACJ,CAAC;AAvDD,4BAuDC","sourcesContent":["/**\n * @license\n * Copyright Google LLC 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 */\n\nimport { JsonValue, Path, basename, dirname, join, normalize } from '@angular-devkit/core';\nimport {\n  Rule,\n  SchematicContext,\n  SchematicsException,\n  Tree,\n  apply,\n  applyTemplates,\n  chain,\n  mergeWith,\n  move,\n  noop,\n  strings,\n  url,\n} from '@angular-devkit/schematics';\nimport { NodePackageInstallTask } from '@angular-devkit/schematics/tasks';\nimport {\n  NodeDependencyType,\n  addPackageJsonDependency,\n  getPackageJsonDependency,\n} from '../utility/dependencies';\nimport { latestVersions } from '../utility/latest-versions';\nimport { isStandaloneApp } from '../utility/ng-ast-utils';\nimport { relativePathToWorkspaceRoot } from '../utility/paths';\nimport { targetBuildNotFoundError } from '../utility/project-targets';\nimport { getWorkspace, updateWorkspace } from '../utility/workspace';\nimport { BrowserBuilderOptions, Builders } from '../utility/workspace-models';\nimport { Schema as UniversalOptions } from './schema';\n\nfunction updateConfigFile(options: UniversalOptions, tsConfigDirectory: Path): Rule {\n  return updateWorkspace((workspace) => {\n    const clientProject = workspace.projects.get(options.project);\n\n    if (clientProject) {\n      // In case the browser builder hashes the assets\n      // we need to add this setting to the server builder\n      // as otherwise when assets it will be requested twice.\n      // One for the server which will be unhashed, and other on the client which will be hashed.\n      const getServerOptions = (options: Record<string, JsonValue | undefined> = {}): {} => {\n        return {\n          buildOptimizer: options?.buildOptimizer,\n          outputHashing: options?.outputHashing === 'all' ? 'media' : options?.outputHashing,\n          fileReplacements: options?.fileReplacements,\n          optimization: options?.optimization === undefined ? undefined : !!options?.optimization,\n          sourceMap: options?.sourceMap,\n          localization: options?.localization,\n          stylePreprocessorOptions: options?.stylePreprocessorOptions,\n          resourcesOutputPath: options?.resourcesOutputPath,\n          deployUrl: options?.deployUrl,\n          i18nMissingTranslation: options?.i18nMissingTranslation,\n          preserveSymlinks: options?.preserveSymlinks,\n          extractLicenses: options?.extractLicenses,\n          inlineStyleLanguage: options?.inlineStyleLanguage,\n          vendorChunk: options?.vendorChunk,\n        };\n      };\n\n      const buildTarget = clientProject.targets.get('build');\n      if (buildTarget?.options) {\n        buildTarget.options.outputPath = `dist/${options.project}/browser`;\n      }\n\n      const buildConfigurations = buildTarget?.configurations;\n      const configurations: Record<string, {}> = {};\n      if (buildConfigurations) {\n        for (const [key, options] of Object.entries(buildConfigurations)) {\n          configurations[key] = getServerOptions(options);\n        }\n      }\n\n      const mainPath = options.main as string;\n      const sourceRoot = clientProject.sourceRoot ?? join(normalize(clientProject.root), 'src');\n      const serverTsConfig = join(tsConfigDirectory, 'tsconfig.server.json');\n      clientProject.targets.add({\n        name: 'server',\n        builder: Builders.Server,\n        defaultConfiguration: 'production',\n        options: {\n          outputPath: `dist/${options.project}/server`,\n          main: join(normalize(sourceRoot), mainPath.endsWith('.ts') ? mainPath : mainPath + '.ts'),\n          tsConfig: serverTsConfig,\n          ...(buildTarget?.options ? getServerOptions(buildTarget?.options) : {}),\n        },\n        configurations,\n      });\n    }\n  });\n}\n\nfunction addDependencies(): Rule {\n  return (host: Tree) => {\n    const coreDep = getPackageJsonDependency(host, '@angular/core');\n    if (coreDep === null) {\n      throw new SchematicsException('Could not find version.');\n    }\n    const platformServerDep = {\n      ...coreDep,\n      name: '@angular/platform-server',\n    };\n    addPackageJsonDependency(host, platformServerDep);\n\n    addPackageJsonDependency(host, {\n      type: NodeDependencyType.Dev,\n      name: '@types/node',\n      version: latestVersions['@types/node'],\n    });\n  };\n}\n\nexport default function (options: UniversalOptions): Rule {\n  return async (host: Tree, context: SchematicContext) => {\n    const workspace = await getWorkspace(host);\n\n    const clientProject = workspace.projects.get(options.project);\n    if (!clientProject || clientProject.extensions.projectType !== 'application') {\n      throw new SchematicsException(`Universal requires a project type of \"application\".`);\n    }\n\n    const clientBuildTarget = clientProject.targets.get('build');\n    if (!clientBuildTarget) {\n      throw targetBuildNotFoundError();\n    }\n\n    const clientBuildOptions = (clientBuildTarget.options ||\n      {}) as unknown as BrowserBuilderOptions;\n\n    if (!options.skipInstall) {\n      context.addTask(new NodePackageInstallTask());\n    }\n\n    const isStandalone = isStandaloneApp(host, clientBuildOptions.main);\n\n    const templateSource = apply(url(isStandalone ? './files/standalone-src' : './files/src'), [\n      applyTemplates({\n        ...strings,\n        ...options,\n        stripTsExtension: (s: string) => s.replace(/\\.ts$/, ''),\n      }),\n      move(join(normalize(clientProject.root), 'src')),\n    ]);\n\n    const clientTsConfig = normalize(clientBuildOptions.tsConfig);\n    const tsConfigExtends = basename(clientTsConfig);\n    const tsConfigDirectory = dirname(clientTsConfig);\n\n    const rootSource = apply(url('./files/root'), [\n      applyTemplates({\n        ...strings,\n        ...options,\n        stripTsExtension: (s: string) => s.replace(/\\.ts$/, ''),\n        tsConfigExtends,\n        hasLocalizePackage: !!getPackageJsonDependency(host, '@angular/localize'),\n        relativePathToWorkspaceRoot: relativePathToWorkspaceRoot(tsConfigDirectory),\n      }),\n      move(tsConfigDirectory),\n    ]);\n\n    return chain([\n      mergeWith(templateSource),\n      mergeWith(rootSource),\n      addDependencies(),\n      updateConfigFile(options, tsConfigDirectory),\n    ]);\n  };\n}\n"]}
|
|
141
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../../../packages/schematics/angular/universal/index.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Google LLC 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 */\n\nimport { JsonValue, Path, basename, dirname, join, normalize } from '@angular-devkit/core';\nimport {\n  Rule,\n  SchematicContext,\n  SchematicsException,\n  Tree,\n  apply,\n  applyTemplates,\n  chain,\n  mergeWith,\n  move,\n  strings,\n  url,\n} from '@angular-devkit/schematics';\nimport { NodePackageInstallTask } from '@angular-devkit/schematics/tasks';\nimport {\n  NodeDependencyType,\n  addPackageJsonDependency,\n  getPackageJsonDependency,\n} from '../utility/dependencies';\nimport { latestVersions } from '../utility/latest-versions';\nimport { isStandaloneApp } from '../utility/ng-ast-utils';\nimport { relativePathToWorkspaceRoot } from '../utility/paths';\nimport { targetBuildNotFoundError } from '../utility/project-targets';\nimport { getWorkspace, updateWorkspace } from '../utility/workspace';\nimport { BrowserBuilderOptions, Builders } from '../utility/workspace-models';\nimport { Schema as UniversalOptions } from './schema';\n\nfunction updateConfigFile(options: UniversalOptions, tsConfigDirectory: Path): Rule {\n  return updateWorkspace((workspace) => {\n    const clientProject = workspace.projects.get(options.project);\n\n    if (clientProject) {\n      // In case the browser builder hashes the assets\n      // we need to add this setting to the server builder\n      // as otherwise when assets it will be requested twice.\n      // One for the server which will be unhashed, and other on the client which will be hashed.\n      const getServerOptions = (options: Record<string, JsonValue | undefined> = {}): {} => {\n        return {\n          buildOptimizer: options?.buildOptimizer,\n          outputHashing: options?.outputHashing === 'all' ? 'media' : options?.outputHashing,\n          fileReplacements: options?.fileReplacements,\n          optimization: options?.optimization === undefined ? undefined : !!options?.optimization,\n          sourceMap: options?.sourceMap,\n          localization: options?.localization,\n          stylePreprocessorOptions: options?.stylePreprocessorOptions,\n          resourcesOutputPath: options?.resourcesOutputPath,\n          deployUrl: options?.deployUrl,\n          i18nMissingTranslation: options?.i18nMissingTranslation,\n          preserveSymlinks: options?.preserveSymlinks,\n          extractLicenses: options?.extractLicenses,\n          inlineStyleLanguage: options?.inlineStyleLanguage,\n          vendorChunk: options?.vendorChunk,\n        };\n      };\n\n      const buildTarget = clientProject.targets.get('build');\n      if (buildTarget?.options) {\n        buildTarget.options.outputPath = `dist/${options.project}/browser`;\n      }\n\n      const buildConfigurations = buildTarget?.configurations;\n      const configurations: Record<string, {}> = {};\n      if (buildConfigurations) {\n        for (const [key, options] of Object.entries(buildConfigurations)) {\n          configurations[key] = getServerOptions(options);\n        }\n      }\n\n      const mainPath = options.main as string;\n      const sourceRoot = clientProject.sourceRoot ?? join(normalize(clientProject.root), 'src');\n      const serverTsConfig = join(tsConfigDirectory, 'tsconfig.server.json');\n      clientProject.targets.add({\n        name: 'server',\n        builder: Builders.Server,\n        defaultConfiguration: 'production',\n        options: {\n          outputPath: `dist/${options.project}/server`,\n          main: join(normalize(sourceRoot), mainPath.endsWith('.ts') ? mainPath : mainPath + '.ts'),\n          tsConfig: serverTsConfig,\n          ...(buildTarget?.options ? getServerOptions(buildTarget?.options) : {}),\n        },\n        configurations,\n      });\n    }\n  });\n}\n\nfunction addDependencies(): Rule {\n  return (host: Tree) => {\n    const coreDep = getPackageJsonDependency(host, '@angular/core');\n    if (coreDep === null) {\n      throw new SchematicsException('Could not find version.');\n    }\n    const platformServerDep = {\n      ...coreDep,\n      name: '@angular/platform-server',\n    };\n    addPackageJsonDependency(host, platformServerDep);\n\n    addPackageJsonDependency(host, {\n      type: NodeDependencyType.Dev,\n      name: '@types/node',\n      version: latestVersions['@types/node'],\n    });\n  };\n}\n\nexport default function (options: UniversalOptions): Rule {\n  return async (host: Tree, context: SchematicContext) => {\n    const workspace = await getWorkspace(host);\n\n    const clientProject = workspace.projects.get(options.project);\n    if (!clientProject || clientProject.extensions.projectType !== 'application') {\n      throw new SchematicsException(`Universal requires a project type of \"application\".`);\n    }\n\n    const clientBuildTarget = clientProject.targets.get('build');\n    if (!clientBuildTarget) {\n      throw targetBuildNotFoundError();\n    }\n\n    const clientBuildOptions = (clientBuildTarget.options ||\n      {}) as unknown as BrowserBuilderOptions;\n\n    if (!options.skipInstall) {\n      context.addTask(new NodePackageInstallTask());\n    }\n\n    const isStandalone = isStandaloneApp(host, clientBuildOptions.main);\n\n    const templateSource = apply(url(isStandalone ? './files/standalone-src' : './files/src'), [\n      applyTemplates({\n        ...strings,\n        ...options,\n        stripTsExtension: (s: string) => s.replace(/\\.ts$/, ''),\n      }),\n      move(join(normalize(clientProject.root), 'src')),\n    ]);\n\n    const clientTsConfig = normalize(clientBuildOptions.tsConfig);\n    const tsConfigExtends = basename(clientTsConfig);\n    const tsConfigDirectory = dirname(clientTsConfig);\n\n    const rootSource = apply(url('./files/root'), [\n      applyTemplates({\n        ...strings,\n        ...options,\n        stripTsExtension: (s: string) => s.replace(/\\.ts$/, ''),\n        tsConfigExtends,\n        hasLocalizePackage: !!getPackageJsonDependency(host, '@angular/localize'),\n        relativePathToWorkspaceRoot: relativePathToWorkspaceRoot(tsConfigDirectory),\n      }),\n      move(tsConfigDirectory),\n    ]);\n\n    return chain([\n      mergeWith(templateSource),\n      mergeWith(rootSource),\n      addDependencies(),\n      updateConfigFile(options, tsConfigDirectory),\n    ]);\n  };\n}\n"]}
|
package/utility/ast-utils.d.ts
CHANGED
|
@@ -10,13 +10,14 @@ import { Change } from './change';
|
|
|
10
10
|
/**
|
|
11
11
|
* Add Import `import { symbolName } from fileName` if the import doesn't exit
|
|
12
12
|
* already. Assumes fileToEdit can be resolved and accessed.
|
|
13
|
-
* @param fileToEdit
|
|
14
|
-
* @param symbolName
|
|
15
|
-
* @param fileName
|
|
16
|
-
* @param isDefault
|
|
13
|
+
* @param fileToEdit File we want to add import to.
|
|
14
|
+
* @param symbolName Item to import.
|
|
15
|
+
* @param fileName Path to the file.
|
|
16
|
+
* @param isDefault If true, import follows style for importing default exports.
|
|
17
|
+
* @param alias Alias that the symbol should be inserted under.
|
|
17
18
|
* @return Change
|
|
18
19
|
*/
|
|
19
|
-
export declare function insertImport(source: ts.SourceFile, fileToEdit: string, symbolName: string, fileName: string, isDefault?: boolean): Change;
|
|
20
|
+
export declare function insertImport(source: ts.SourceFile, fileToEdit: string, symbolName: string, fileName: string, isDefault?: boolean, alias?: string): Change;
|
|
20
21
|
/**
|
|
21
22
|
* Find all nodes from the AST in the subtree of node of SyntaxKind kind.
|
|
22
23
|
* @param node
|
|
@@ -57,7 +58,7 @@ export declare function findNode(node: ts.Node, kind: ts.SyntaxKind, text: strin
|
|
|
57
58
|
* @return Change instance
|
|
58
59
|
* @throw Error if toInsert is first occurence but fall back is not set
|
|
59
60
|
*/
|
|
60
|
-
export declare function insertAfterLastOccurrence(nodes: ts.Node[]
|
|
61
|
+
export declare function insertAfterLastOccurrence(nodes: ts.Node[] | ts.NodeArray<ts.Node>, toInsert: string, file: string, fallbackPos: number, syntaxKind?: ts.SyntaxKind): Change;
|
|
61
62
|
export declare function getDecoratorMetadata(source: ts.SourceFile, identifier: string, module: string): ts.Node[];
|
|
62
63
|
export declare function getMetadataField(node: ts.ObjectLiteralExpression, metadataField: string): ts.ObjectLiteralElement[];
|
|
63
64
|
export declare function addSymbolToNgModuleMetadata(source: ts.SourceFile, ngModulePath: string, metadataField: string, symbolName: string, importPath?: string | null): Change[];
|
|
@@ -94,3 +95,12 @@ export declare function getRouterModuleDeclaration(source: ts.SourceFile): ts.Ex
|
|
|
94
95
|
* Adds a new route declaration to a router module (i.e. has a RouterModule declaration)
|
|
95
96
|
*/
|
|
96
97
|
export declare function addRouteDeclarationToModule(source: ts.SourceFile, fileToAdd: string, routeLiteral: string): Change;
|
|
98
|
+
/**
|
|
99
|
+
* Determines if a SourceFile has a top-level declaration whose name matches a specific symbol.
|
|
100
|
+
* Can be used to avoid conflicts when inserting new imports into a file.
|
|
101
|
+
* @param sourceFile File in which to search.
|
|
102
|
+
* @param symbolName Name of the symbol to search for.
|
|
103
|
+
* @param skipModule Path of the module that the symbol may have been imported from. Used to
|
|
104
|
+
* avoid false positives where the same symbol we're looking for may have been imported.
|
|
105
|
+
*/
|
|
106
|
+
export declare function hasTopLevelIdentifier(sourceFile: ts.SourceFile, symbolName: string, skipModule?: string | null): boolean;
|
package/utility/ast-utils.js
CHANGED
|
@@ -30,51 +30,46 @@ var __importStar = (this && this.__importStar) || function (mod) {
|
|
|
30
30
|
return result;
|
|
31
31
|
};
|
|
32
32
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
33
|
-
exports.addRouteDeclarationToModule = exports.getRouterModuleDeclaration = exports.isImported = exports.addBootstrapToModule = exports.addExportToModule = exports.addProviderToModule = exports.addImportToModule = exports.addDeclarationToModule = exports.addSymbolToNgModuleMetadata = exports.getMetadataField = exports.getDecoratorMetadata = exports.insertAfterLastOccurrence = exports.findNode = exports.getSourceNodes = exports.findNodes = exports.insertImport = void 0;
|
|
33
|
+
exports.hasTopLevelIdentifier = exports.addRouteDeclarationToModule = exports.getRouterModuleDeclaration = exports.isImported = exports.addBootstrapToModule = exports.addExportToModule = exports.addProviderToModule = exports.addImportToModule = exports.addDeclarationToModule = exports.addSymbolToNgModuleMetadata = exports.getMetadataField = exports.getDecoratorMetadata = exports.insertAfterLastOccurrence = exports.findNode = exports.getSourceNodes = exports.findNodes = exports.insertImport = void 0;
|
|
34
34
|
const core_1 = require("@angular-devkit/core");
|
|
35
35
|
const ts = __importStar(require("../third_party/github.com/Microsoft/TypeScript/lib/typescript"));
|
|
36
36
|
const change_1 = require("./change");
|
|
37
37
|
/**
|
|
38
38
|
* Add Import `import { symbolName } from fileName` if the import doesn't exit
|
|
39
39
|
* already. Assumes fileToEdit can be resolved and accessed.
|
|
40
|
-
* @param fileToEdit
|
|
41
|
-
* @param symbolName
|
|
42
|
-
* @param fileName
|
|
43
|
-
* @param isDefault
|
|
40
|
+
* @param fileToEdit File we want to add import to.
|
|
41
|
+
* @param symbolName Item to import.
|
|
42
|
+
* @param fileName Path to the file.
|
|
43
|
+
* @param isDefault If true, import follows style for importing default exports.
|
|
44
|
+
* @param alias Alias that the symbol should be inserted under.
|
|
44
45
|
* @return Change
|
|
45
46
|
*/
|
|
46
|
-
function insertImport(source, fileToEdit, symbolName, fileName, isDefault = false) {
|
|
47
|
+
function insertImport(source, fileToEdit, symbolName, fileName, isDefault = false, alias) {
|
|
47
48
|
const rootNode = source;
|
|
48
|
-
const allImports = findNodes(rootNode, ts.
|
|
49
|
+
const allImports = findNodes(rootNode, ts.isImportDeclaration);
|
|
50
|
+
const importExpression = alias ? `${symbolName} as ${alias}` : symbolName;
|
|
49
51
|
// get nodes that map to import statements from the file fileName
|
|
50
52
|
const relevantImports = allImports.filter((node) => {
|
|
51
|
-
|
|
52
|
-
const importFiles = node
|
|
53
|
-
.getChildren()
|
|
54
|
-
.filter(ts.isStringLiteral)
|
|
55
|
-
.map((n) => n.text);
|
|
56
|
-
return importFiles.filter((file) => file === fileName).length === 1;
|
|
53
|
+
return ts.isStringLiteralLike(node.moduleSpecifier) && node.moduleSpecifier.text === fileName;
|
|
57
54
|
});
|
|
58
55
|
if (relevantImports.length > 0) {
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
const imports = [];
|
|
62
|
-
relevantImports.forEach((n) => {
|
|
63
|
-
Array.prototype.push.apply(imports, findNodes(n, ts.SyntaxKind.Identifier));
|
|
64
|
-
if (findNodes(n, ts.SyntaxKind.AsteriskToken).length > 0) {
|
|
65
|
-
importsAsterisk = true;
|
|
66
|
-
}
|
|
56
|
+
const hasNamespaceImport = relevantImports.some((node) => {
|
|
57
|
+
return node.importClause?.namedBindings?.kind === ts.SyntaxKind.NamespaceImport;
|
|
67
58
|
});
|
|
68
59
|
// if imports * from fileName, don't add symbolName
|
|
69
|
-
if (
|
|
60
|
+
if (hasNamespaceImport) {
|
|
70
61
|
return new change_1.NoopChange();
|
|
71
62
|
}
|
|
72
|
-
const
|
|
63
|
+
const imports = relevantImports.flatMap((node) => {
|
|
64
|
+
return node.importClause?.namedBindings && ts.isNamedImports(node.importClause.namedBindings)
|
|
65
|
+
? node.importClause.namedBindings.elements
|
|
66
|
+
: [];
|
|
67
|
+
});
|
|
73
68
|
// insert import if it's not there
|
|
74
|
-
if (
|
|
69
|
+
if (!imports.some((node) => (node.propertyName || node.name).text === symbolName)) {
|
|
75
70
|
const fallbackPos = findNodes(relevantImports[0], ts.SyntaxKind.CloseBraceToken)[0].getStart() ||
|
|
76
71
|
findNodes(relevantImports[0], ts.SyntaxKind.FromKeyword)[0].getStart();
|
|
77
|
-
return insertAfterLastOccurrence(imports, `, ${
|
|
72
|
+
return insertAfterLastOccurrence(imports, `, ${importExpression}`, fileToEdit, fallbackPos);
|
|
78
73
|
}
|
|
79
74
|
return new change_1.NoopChange();
|
|
80
75
|
}
|
|
@@ -89,7 +84,7 @@ function insertImport(source, fileToEdit, symbolName, fileName, isDefault = fals
|
|
|
89
84
|
// if there are no imports or 'use strict' statement, insert import at beginning of file
|
|
90
85
|
const insertAtBeginning = allImports.length === 0 && useStrict.length === 0;
|
|
91
86
|
const separator = insertAtBeginning ? '' : ';\n';
|
|
92
|
-
const toInsert = `${separator}import ${open}${
|
|
87
|
+
const toInsert = `${separator}import ${open}${importExpression}${close}` +
|
|
93
88
|
` from '${fileName}'${insertAtBeginning ? ';\n' : ''}`;
|
|
94
89
|
return insertAfterLastOccurrence(allImports, toInsert, fileToEdit, fallbackPos, ts.SyntaxKind.StringLiteral);
|
|
95
90
|
}
|
|
@@ -510,4 +505,39 @@ function addRouteDeclarationToModule(source, fileToAdd, routeLiteral) {
|
|
|
510
505
|
return new change_1.InsertChange(fileToAdd, insertPos, route);
|
|
511
506
|
}
|
|
512
507
|
exports.addRouteDeclarationToModule = addRouteDeclarationToModule;
|
|
513
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ast-utils.js","sourceRoot":"","sources":["../../../../../../../packages/schematics/angular/utility/ast-utils.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Google LLC 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 */\n\nimport { tags } from '@angular-devkit/core';\nimport * as ts from '../third_party/github.com/Microsoft/TypeScript/lib/typescript';\nimport { Change, InsertChange, NoopChange } from './change';\n\n/**\n * Add Import `import { symbolName } from fileName` if the import doesn't exit\n * already. Assumes fileToEdit can be resolved and accessed.\n * @param fileToEdit (file we want to add import to)\n * @param symbolName (item to import)\n * @param fileName (path to the file)\n * @param isDefault (if true, import follows style for importing default exports)\n * @return Change\n */\nexport function insertImport(\n  source: ts.SourceFile,\n  fileToEdit: string,\n  symbolName: string,\n  fileName: string,\n  isDefault = false,\n): Change {\n  const rootNode = source;\n  const allImports = findNodes(rootNode, ts.SyntaxKind.ImportDeclaration);\n\n  // get nodes that map to import statements from the file fileName\n  const relevantImports = allImports.filter((node) => {\n    // StringLiteral of the ImportDeclaration is the import file (fileName in this case).\n    const importFiles = node\n      .getChildren()\n      .filter(ts.isStringLiteral)\n      .map((n) => n.text);\n\n    return importFiles.filter((file) => file === fileName).length === 1;\n  });\n\n  if (relevantImports.length > 0) {\n    let importsAsterisk = false;\n    // imports from import file\n    const imports: ts.Node[] = [];\n    relevantImports.forEach((n) => {\n      Array.prototype.push.apply(imports, findNodes(n, ts.SyntaxKind.Identifier));\n      if (findNodes(n, ts.SyntaxKind.AsteriskToken).length > 0) {\n        importsAsterisk = true;\n      }\n    });\n\n    // if imports * from fileName, don't add symbolName\n    if (importsAsterisk) {\n      return new NoopChange();\n    }\n\n    const importTextNodes = imports.filter((n) => (n as ts.Identifier).text === symbolName);\n\n    // insert import if it's not there\n    if (importTextNodes.length === 0) {\n      const fallbackPos =\n        findNodes(relevantImports[0], ts.SyntaxKind.CloseBraceToken)[0].getStart() ||\n        findNodes(relevantImports[0], ts.SyntaxKind.FromKeyword)[0].getStart();\n\n      return insertAfterLastOccurrence(imports, `, ${symbolName}`, fileToEdit, fallbackPos);\n    }\n\n    return new NoopChange();\n  }\n\n  // no such import declaration exists\n  const useStrict = findNodes(rootNode, ts.isStringLiteral).filter((n) => n.text === 'use strict');\n  let fallbackPos = 0;\n  if (useStrict.length > 0) {\n    fallbackPos = useStrict[0].end;\n  }\n  const open = isDefault ? '' : '{ ';\n  const close = isDefault ? '' : ' }';\n  // if there are no imports or 'use strict' statement, insert import at beginning of file\n  const insertAtBeginning = allImports.length === 0 && useStrict.length === 0;\n  const separator = insertAtBeginning ? '' : ';\\n';\n  const toInsert =\n    `${separator}import ${open}${symbolName}${close}` +\n    ` from '${fileName}'${insertAtBeginning ? ';\\n' : ''}`;\n\n  return insertAfterLastOccurrence(\n    allImports,\n    toInsert,\n    fileToEdit,\n    fallbackPos,\n    ts.SyntaxKind.StringLiteral,\n  );\n}\n\n/**\n * Find all nodes from the AST in the subtree of node of SyntaxKind kind.\n * @param node\n * @param kind\n * @param max The maximum number of items to return.\n * @param recursive Continue looking for nodes of kind recursive until end\n * the last child even when node of kind has been found.\n * @return all nodes of kind, or [] if none is found\n */\nexport function findNodes(\n  node: ts.Node,\n  kind: ts.SyntaxKind,\n  max?: number,\n  recursive?: boolean,\n): ts.Node[];\n\n/**\n * Find all nodes from the AST in the subtree that satisfy a type guard.\n * @param node\n * @param guard\n * @param max The maximum number of items to return.\n * @param recursive Continue looking for nodes of kind recursive until end\n * the last child even when node of kind has been found.\n * @return all nodes that satisfy the type guard, or [] if none is found\n */\nexport function findNodes<T extends ts.Node>(\n  node: ts.Node,\n  guard: (node: ts.Node) => node is T,\n  max?: number,\n  recursive?: boolean,\n): T[];\n\nexport function findNodes<T extends ts.Node>(\n  node: ts.Node,\n  kindOrGuard: ts.SyntaxKind | ((node: ts.Node) => node is T),\n  max = Infinity,\n  recursive = false,\n): T[] {\n  if (!node || max == 0) {\n    return [];\n  }\n\n  const test =\n    typeof kindOrGuard === 'function'\n      ? kindOrGuard\n      : (node: ts.Node): node is T => node.kind === kindOrGuard;\n\n  const arr: T[] = [];\n  if (test(node)) {\n    arr.push(node);\n    max--;\n  }\n  if (max > 0 && (recursive || !test(node))) {\n    for (const child of node.getChildren()) {\n      findNodes(child, test, max, recursive).forEach((node) => {\n        if (max > 0) {\n          arr.push(node);\n        }\n        max--;\n      });\n\n      if (max <= 0) {\n        break;\n      }\n    }\n  }\n\n  return arr;\n}\n\n/**\n * Get all the nodes from a source.\n * @param sourceFile The source file object.\n * @returns {Array<ts.Node>} An array of all the nodes in the source.\n */\nexport function getSourceNodes(sourceFile: ts.SourceFile): ts.Node[] {\n  const nodes: ts.Node[] = [sourceFile];\n  const result: ts.Node[] = [];\n\n  while (nodes.length > 0) {\n    const node = nodes.shift();\n\n    if (node) {\n      result.push(node);\n      if (node.getChildCount(sourceFile) >= 0) {\n        nodes.unshift(...node.getChildren());\n      }\n    }\n  }\n\n  return result;\n}\n\nexport function findNode(node: ts.Node, kind: ts.SyntaxKind, text: string): ts.Node | null {\n  if (node.kind === kind && node.getText() === text) {\n    return node;\n  }\n\n  let foundNode: ts.Node | null = null;\n  ts.forEachChild(node, (childNode) => {\n    foundNode = foundNode || findNode(childNode, kind, text);\n  });\n\n  return foundNode;\n}\n\n/**\n * Helper for sorting nodes.\n * @return function to sort nodes in increasing order of position in sourceFile\n */\nfunction nodesByPosition(first: ts.Node, second: ts.Node): number {\n  return first.getStart() - second.getStart();\n}\n\n/**\n * Insert `toInsert` after the last occurence of `ts.SyntaxKind[nodes[i].kind]`\n * or after the last of occurence of `syntaxKind` if the last occurence is a sub child\n * of ts.SyntaxKind[nodes[i].kind] and save the changes in file.\n *\n * @param nodes insert after the last occurence of nodes\n * @param toInsert string to insert\n * @param file file to insert changes into\n * @param fallbackPos position to insert if toInsert happens to be the first occurence\n * @param syntaxKind the ts.SyntaxKind of the subchildren to insert after\n * @return Change instance\n * @throw Error if toInsert is first occurence but fall back is not set\n */\nexport function insertAfterLastOccurrence(\n  nodes: ts.Node[],\n  toInsert: string,\n  file: string,\n  fallbackPos: number,\n  syntaxKind?: ts.SyntaxKind,\n): Change {\n  let lastItem: ts.Node | undefined;\n  for (const node of nodes) {\n    if (!lastItem || lastItem.getStart() < node.getStart()) {\n      lastItem = node;\n    }\n  }\n  if (syntaxKind && lastItem) {\n    lastItem = findNodes(lastItem, syntaxKind).sort(nodesByPosition).pop();\n  }\n  if (!lastItem && fallbackPos == undefined) {\n    throw new Error(`tried to insert ${toInsert} as first occurence with no fallback position`);\n  }\n  const lastItemPosition: number = lastItem ? lastItem.getEnd() : fallbackPos;\n\n  return new InsertChange(file, lastItemPosition, toInsert);\n}\n\nfunction _angularImportsFromNode(node: ts.ImportDeclaration): { [name: string]: string } {\n  const ms = node.moduleSpecifier;\n  let modulePath: string;\n  switch (ms.kind) {\n    case ts.SyntaxKind.StringLiteral:\n      modulePath = (ms as ts.StringLiteral).text;\n      break;\n    default:\n      return {};\n  }\n\n  if (!modulePath.startsWith('@angular/')) {\n    return {};\n  }\n\n  if (node.importClause) {\n    if (node.importClause.name) {\n      // This is of the form `import Name from 'path'`. Ignore.\n      return {};\n    } else if (node.importClause.namedBindings) {\n      const nb = node.importClause.namedBindings;\n      if (nb.kind == ts.SyntaxKind.NamespaceImport) {\n        // This is of the form `import * as name from 'path'`. Return `name.`.\n        return {\n          [nb.name.text + '.']: modulePath,\n        };\n      } else {\n        // This is of the form `import {a,b,c} from 'path'`\n        const namedImports = nb;\n\n        return namedImports.elements\n          .map((is: ts.ImportSpecifier) => (is.propertyName ? is.propertyName.text : is.name.text))\n          .reduce((acc: { [name: string]: string }, curr: string) => {\n            acc[curr] = modulePath;\n\n            return acc;\n          }, {});\n      }\n    }\n\n    return {};\n  } else {\n    // This is of the form `import 'path';`. Nothing to do.\n    return {};\n  }\n}\n\nexport function getDecoratorMetadata(\n  source: ts.SourceFile,\n  identifier: string,\n  module: string,\n): ts.Node[] {\n  const angularImports = findNodes(source, ts.isImportDeclaration)\n    .map((node) => _angularImportsFromNode(node))\n    .reduce((acc, current) => {\n      for (const key of Object.keys(current)) {\n        acc[key] = current[key];\n      }\n\n      return acc;\n    }, {});\n\n  return getSourceNodes(source)\n    .filter((node) => {\n      return (\n        node.kind == ts.SyntaxKind.Decorator &&\n        (node as ts.Decorator).expression.kind == ts.SyntaxKind.CallExpression\n      );\n    })\n    .map((node) => (node as ts.Decorator).expression as ts.CallExpression)\n    .filter((expr) => {\n      if (expr.expression.kind == ts.SyntaxKind.Identifier) {\n        const id = expr.expression as ts.Identifier;\n\n        return id.text == identifier && angularImports[id.text] === module;\n      } else if (expr.expression.kind == ts.SyntaxKind.PropertyAccessExpression) {\n        // This covers foo.NgModule when importing * as foo.\n        const paExpr = expr.expression as ts.PropertyAccessExpression;\n        // If the left expression is not an identifier, just give up at that point.\n        if (paExpr.expression.kind !== ts.SyntaxKind.Identifier) {\n          return false;\n        }\n\n        const id = paExpr.name.text;\n        const moduleId = (paExpr.expression as ts.Identifier).text;\n\n        return id === identifier && angularImports[moduleId + '.'] === module;\n      }\n\n      return false;\n    })\n    .filter(\n      (expr) =>\n        expr.arguments[0] && expr.arguments[0].kind == ts.SyntaxKind.ObjectLiteralExpression,\n    )\n    .map((expr) => expr.arguments[0] as ts.ObjectLiteralExpression);\n}\n\nexport function getMetadataField(\n  node: ts.ObjectLiteralExpression,\n  metadataField: string,\n): ts.ObjectLiteralElement[] {\n  return (\n    node.properties\n      .filter(ts.isPropertyAssignment)\n      // Filter out every fields that's not \"metadataField\". Also handles string literals\n      // (but not expressions).\n      .filter(({ name }) => {\n        return (ts.isIdentifier(name) || ts.isStringLiteral(name)) && name.text === metadataField;\n      })\n  );\n}\n\nexport function addSymbolToNgModuleMetadata(\n  source: ts.SourceFile,\n  ngModulePath: string,\n  metadataField: string,\n  symbolName: string,\n  importPath: string | null = null,\n): Change[] {\n  const nodes = getDecoratorMetadata(source, 'NgModule', '@angular/core');\n  const node = nodes[0];\n\n  // Find the decorator declaration.\n  if (!node || !ts.isObjectLiteralExpression(node)) {\n    return [];\n  }\n\n  // Get all the children property assignment of object literals.\n  const matchingProperties = getMetadataField(node, metadataField);\n\n  if (matchingProperties.length == 0) {\n    // We haven't found the field in the metadata declaration. Insert a new field.\n    let position: number;\n    let toInsert: string;\n    if (node.properties.length == 0) {\n      position = node.getEnd() - 1;\n      toInsert = `\\n  ${metadataField}: [\\n${tags.indentBy(4)`${symbolName}`}\\n  ]\\n`;\n    } else {\n      const childNode = node.properties[node.properties.length - 1];\n      position = childNode.getEnd();\n      // Get the indentation of the last element, if any.\n      const text = childNode.getFullText(source);\n      const matches = text.match(/^(\\r?\\n)(\\s*)/);\n      if (matches) {\n        toInsert =\n          `,${matches[0]}${metadataField}: [${matches[1]}` +\n          `${tags.indentBy(matches[2].length + 2)`${symbolName}`}${matches[0]}]`;\n      } else {\n        toInsert = `, ${metadataField}: [${symbolName}]`;\n      }\n    }\n    if (importPath !== null) {\n      return [\n        new InsertChange(ngModulePath, position, toInsert),\n        insertImport(source, ngModulePath, symbolName.replace(/\\..*$/, ''), importPath),\n      ];\n    } else {\n      return [new InsertChange(ngModulePath, position, toInsert)];\n    }\n  }\n  const assignment = matchingProperties[0];\n\n  // If it's not an array, nothing we can do really.\n  if (\n    !ts.isPropertyAssignment(assignment) ||\n    !ts.isArrayLiteralExpression(assignment.initializer)\n  ) {\n    return [];\n  }\n\n  let expresssion: ts.Expression | ts.ArrayLiteralExpression;\n  const assignmentInit = assignment.initializer;\n  const elements = assignmentInit.elements;\n\n  if (elements.length) {\n    const symbolsArray = elements.map((node) => tags.oneLine`${node.getText()}`);\n    if (symbolsArray.includes(tags.oneLine`${symbolName}`)) {\n      return [];\n    }\n\n    expresssion = elements[elements.length - 1];\n  } else {\n    expresssion = assignmentInit;\n  }\n\n  let toInsert: string;\n  let position = expresssion.getEnd();\n  if (ts.isArrayLiteralExpression(expresssion)) {\n    // We found the field but it's empty. Insert it just before the `]`.\n    position--;\n    toInsert = `\\n${tags.indentBy(4)`${symbolName}`}\\n  `;\n  } else {\n    // Get the indentation of the last element, if any.\n    const text = expresssion.getFullText(source);\n    const matches = text.match(/^(\\r?\\n)(\\s*)/);\n    if (matches) {\n      toInsert = `,${matches[1]}${tags.indentBy(matches[2].length)`${symbolName}`}`;\n    } else {\n      toInsert = `, ${symbolName}`;\n    }\n  }\n\n  if (importPath !== null) {\n    return [\n      new InsertChange(ngModulePath, position, toInsert),\n      insertImport(source, ngModulePath, symbolName.replace(/\\..*$/, ''), importPath),\n    ];\n  }\n\n  return [new InsertChange(ngModulePath, position, toInsert)];\n}\n\n/**\n * Custom function to insert a declaration (component, pipe, directive)\n * into NgModule declarations. It also imports the component.\n */\nexport function addDeclarationToModule(\n  source: ts.SourceFile,\n  modulePath: string,\n  classifiedName: string,\n  importPath: string,\n): Change[] {\n  return addSymbolToNgModuleMetadata(\n    source,\n    modulePath,\n    'declarations',\n    classifiedName,\n    importPath,\n  );\n}\n\n/**\n * Custom function to insert an NgModule into NgModule imports. It also imports the module.\n */\nexport function addImportToModule(\n  source: ts.SourceFile,\n  modulePath: string,\n  classifiedName: string,\n  importPath: string,\n): Change[] {\n  return addSymbolToNgModuleMetadata(source, modulePath, 'imports', classifiedName, importPath);\n}\n\n/**\n * Custom function to insert a provider into NgModule. It also imports it.\n */\nexport function addProviderToModule(\n  source: ts.SourceFile,\n  modulePath: string,\n  classifiedName: string,\n  importPath: string,\n): Change[] {\n  return addSymbolToNgModuleMetadata(source, modulePath, 'providers', classifiedName, importPath);\n}\n\n/**\n * Custom function to insert an export into NgModule. It also imports it.\n */\nexport function addExportToModule(\n  source: ts.SourceFile,\n  modulePath: string,\n  classifiedName: string,\n  importPath: string,\n): Change[] {\n  return addSymbolToNgModuleMetadata(source, modulePath, 'exports', classifiedName, importPath);\n}\n\n/**\n * Custom function to insert an export into NgModule. It also imports it.\n */\nexport function addBootstrapToModule(\n  source: ts.SourceFile,\n  modulePath: string,\n  classifiedName: string,\n  importPath: string,\n): Change[] {\n  return addSymbolToNgModuleMetadata(source, modulePath, 'bootstrap', classifiedName, importPath);\n}\n\n/**\n * Determine if an import already exists.\n */\nexport function isImported(\n  source: ts.SourceFile,\n  classifiedName: string,\n  importPath: string,\n): boolean {\n  const allNodes = getSourceNodes(source);\n  const matchingNodes = allNodes\n    .filter(ts.isImportDeclaration)\n    .filter(\n      (imp) => ts.isStringLiteral(imp.moduleSpecifier) && imp.moduleSpecifier.text === importPath,\n    )\n    .filter((imp) => {\n      if (!imp.importClause) {\n        return false;\n      }\n      const nodes = findNodes(imp.importClause, ts.isImportSpecifier).filter(\n        (n) => n.getText() === classifiedName,\n      );\n\n      return nodes.length > 0;\n    });\n\n  return matchingNodes.length > 0;\n}\n\n/**\n * Returns the RouterModule declaration from NgModule metadata, if any.\n */\nexport function getRouterModuleDeclaration(source: ts.SourceFile): ts.Expression | undefined {\n  const result = getDecoratorMetadata(source, 'NgModule', '@angular/core');\n  const node = result[0];\n  if (!node || !ts.isObjectLiteralExpression(node)) {\n    return undefined;\n  }\n\n  const matchingProperties = getMetadataField(node, 'imports');\n  if (!matchingProperties) {\n    return;\n  }\n\n  const assignment = matchingProperties[0] as ts.PropertyAssignment;\n\n  if (assignment.initializer.kind !== ts.SyntaxKind.ArrayLiteralExpression) {\n    return;\n  }\n\n  const arrLiteral = assignment.initializer as ts.ArrayLiteralExpression;\n\n  return arrLiteral.elements\n    .filter((el) => el.kind === ts.SyntaxKind.CallExpression)\n    .find((el) => (el as ts.Identifier).getText().startsWith('RouterModule'));\n}\n\n/**\n * Adds a new route declaration to a router module (i.e. has a RouterModule declaration)\n */\nexport function addRouteDeclarationToModule(\n  source: ts.SourceFile,\n  fileToAdd: string,\n  routeLiteral: string,\n): Change {\n  const routerModuleExpr = getRouterModuleDeclaration(source);\n  if (!routerModuleExpr) {\n    throw new Error(\n      `Couldn't find a route declaration in ${fileToAdd}.\\n` +\n        `Use the '--module' option to specify a different routing module.`,\n    );\n  }\n  const scopeConfigMethodArgs = (routerModuleExpr as ts.CallExpression).arguments;\n  if (!scopeConfigMethodArgs.length) {\n    const { line } = source.getLineAndCharacterOfPosition(routerModuleExpr.getStart());\n    throw new Error(\n      `The router module method doesn't have arguments ` + `at line ${line} in ${fileToAdd}`,\n    );\n  }\n\n  let routesArr: ts.ArrayLiteralExpression | undefined;\n  const routesArg = scopeConfigMethodArgs[0];\n\n  // Check if the route declarations array is\n  // an inlined argument of RouterModule or a standalone variable\n  if (ts.isArrayLiteralExpression(routesArg)) {\n    routesArr = routesArg;\n  } else {\n    const routesVarName = routesArg.getText();\n    let routesVar;\n    if (routesArg.kind === ts.SyntaxKind.Identifier) {\n      routesVar = source.statements.filter(ts.isVariableStatement).find((v) => {\n        return v.declarationList.declarations[0].name.getText() === routesVarName;\n      });\n    }\n\n    if (!routesVar) {\n      const { line } = source.getLineAndCharacterOfPosition(routesArg.getStart());\n      throw new Error(\n        `No route declaration array was found that corresponds ` +\n          `to router module at line ${line} in ${fileToAdd}`,\n      );\n    }\n\n    routesArr = findNodes(\n      routesVar,\n      ts.SyntaxKind.ArrayLiteralExpression,\n      1,\n    )[0] as ts.ArrayLiteralExpression;\n  }\n\n  const occurrencesCount = routesArr.elements.length;\n  const text = routesArr.getFullText(source);\n\n  let route: string = routeLiteral;\n  let insertPos = routesArr.elements.pos;\n\n  if (occurrencesCount > 0) {\n    const lastRouteLiteral = [...routesArr.elements].pop() as ts.Expression;\n    const lastRouteIsWildcard =\n      ts.isObjectLiteralExpression(lastRouteLiteral) &&\n      lastRouteLiteral.properties.some(\n        (n) =>\n          ts.isPropertyAssignment(n) &&\n          ts.isIdentifier(n.name) &&\n          n.name.text === 'path' &&\n          ts.isStringLiteral(n.initializer) &&\n          n.initializer.text === '**',\n      );\n\n    const indentation = text.match(/\\r?\\n(\\r?)\\s*/) || [];\n    const routeText = `${indentation[0] || ' '}${routeLiteral}`;\n\n    // Add the new route before the wildcard route\n    // otherwise we'll always redirect to the wildcard route\n    if (lastRouteIsWildcard) {\n      insertPos = lastRouteLiteral.pos;\n      route = `${routeText},`;\n    } else {\n      insertPos = lastRouteLiteral.end;\n      route = `,${routeText}`;\n    }\n  }\n\n  return new InsertChange(fileToAdd, insertPos, route);\n}\n"]}
|
|
508
|
+
/** Asserts if the specified node is a named declaration (e.g. class, interface). */
|
|
509
|
+
function isNamedNode(node) {
|
|
510
|
+
return !!node.name && ts.isIdentifier(node.name);
|
|
511
|
+
}
|
|
512
|
+
/**
|
|
513
|
+
* Determines if a SourceFile has a top-level declaration whose name matches a specific symbol.
|
|
514
|
+
* Can be used to avoid conflicts when inserting new imports into a file.
|
|
515
|
+
* @param sourceFile File in which to search.
|
|
516
|
+
* @param symbolName Name of the symbol to search for.
|
|
517
|
+
* @param skipModule Path of the module that the symbol may have been imported from. Used to
|
|
518
|
+
* avoid false positives where the same symbol we're looking for may have been imported.
|
|
519
|
+
*/
|
|
520
|
+
function hasTopLevelIdentifier(sourceFile, symbolName, skipModule = null) {
|
|
521
|
+
for (const node of sourceFile.statements) {
|
|
522
|
+
if (isNamedNode(node) && node.name.text === symbolName) {
|
|
523
|
+
return true;
|
|
524
|
+
}
|
|
525
|
+
if (ts.isVariableStatement(node) &&
|
|
526
|
+
node.declarationList.declarations.some((decl) => {
|
|
527
|
+
return isNamedNode(decl) && decl.name.text === symbolName;
|
|
528
|
+
})) {
|
|
529
|
+
return true;
|
|
530
|
+
}
|
|
531
|
+
if (ts.isImportDeclaration(node) &&
|
|
532
|
+
ts.isStringLiteralLike(node.moduleSpecifier) &&
|
|
533
|
+
node.moduleSpecifier.text !== skipModule &&
|
|
534
|
+
node.importClause?.namedBindings &&
|
|
535
|
+
ts.isNamedImports(node.importClause.namedBindings) &&
|
|
536
|
+
node.importClause.namedBindings.elements.some((el) => el.name.text === symbolName)) {
|
|
537
|
+
return true;
|
|
538
|
+
}
|
|
539
|
+
}
|
|
540
|
+
return false;
|
|
541
|
+
}
|
|
542
|
+
exports.hasTopLevelIdentifier = hasTopLevelIdentifier;
|
|
543
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ast-utils.js","sourceRoot":"","sources":["../../../../../../../packages/schematics/angular/utility/ast-utils.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Google LLC 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 */\n\nimport { tags } from '@angular-devkit/core';\nimport * as ts from '../third_party/github.com/Microsoft/TypeScript/lib/typescript';\nimport { Change, InsertChange, NoopChange } from './change';\n\n/**\n * Add Import `import { symbolName } from fileName` if the import doesn't exit\n * already. Assumes fileToEdit can be resolved and accessed.\n * @param fileToEdit File we want to add import to.\n * @param symbolName Item to import.\n * @param fileName Path to the file.\n * @param isDefault If true, import follows style for importing default exports.\n * @param alias Alias that the symbol should be inserted under.\n * @return Change\n */\nexport function insertImport(\n  source: ts.SourceFile,\n  fileToEdit: string,\n  symbolName: string,\n  fileName: string,\n  isDefault = false,\n  alias?: string,\n): Change {\n  const rootNode = source;\n  const allImports = findNodes(rootNode, ts.isImportDeclaration);\n  const importExpression = alias ? `${symbolName} as ${alias}` : symbolName;\n\n  // get nodes that map to import statements from the file fileName\n  const relevantImports = allImports.filter((node) => {\n    return ts.isStringLiteralLike(node.moduleSpecifier) && node.moduleSpecifier.text === fileName;\n  });\n\n  if (relevantImports.length > 0) {\n    const hasNamespaceImport = relevantImports.some((node) => {\n      return node.importClause?.namedBindings?.kind === ts.SyntaxKind.NamespaceImport;\n    });\n\n    // if imports * from fileName, don't add symbolName\n    if (hasNamespaceImport) {\n      return new NoopChange();\n    }\n\n    const imports = relevantImports.flatMap((node) => {\n      return node.importClause?.namedBindings && ts.isNamedImports(node.importClause.namedBindings)\n        ? node.importClause.namedBindings.elements\n        : [];\n    });\n\n    // insert import if it's not there\n    if (!imports.some((node) => (node.propertyName || node.name).text === symbolName)) {\n      const fallbackPos =\n        findNodes(relevantImports[0], ts.SyntaxKind.CloseBraceToken)[0].getStart() ||\n        findNodes(relevantImports[0], ts.SyntaxKind.FromKeyword)[0].getStart();\n\n      return insertAfterLastOccurrence(imports, `, ${importExpression}`, fileToEdit, fallbackPos);\n    }\n\n    return new NoopChange();\n  }\n\n  // no such import declaration exists\n  const useStrict = findNodes(rootNode, ts.isStringLiteral).filter((n) => n.text === 'use strict');\n  let fallbackPos = 0;\n  if (useStrict.length > 0) {\n    fallbackPos = useStrict[0].end;\n  }\n  const open = isDefault ? '' : '{ ';\n  const close = isDefault ? '' : ' }';\n  // if there are no imports or 'use strict' statement, insert import at beginning of file\n  const insertAtBeginning = allImports.length === 0 && useStrict.length === 0;\n  const separator = insertAtBeginning ? '' : ';\\n';\n  const toInsert =\n    `${separator}import ${open}${importExpression}${close}` +\n    ` from '${fileName}'${insertAtBeginning ? ';\\n' : ''}`;\n\n  return insertAfterLastOccurrence(\n    allImports,\n    toInsert,\n    fileToEdit,\n    fallbackPos,\n    ts.SyntaxKind.StringLiteral,\n  );\n}\n\n/**\n * Find all nodes from the AST in the subtree of node of SyntaxKind kind.\n * @param node\n * @param kind\n * @param max The maximum number of items to return.\n * @param recursive Continue looking for nodes of kind recursive until end\n * the last child even when node of kind has been found.\n * @return all nodes of kind, or [] if none is found\n */\nexport function findNodes(\n  node: ts.Node,\n  kind: ts.SyntaxKind,\n  max?: number,\n  recursive?: boolean,\n): ts.Node[];\n\n/**\n * Find all nodes from the AST in the subtree that satisfy a type guard.\n * @param node\n * @param guard\n * @param max The maximum number of items to return.\n * @param recursive Continue looking for nodes of kind recursive until end\n * the last child even when node of kind has been found.\n * @return all nodes that satisfy the type guard, or [] if none is found\n */\nexport function findNodes<T extends ts.Node>(\n  node: ts.Node,\n  guard: (node: ts.Node) => node is T,\n  max?: number,\n  recursive?: boolean,\n): T[];\n\nexport function findNodes<T extends ts.Node>(\n  node: ts.Node,\n  kindOrGuard: ts.SyntaxKind | ((node: ts.Node) => node is T),\n  max = Infinity,\n  recursive = false,\n): T[] {\n  if (!node || max == 0) {\n    return [];\n  }\n\n  const test =\n    typeof kindOrGuard === 'function'\n      ? kindOrGuard\n      : (node: ts.Node): node is T => node.kind === kindOrGuard;\n\n  const arr: T[] = [];\n  if (test(node)) {\n    arr.push(node);\n    max--;\n  }\n  if (max > 0 && (recursive || !test(node))) {\n    for (const child of node.getChildren()) {\n      findNodes(child, test, max, recursive).forEach((node) => {\n        if (max > 0) {\n          arr.push(node);\n        }\n        max--;\n      });\n\n      if (max <= 0) {\n        break;\n      }\n    }\n  }\n\n  return arr;\n}\n\n/**\n * Get all the nodes from a source.\n * @param sourceFile The source file object.\n * @returns {Array<ts.Node>} An array of all the nodes in the source.\n */\nexport function getSourceNodes(sourceFile: ts.SourceFile): ts.Node[] {\n  const nodes: ts.Node[] = [sourceFile];\n  const result: ts.Node[] = [];\n\n  while (nodes.length > 0) {\n    const node = nodes.shift();\n\n    if (node) {\n      result.push(node);\n      if (node.getChildCount(sourceFile) >= 0) {\n        nodes.unshift(...node.getChildren());\n      }\n    }\n  }\n\n  return result;\n}\n\nexport function findNode(node: ts.Node, kind: ts.SyntaxKind, text: string): ts.Node | null {\n  if (node.kind === kind && node.getText() === text) {\n    return node;\n  }\n\n  let foundNode: ts.Node | null = null;\n  ts.forEachChild(node, (childNode) => {\n    foundNode = foundNode || findNode(childNode, kind, text);\n  });\n\n  return foundNode;\n}\n\n/**\n * Helper for sorting nodes.\n * @return function to sort nodes in increasing order of position in sourceFile\n */\nfunction nodesByPosition(first: ts.Node, second: ts.Node): number {\n  return first.getStart() - second.getStart();\n}\n\n/**\n * Insert `toInsert` after the last occurence of `ts.SyntaxKind[nodes[i].kind]`\n * or after the last of occurence of `syntaxKind` if the last occurence is a sub child\n * of ts.SyntaxKind[nodes[i].kind] and save the changes in file.\n *\n * @param nodes insert after the last occurence of nodes\n * @param toInsert string to insert\n * @param file file to insert changes into\n * @param fallbackPos position to insert if toInsert happens to be the first occurence\n * @param syntaxKind the ts.SyntaxKind of the subchildren to insert after\n * @return Change instance\n * @throw Error if toInsert is first occurence but fall back is not set\n */\nexport function insertAfterLastOccurrence(\n  nodes: ts.Node[] | ts.NodeArray<ts.Node>,\n  toInsert: string,\n  file: string,\n  fallbackPos: number,\n  syntaxKind?: ts.SyntaxKind,\n): Change {\n  let lastItem: ts.Node | undefined;\n  for (const node of nodes) {\n    if (!lastItem || lastItem.getStart() < node.getStart()) {\n      lastItem = node;\n    }\n  }\n  if (syntaxKind && lastItem) {\n    lastItem = findNodes(lastItem, syntaxKind).sort(nodesByPosition).pop();\n  }\n  if (!lastItem && fallbackPos == undefined) {\n    throw new Error(`tried to insert ${toInsert} as first occurence with no fallback position`);\n  }\n  const lastItemPosition: number = lastItem ? lastItem.getEnd() : fallbackPos;\n\n  return new InsertChange(file, lastItemPosition, toInsert);\n}\n\nfunction _angularImportsFromNode(node: ts.ImportDeclaration): { [name: string]: string } {\n  const ms = node.moduleSpecifier;\n  let modulePath: string;\n  switch (ms.kind) {\n    case ts.SyntaxKind.StringLiteral:\n      modulePath = (ms as ts.StringLiteral).text;\n      break;\n    default:\n      return {};\n  }\n\n  if (!modulePath.startsWith('@angular/')) {\n    return {};\n  }\n\n  if (node.importClause) {\n    if (node.importClause.name) {\n      // This is of the form `import Name from 'path'`. Ignore.\n      return {};\n    } else if (node.importClause.namedBindings) {\n      const nb = node.importClause.namedBindings;\n      if (nb.kind == ts.SyntaxKind.NamespaceImport) {\n        // This is of the form `import * as name from 'path'`. Return `name.`.\n        return {\n          [nb.name.text + '.']: modulePath,\n        };\n      } else {\n        // This is of the form `import {a,b,c} from 'path'`\n        const namedImports = nb;\n\n        return namedImports.elements\n          .map((is: ts.ImportSpecifier) => (is.propertyName ? is.propertyName.text : is.name.text))\n          .reduce((acc: { [name: string]: string }, curr: string) => {\n            acc[curr] = modulePath;\n\n            return acc;\n          }, {});\n      }\n    }\n\n    return {};\n  } else {\n    // This is of the form `import 'path';`. Nothing to do.\n    return {};\n  }\n}\n\nexport function getDecoratorMetadata(\n  source: ts.SourceFile,\n  identifier: string,\n  module: string,\n): ts.Node[] {\n  const angularImports = findNodes(source, ts.isImportDeclaration)\n    .map((node) => _angularImportsFromNode(node))\n    .reduce((acc, current) => {\n      for (const key of Object.keys(current)) {\n        acc[key] = current[key];\n      }\n\n      return acc;\n    }, {});\n\n  return getSourceNodes(source)\n    .filter((node) => {\n      return (\n        node.kind == ts.SyntaxKind.Decorator &&\n        (node as ts.Decorator).expression.kind == ts.SyntaxKind.CallExpression\n      );\n    })\n    .map((node) => (node as ts.Decorator).expression as ts.CallExpression)\n    .filter((expr) => {\n      if (expr.expression.kind == ts.SyntaxKind.Identifier) {\n        const id = expr.expression as ts.Identifier;\n\n        return id.text == identifier && angularImports[id.text] === module;\n      } else if (expr.expression.kind == ts.SyntaxKind.PropertyAccessExpression) {\n        // This covers foo.NgModule when importing * as foo.\n        const paExpr = expr.expression as ts.PropertyAccessExpression;\n        // If the left expression is not an identifier, just give up at that point.\n        if (paExpr.expression.kind !== ts.SyntaxKind.Identifier) {\n          return false;\n        }\n\n        const id = paExpr.name.text;\n        const moduleId = (paExpr.expression as ts.Identifier).text;\n\n        return id === identifier && angularImports[moduleId + '.'] === module;\n      }\n\n      return false;\n    })\n    .filter(\n      (expr) =>\n        expr.arguments[0] && expr.arguments[0].kind == ts.SyntaxKind.ObjectLiteralExpression,\n    )\n    .map((expr) => expr.arguments[0] as ts.ObjectLiteralExpression);\n}\n\nexport function getMetadataField(\n  node: ts.ObjectLiteralExpression,\n  metadataField: string,\n): ts.ObjectLiteralElement[] {\n  return (\n    node.properties\n      .filter(ts.isPropertyAssignment)\n      // Filter out every fields that's not \"metadataField\". Also handles string literals\n      // (but not expressions).\n      .filter(({ name }) => {\n        return (ts.isIdentifier(name) || ts.isStringLiteral(name)) && name.text === metadataField;\n      })\n  );\n}\n\nexport function addSymbolToNgModuleMetadata(\n  source: ts.SourceFile,\n  ngModulePath: string,\n  metadataField: string,\n  symbolName: string,\n  importPath: string | null = null,\n): Change[] {\n  const nodes = getDecoratorMetadata(source, 'NgModule', '@angular/core');\n  const node = nodes[0];\n\n  // Find the decorator declaration.\n  if (!node || !ts.isObjectLiteralExpression(node)) {\n    return [];\n  }\n\n  // Get all the children property assignment of object literals.\n  const matchingProperties = getMetadataField(node, metadataField);\n\n  if (matchingProperties.length == 0) {\n    // We haven't found the field in the metadata declaration. Insert a new field.\n    let position: number;\n    let toInsert: string;\n    if (node.properties.length == 0) {\n      position = node.getEnd() - 1;\n      toInsert = `\\n  ${metadataField}: [\\n${tags.indentBy(4)`${symbolName}`}\\n  ]\\n`;\n    } else {\n      const childNode = node.properties[node.properties.length - 1];\n      position = childNode.getEnd();\n      // Get the indentation of the last element, if any.\n      const text = childNode.getFullText(source);\n      const matches = text.match(/^(\\r?\\n)(\\s*)/);\n      if (matches) {\n        toInsert =\n          `,${matches[0]}${metadataField}: [${matches[1]}` +\n          `${tags.indentBy(matches[2].length + 2)`${symbolName}`}${matches[0]}]`;\n      } else {\n        toInsert = `, ${metadataField}: [${symbolName}]`;\n      }\n    }\n    if (importPath !== null) {\n      return [\n        new InsertChange(ngModulePath, position, toInsert),\n        insertImport(source, ngModulePath, symbolName.replace(/\\..*$/, ''), importPath),\n      ];\n    } else {\n      return [new InsertChange(ngModulePath, position, toInsert)];\n    }\n  }\n  const assignment = matchingProperties[0];\n\n  // If it's not an array, nothing we can do really.\n  if (\n    !ts.isPropertyAssignment(assignment) ||\n    !ts.isArrayLiteralExpression(assignment.initializer)\n  ) {\n    return [];\n  }\n\n  let expresssion: ts.Expression | ts.ArrayLiteralExpression;\n  const assignmentInit = assignment.initializer;\n  const elements = assignmentInit.elements;\n\n  if (elements.length) {\n    const symbolsArray = elements.map((node) => tags.oneLine`${node.getText()}`);\n    if (symbolsArray.includes(tags.oneLine`${symbolName}`)) {\n      return [];\n    }\n\n    expresssion = elements[elements.length - 1];\n  } else {\n    expresssion = assignmentInit;\n  }\n\n  let toInsert: string;\n  let position = expresssion.getEnd();\n  if (ts.isArrayLiteralExpression(expresssion)) {\n    // We found the field but it's empty. Insert it just before the `]`.\n    position--;\n    toInsert = `\\n${tags.indentBy(4)`${symbolName}`}\\n  `;\n  } else {\n    // Get the indentation of the last element, if any.\n    const text = expresssion.getFullText(source);\n    const matches = text.match(/^(\\r?\\n)(\\s*)/);\n    if (matches) {\n      toInsert = `,${matches[1]}${tags.indentBy(matches[2].length)`${symbolName}`}`;\n    } else {\n      toInsert = `, ${symbolName}`;\n    }\n  }\n\n  if (importPath !== null) {\n    return [\n      new InsertChange(ngModulePath, position, toInsert),\n      insertImport(source, ngModulePath, symbolName.replace(/\\..*$/, ''), importPath),\n    ];\n  }\n\n  return [new InsertChange(ngModulePath, position, toInsert)];\n}\n\n/**\n * Custom function to insert a declaration (component, pipe, directive)\n * into NgModule declarations. It also imports the component.\n */\nexport function addDeclarationToModule(\n  source: ts.SourceFile,\n  modulePath: string,\n  classifiedName: string,\n  importPath: string,\n): Change[] {\n  return addSymbolToNgModuleMetadata(\n    source,\n    modulePath,\n    'declarations',\n    classifiedName,\n    importPath,\n  );\n}\n\n/**\n * Custom function to insert an NgModule into NgModule imports. It also imports the module.\n */\nexport function addImportToModule(\n  source: ts.SourceFile,\n  modulePath: string,\n  classifiedName: string,\n  importPath: string,\n): Change[] {\n  return addSymbolToNgModuleMetadata(source, modulePath, 'imports', classifiedName, importPath);\n}\n\n/**\n * Custom function to insert a provider into NgModule. It also imports it.\n */\nexport function addProviderToModule(\n  source: ts.SourceFile,\n  modulePath: string,\n  classifiedName: string,\n  importPath: string,\n): Change[] {\n  return addSymbolToNgModuleMetadata(source, modulePath, 'providers', classifiedName, importPath);\n}\n\n/**\n * Custom function to insert an export into NgModule. It also imports it.\n */\nexport function addExportToModule(\n  source: ts.SourceFile,\n  modulePath: string,\n  classifiedName: string,\n  importPath: string,\n): Change[] {\n  return addSymbolToNgModuleMetadata(source, modulePath, 'exports', classifiedName, importPath);\n}\n\n/**\n * Custom function to insert an export into NgModule. It also imports it.\n */\nexport function addBootstrapToModule(\n  source: ts.SourceFile,\n  modulePath: string,\n  classifiedName: string,\n  importPath: string,\n): Change[] {\n  return addSymbolToNgModuleMetadata(source, modulePath, 'bootstrap', classifiedName, importPath);\n}\n\n/**\n * Determine if an import already exists.\n */\nexport function isImported(\n  source: ts.SourceFile,\n  classifiedName: string,\n  importPath: string,\n): boolean {\n  const allNodes = getSourceNodes(source);\n  const matchingNodes = allNodes\n    .filter(ts.isImportDeclaration)\n    .filter(\n      (imp) => ts.isStringLiteral(imp.moduleSpecifier) && imp.moduleSpecifier.text === importPath,\n    )\n    .filter((imp) => {\n      if (!imp.importClause) {\n        return false;\n      }\n      const nodes = findNodes(imp.importClause, ts.isImportSpecifier).filter(\n        (n) => n.getText() === classifiedName,\n      );\n\n      return nodes.length > 0;\n    });\n\n  return matchingNodes.length > 0;\n}\n\n/**\n * Returns the RouterModule declaration from NgModule metadata, if any.\n */\nexport function getRouterModuleDeclaration(source: ts.SourceFile): ts.Expression | undefined {\n  const result = getDecoratorMetadata(source, 'NgModule', '@angular/core');\n  const node = result[0];\n  if (!node || !ts.isObjectLiteralExpression(node)) {\n    return undefined;\n  }\n\n  const matchingProperties = getMetadataField(node, 'imports');\n  if (!matchingProperties) {\n    return;\n  }\n\n  const assignment = matchingProperties[0] as ts.PropertyAssignment;\n\n  if (assignment.initializer.kind !== ts.SyntaxKind.ArrayLiteralExpression) {\n    return;\n  }\n\n  const arrLiteral = assignment.initializer as ts.ArrayLiteralExpression;\n\n  return arrLiteral.elements\n    .filter((el) => el.kind === ts.SyntaxKind.CallExpression)\n    .find((el) => (el as ts.Identifier).getText().startsWith('RouterModule'));\n}\n\n/**\n * Adds a new route declaration to a router module (i.e. has a RouterModule declaration)\n */\nexport function addRouteDeclarationToModule(\n  source: ts.SourceFile,\n  fileToAdd: string,\n  routeLiteral: string,\n): Change {\n  const routerModuleExpr = getRouterModuleDeclaration(source);\n  if (!routerModuleExpr) {\n    throw new Error(\n      `Couldn't find a route declaration in ${fileToAdd}.\\n` +\n        `Use the '--module' option to specify a different routing module.`,\n    );\n  }\n  const scopeConfigMethodArgs = (routerModuleExpr as ts.CallExpression).arguments;\n  if (!scopeConfigMethodArgs.length) {\n    const { line } = source.getLineAndCharacterOfPosition(routerModuleExpr.getStart());\n    throw new Error(\n      `The router module method doesn't have arguments ` + `at line ${line} in ${fileToAdd}`,\n    );\n  }\n\n  let routesArr: ts.ArrayLiteralExpression | undefined;\n  const routesArg = scopeConfigMethodArgs[0];\n\n  // Check if the route declarations array is\n  // an inlined argument of RouterModule or a standalone variable\n  if (ts.isArrayLiteralExpression(routesArg)) {\n    routesArr = routesArg;\n  } else {\n    const routesVarName = routesArg.getText();\n    let routesVar;\n    if (routesArg.kind === ts.SyntaxKind.Identifier) {\n      routesVar = source.statements.filter(ts.isVariableStatement).find((v) => {\n        return v.declarationList.declarations[0].name.getText() === routesVarName;\n      });\n    }\n\n    if (!routesVar) {\n      const { line } = source.getLineAndCharacterOfPosition(routesArg.getStart());\n      throw new Error(\n        `No route declaration array was found that corresponds ` +\n          `to router module at line ${line} in ${fileToAdd}`,\n      );\n    }\n\n    routesArr = findNodes(\n      routesVar,\n      ts.SyntaxKind.ArrayLiteralExpression,\n      1,\n    )[0] as ts.ArrayLiteralExpression;\n  }\n\n  const occurrencesCount = routesArr.elements.length;\n  const text = routesArr.getFullText(source);\n\n  let route: string = routeLiteral;\n  let insertPos = routesArr.elements.pos;\n\n  if (occurrencesCount > 0) {\n    const lastRouteLiteral = [...routesArr.elements].pop() as ts.Expression;\n    const lastRouteIsWildcard =\n      ts.isObjectLiteralExpression(lastRouteLiteral) &&\n      lastRouteLiteral.properties.some(\n        (n) =>\n          ts.isPropertyAssignment(n) &&\n          ts.isIdentifier(n.name) &&\n          n.name.text === 'path' &&\n          ts.isStringLiteral(n.initializer) &&\n          n.initializer.text === '**',\n      );\n\n    const indentation = text.match(/\\r?\\n(\\r?)\\s*/) || [];\n    const routeText = `${indentation[0] || ' '}${routeLiteral}`;\n\n    // Add the new route before the wildcard route\n    // otherwise we'll always redirect to the wildcard route\n    if (lastRouteIsWildcard) {\n      insertPos = lastRouteLiteral.pos;\n      route = `${routeText},`;\n    } else {\n      insertPos = lastRouteLiteral.end;\n      route = `,${routeText}`;\n    }\n  }\n\n  return new InsertChange(fileToAdd, insertPos, route);\n}\n\n/** Asserts if the specified node is a named declaration (e.g. class, interface). */\nfunction isNamedNode(\n  node: ts.Node & { name?: ts.Node },\n): node is ts.Node & { name: ts.Identifier } {\n  return !!node.name && ts.isIdentifier(node.name);\n}\n\n/**\n * Determines if a SourceFile has a top-level declaration whose name matches a specific symbol.\n * Can be used to avoid conflicts when inserting new imports into a file.\n * @param sourceFile File in which to search.\n * @param symbolName Name of the symbol to search for.\n * @param skipModule Path of the module that the symbol may have been imported from. Used to\n * avoid false positives where the same symbol we're looking for may have been imported.\n */\nexport function hasTopLevelIdentifier(\n  sourceFile: ts.SourceFile,\n  symbolName: string,\n  skipModule: string | null = null,\n): boolean {\n  for (const node of sourceFile.statements) {\n    if (isNamedNode(node) && node.name.text === symbolName) {\n      return true;\n    }\n\n    if (\n      ts.isVariableStatement(node) &&\n      node.declarationList.declarations.some((decl) => {\n        return isNamedNode(decl) && decl.name.text === symbolName;\n      })\n    ) {\n      return true;\n    }\n\n    if (\n      ts.isImportDeclaration(node) &&\n      ts.isStringLiteralLike(node.moduleSpecifier) &&\n      node.moduleSpecifier.text !== skipModule &&\n      node.importClause?.namedBindings &&\n      ts.isNamedImports(node.importClause.namedBindings) &&\n      node.importClause.namedBindings.elements.some((el) => el.name.text === symbolName)\n    ) {\n      return true;\n    }\n  }\n\n  return false;\n}\n"]}
|
package/utility/dependencies.js
CHANGED
|
@@ -16,7 +16,7 @@ var NodeDependencyType;
|
|
|
16
16
|
NodeDependencyType["Dev"] = "devDependencies";
|
|
17
17
|
NodeDependencyType["Peer"] = "peerDependencies";
|
|
18
18
|
NodeDependencyType["Optional"] = "optionalDependencies";
|
|
19
|
-
})(NodeDependencyType
|
|
19
|
+
})(NodeDependencyType || (exports.NodeDependencyType = NodeDependencyType = {}));
|
|
20
20
|
const ALL_DEPENDENCY_TYPE = [
|
|
21
21
|
NodeDependencyType.Default,
|
|
22
22
|
NodeDependencyType.Dev,
|
|
@@ -54,4 +54,4 @@ function getPackageJsonDependency(tree, name, pkgJsonPath = PKG_JSON_PATH) {
|
|
|
54
54
|
return null;
|
|
55
55
|
}
|
|
56
56
|
exports.getPackageJsonDependency = getPackageJsonDependency;
|
|
57
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
57
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGVwZW5kZW5jaWVzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvc2NoZW1hdGljcy9hbmd1bGFyL3V0aWxpdHkvZGVwZW5kZW5jaWVzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQTs7Ozs7O0dBTUc7OztBQUdILDJDQUF1QztBQUV2QyxNQUFNLGFBQWEsR0FBRyxlQUFlLENBQUM7QUFDdEMsSUFBWSxrQkFLWDtBQUxELFdBQVksa0JBQWtCO0lBQzVCLDhDQUF3QixDQUFBO0lBQ3hCLDZDQUF1QixDQUFBO0lBQ3ZCLCtDQUF5QixDQUFBO0lBQ3pCLHVEQUFpQyxDQUFBO0FBQ25DLENBQUMsRUFMVyxrQkFBa0Isa0NBQWxCLGtCQUFrQixRQUs3QjtBQVNELE1BQU0sbUJBQW1CLEdBQUc7SUFDMUIsa0JBQWtCLENBQUMsT0FBTztJQUMxQixrQkFBa0IsQ0FBQyxHQUFHO0lBQ3RCLGtCQUFrQixDQUFDLFFBQVE7SUFDM0Isa0JBQWtCLENBQUMsSUFBSTtDQUN4QixDQUFDO0FBRUYsU0FBZ0Isd0JBQXdCLENBQ3RDLElBQVUsRUFDVixVQUEwQixFQUMxQixXQUFXLEdBQUcsYUFBYTtJQUUzQixNQUFNLElBQUksR0FBRyxJQUFJLG9CQUFRLENBQUMsSUFBSSxFQUFFLFdBQVcsQ0FBQyxDQUFDO0lBRTdDLE1BQU0sRUFBRSxTQUFTLEVBQUUsSUFBSSxFQUFFLElBQUksRUFBRSxPQUFPLEVBQUUsR0FBRyxVQUFVLENBQUM7SUFDdEQsTUFBTSxJQUFJLEdBQUcsQ0FBQyxJQUFJLEVBQUUsSUFBSSxDQUFDLENBQUM7SUFDMUIsSUFBSSxTQUFTLElBQUksQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLElBQUksQ0FBQyxFQUFFO1FBQ2hDLElBQUksQ0FBQyxNQUFNLENBQUMsSUFBSSxFQUFFLE9BQU8sQ0FBQyxDQUFDO0tBQzVCO0FBQ0gsQ0FBQztBQVpELDREQVlDO0FBRUQsU0FBZ0IsMkJBQTJCLENBQ3pDLElBQVUsRUFDVixJQUFZLEVBQ1osV0FBVyxHQUFHLGFBQWE7SUFFM0IsTUFBTSxJQUFJLEdBQUcsSUFBSSxvQkFBUSxDQUFDLElBQUksRUFBRSxXQUFXLENBQUMsQ0FBQztJQUU3QyxLQUFLLE1BQU0sT0FBTyxJQUFJLG1CQUFtQixFQUFFO1FBQ3pDLElBQUksQ0FBQyxNQUFNLENBQUMsQ0FBQyxPQUFPLEVBQUUsSUFBSSxDQUFDLENBQUMsQ0FBQztLQUM5QjtBQUNILENBQUM7QUFWRCxrRUFVQztBQUVELFNBQWdCLHdCQUF3QixDQUN0QyxJQUFVLEVBQ1YsSUFBWSxFQUNaLFdBQVcsR0FBRyxhQUFhO0lBRTNCLE1BQU0sSUFBSSxHQUFHLElBQUksb0JBQVEsQ0FBQyxJQUFJLEVBQUUsV0FBVyxDQUFDLENBQUM7SUFFN0MsS0FBSyxNQUFNLE9BQU8sSUFBSSxtQkFBbUIsRUFBRTtRQUN6QyxNQUFNLE9BQU8sR0FBRyxJQUFJLENBQUMsR0FBRyxDQUFDLENBQUMsT0FBTyxFQUFFLElBQUksQ0FBQyxDQUFDLENBQUM7UUFFMUMsSUFBSSxPQUFPLE9BQU8sS0FBSyxRQUFRLEVBQUU7WUFDL0IsT0FBTztnQkFDTCxJQUFJLEVBQUUsT0FBTztnQkFDYixJQUFJLEVBQUUsSUFBSTtnQkFDVixPQUFPO2FBQ1IsQ0FBQztTQUNIO0tBQ0Y7SUFFRCxPQUFPLElBQUksQ0FBQztBQUNkLENBQUM7QUFwQkQsNERBb0JDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBAbGljZW5zZVxuICogQ29weXJpZ2h0IEdvb2dsZSBMTEMgQWxsIFJpZ2h0cyBSZXNlcnZlZC5cbiAqXG4gKiBVc2Ugb2YgdGhpcyBzb3VyY2UgY29kZSBpcyBnb3Zlcm5lZCBieSBhbiBNSVQtc3R5bGUgbGljZW5zZSB0aGF0IGNhbiBiZVxuICogZm91bmQgaW4gdGhlIExJQ0VOU0UgZmlsZSBhdCBodHRwczovL2FuZ3VsYXIuaW8vbGljZW5zZVxuICovXG5cbmltcG9ydCB7IFRyZWUgfSBmcm9tICdAYW5ndWxhci1kZXZraXQvc2NoZW1hdGljcyc7XG5pbXBvcnQgeyBKU09ORmlsZSB9IGZyb20gJy4vanNvbi1maWxlJztcblxuY29uc3QgUEtHX0pTT05fUEFUSCA9ICcvcGFja2FnZS5qc29uJztcbmV4cG9ydCBlbnVtIE5vZGVEZXBlbmRlbmN5VHlwZSB7XG4gIERlZmF1bHQgPSAnZGVwZW5kZW5jaWVzJyxcbiAgRGV2ID0gJ2RldkRlcGVuZGVuY2llcycsXG4gIFBlZXIgPSAncGVlckRlcGVuZGVuY2llcycsXG4gIE9wdGlvbmFsID0gJ29wdGlvbmFsRGVwZW5kZW5jaWVzJyxcbn1cblxuZXhwb3J0IGludGVyZmFjZSBOb2RlRGVwZW5kZW5jeSB7XG4gIHR5cGU6IE5vZGVEZXBlbmRlbmN5VHlwZTtcbiAgbmFtZTogc3RyaW5nO1xuICB2ZXJzaW9uOiBzdHJpbmc7XG4gIG92ZXJ3cml0ZT86IGJvb2xlYW47XG59XG5cbmNvbnN0IEFMTF9ERVBFTkRFTkNZX1RZUEUgPSBbXG4gIE5vZGVEZXBlbmRlbmN5VHlwZS5EZWZhdWx0LFxuICBOb2RlRGVwZW5kZW5jeVR5cGUuRGV2LFxuICBOb2RlRGVwZW5kZW5jeVR5cGUuT3B0aW9uYWwsXG4gIE5vZGVEZXBlbmRlbmN5VHlwZS5QZWVyLFxuXTtcblxuZXhwb3J0IGZ1bmN0aW9uIGFkZFBhY2thZ2VKc29uRGVwZW5kZW5jeShcbiAgdHJlZTogVHJlZSxcbiAgZGVwZW5kZW5jeTogTm9kZURlcGVuZGVuY3ksXG4gIHBrZ0pzb25QYXRoID0gUEtHX0pTT05fUEFUSCxcbik6IHZvaWQge1xuICBjb25zdCBqc29uID0gbmV3IEpTT05GaWxlKHRyZWUsIHBrZ0pzb25QYXRoKTtcblxuICBjb25zdCB7IG92ZXJ3cml0ZSwgdHlwZSwgbmFtZSwgdmVyc2lvbiB9ID0gZGVwZW5kZW5jeTtcbiAgY29uc3QgcGF0aCA9IFt0eXBlLCBuYW1lXTtcbiAgaWYgKG92ZXJ3cml0ZSB8fCAhanNvbi5nZXQocGF0aCkpIHtcbiAgICBqc29uLm1vZGlmeShwYXRoLCB2ZXJzaW9uKTtcbiAgfVxufVxuXG5leHBvcnQgZnVuY3Rpb24gcmVtb3ZlUGFja2FnZUpzb25EZXBlbmRlbmN5KFxuICB0cmVlOiBUcmVlLFxuICBuYW1lOiBzdHJpbmcsXG4gIHBrZ0pzb25QYXRoID0gUEtHX0pTT05fUEFUSCxcbik6IHZvaWQge1xuICBjb25zdCBqc29uID0gbmV3IEpTT05GaWxlKHRyZWUsIHBrZ0pzb25QYXRoKTtcblxuICBmb3IgKGNvbnN0IGRlcFR5cGUgb2YgQUxMX0RFUEVOREVOQ1lfVFlQRSkge1xuICAgIGpzb24ucmVtb3ZlKFtkZXBUeXBlLCBuYW1lXSk7XG4gIH1cbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGdldFBhY2thZ2VKc29uRGVwZW5kZW5jeShcbiAgdHJlZTogVHJlZSxcbiAgbmFtZTogc3RyaW5nLFxuICBwa2dKc29uUGF0aCA9IFBLR19KU09OX1BBVEgsXG4pOiBOb2RlRGVwZW5kZW5jeSB8IG51bGwge1xuICBjb25zdCBqc29uID0gbmV3IEpTT05GaWxlKHRyZWUsIHBrZ0pzb25QYXRoKTtcblxuICBmb3IgKGNvbnN0IGRlcFR5cGUgb2YgQUxMX0RFUEVOREVOQ1lfVFlQRSkge1xuICAgIGNvbnN0IHZlcnNpb24gPSBqc29uLmdldChbZGVwVHlwZSwgbmFtZV0pO1xuXG4gICAgaWYgKHR5cGVvZiB2ZXJzaW9uID09PSAnc3RyaW5nJykge1xuICAgICAgcmV0dXJuIHtcbiAgICAgICAgdHlwZTogZGVwVHlwZSxcbiAgICAgICAgbmFtZTogbmFtZSxcbiAgICAgICAgdmVyc2lvbixcbiAgICAgIH07XG4gICAgfVxuICB9XG5cbiAgcmV0dXJuIG51bGw7XG59XG4iXX0=
|
package/utility/dependency.js
CHANGED
|
@@ -43,7 +43,7 @@ var DependencyType;
|
|
|
43
43
|
DependencyType["Default"] = "dependencies";
|
|
44
44
|
DependencyType["Dev"] = "devDependencies";
|
|
45
45
|
DependencyType["Peer"] = "peerDependencies";
|
|
46
|
-
})(DependencyType
|
|
46
|
+
})(DependencyType || (exports.DependencyType = DependencyType = {}));
|
|
47
47
|
/**
|
|
48
48
|
* An enum used to specify the dependency installation behavior for the {@link addDependency}
|
|
49
49
|
* schematics rule. The installation behavior affects if and when {@link NodePackageInstallTask}
|
|
@@ -67,7 +67,7 @@ var InstallBehavior;
|
|
|
67
67
|
* Always schedule a {@link NodePackageInstallTask} when the rule is executed.
|
|
68
68
|
*/
|
|
69
69
|
InstallBehavior[InstallBehavior["Always"] = 2] = "Always";
|
|
70
|
-
})(InstallBehavior
|
|
70
|
+
})(InstallBehavior || (exports.InstallBehavior = InstallBehavior = {}));
|
|
71
71
|
/**
|
|
72
72
|
* An enum used to specify the existing dependency behavior for the {@link addDependency}
|
|
73
73
|
* schematics rule. The existing behavior affects whether the named dependency will be added
|
|
@@ -85,7 +85,7 @@ var ExistingBehavior;
|
|
|
85
85
|
* notify the user of the replacement.
|
|
86
86
|
*/
|
|
87
87
|
ExistingBehavior[ExistingBehavior["Replace"] = 1] = "Replace";
|
|
88
|
-
})(ExistingBehavior
|
|
88
|
+
})(ExistingBehavior || (exports.ExistingBehavior = ExistingBehavior = {}));
|
|
89
89
|
/**
|
|
90
90
|
* Adds a package as a dependency to a `package.json`. By default the `package.json` located
|
|
91
91
|
* at the schematic's root will be used. The `manifestPath` option can be used to explicitly specify
|
|
@@ -143,4 +143,4 @@ function addDependency(name, specifier, options = {}) {
|
|
|
143
143
|
};
|
|
144
144
|
}
|
|
145
145
|
exports.addDependency = addDependency;
|
|
146
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dependency.js","sourceRoot":"","sources":["../../../../../../../packages/schematics/angular/utility/dependency.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Google LLC 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 */\n\nimport { Rule, SchematicContext } from '@angular-devkit/schematics';\nimport { NodePackageInstallTask } from '@angular-devkit/schematics/tasks';\nimport * as path from 'path';\n\nconst installTasks = new WeakMap<SchematicContext, Set<string>>();\n\ninterface MinimalPackageManifest {\n  dependencies?: Record<string, string>;\n  devDependencies?: Record<string, string>;\n  peerDependencies?: Record<string, string>;\n}\n\n/**\n * An enum used to specify the type of a dependency found within a package manifest\n * file (`package.json`).\n */\nexport enum DependencyType {\n  Default = 'dependencies',\n  Dev = 'devDependencies',\n  Peer = 'peerDependencies',\n}\n\n/**\n * An enum used to specify the dependency installation behavior for the {@link addDependency}\n * schematics rule. The installation behavior affects if and when {@link NodePackageInstallTask}\n * will be scheduled when using the rule.\n */\nexport enum InstallBehavior {\n  /**\n   * No installation will occur as a result of the rule when specified.\n   *\n   * NOTE: This does not prevent other rules from scheduling a {@link NodePackageInstallTask}\n   * which may install the dependency.\n   */\n  None,\n  /**\n   * Automatically determine the need to schedule a {@link NodePackageInstallTask} based on\n   * previous usage of the {@link addDependency} within the schematic.\n   */\n  Auto,\n  /**\n   * Always schedule a {@link NodePackageInstallTask} when the rule is executed.\n   */\n  Always,\n}\n\n/**\n * An enum used to specify the existing dependency behavior for the {@link addDependency}\n * schematics rule. The existing behavior affects whether the named dependency will be added\n * to the `package.json` when the dependency is already present with a differing specifier.\n */\nexport enum ExistingBehavior {\n  /**\n   * The dependency will not be added or otherwise changed if it already exists.\n   */\n  Skip,\n  /**\n   * The dependency's existing specifier will be replaced with the specifier provided in the\n   * {@link addDependency} call. A warning will also be shown during schematic execution to\n   * notify the user of the replacement.\n   */\n  Replace,\n}\n\n/**\n * Adds a package as a dependency to a `package.json`. By default the `package.json` located\n * at the schematic's root will be used. The `manifestPath` option can be used to explicitly specify\n * a `package.json` in different location. The type of the dependency can also be specified instead\n * of the default of the `dependencies` section by using the `type` option for either `devDependencies`\n * or `peerDependencies`.\n *\n * When using this rule, {@link NodePackageInstallTask} does not need to be included directly by\n * a schematic. A package manager install task will be automatically scheduled as needed.\n *\n * @param name The name of the package to add.\n * @param specifier The package specifier for the package to add. Typically a SemVer range.\n * @param options An optional object that can contain the `type` of the dependency\n * and/or a path (`packageJsonPath`) of a manifest file (`package.json`) to modify.\n * @returns A Schematics {@link Rule}\n */\nexport function addDependency(\n  name: string,\n  specifier: string,\n  options: {\n    /**\n     * The type of the dependency determines the section of the `package.json` to which the\n     * dependency will be added. Defaults to {@link DependencyType.Default} (`dependencies`).\n     */\n    type?: DependencyType;\n    /**\n     * The path of the package manifest file (`package.json`) that will be modified.\n     * Defaults to `/package.json`.\n     */\n    packageJsonPath?: string;\n    /**\n     * The dependency installation behavior to use to determine whether a\n     * {@link NodePackageInstallTask} should be scheduled after adding the dependency.\n     * Defaults to {@link InstallBehavior.Auto}.\n     */\n    install?: InstallBehavior;\n    /**\n     * The behavior to use when the dependency already exists within the `package.json`.\n     * Defaults to {@link ExistingBehavior.Replace}.\n     */\n    existing?: ExistingBehavior;\n  } = {},\n): Rule {\n  const {\n    type = DependencyType.Default,\n    packageJsonPath = '/package.json',\n    install = InstallBehavior.Auto,\n    existing = ExistingBehavior.Replace,\n  } = options;\n\n  return (tree, context) => {\n    const manifest = tree.readJson(packageJsonPath) as MinimalPackageManifest;\n    const dependencySection = manifest[type];\n\n    if (!dependencySection) {\n      // Section is not present. The dependency can be added to a new object literal for the section.\n      manifest[type] = { [name]: specifier };\n    } else {\n      const existingSpecifier = dependencySection[name];\n\n      if (existingSpecifier === specifier) {\n        // Already present with same specifier\n        return;\n      }\n\n      if (existingSpecifier) {\n        // Already present but different specifier\n\n        if (existing === ExistingBehavior.Skip) {\n          return;\n        }\n\n        // ExistingBehavior.Replace is the only other behavior currently\n        context.logger.warn(\n          `Package dependency \"${name}\" already exists with a different specifier. ` +\n            `\"${existingSpecifier}\" will be replaced with \"${specifier}\".`,\n        );\n      }\n\n      // Add new dependency in alphabetical order\n      const entries = Object.entries(dependencySection);\n      entries.push([name, specifier]);\n      entries.sort((a, b) => a[0].localeCompare(b[0]));\n      manifest[type] = Object.fromEntries(entries);\n    }\n\n    tree.overwrite(packageJsonPath, JSON.stringify(manifest, null, 2));\n\n    const installPaths = installTasks.get(context) ?? new Set<string>();\n    if (\n      install === InstallBehavior.Always ||\n      (install === InstallBehavior.Auto && !installPaths.has(packageJsonPath))\n    ) {\n      context.addTask(\n        new NodePackageInstallTask({ workingDirectory: path.dirname(packageJsonPath) }),\n      );\n      installPaths.add(packageJsonPath);\n      installTasks.set(context, installPaths);\n    }\n  };\n}\n"]}
|
|
146
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dependency.js","sourceRoot":"","sources":["../../../../../../../packages/schematics/angular/utility/dependency.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Google LLC 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 */\n\nimport { Rule, SchematicContext } from '@angular-devkit/schematics';\nimport { NodePackageInstallTask } from '@angular-devkit/schematics/tasks';\nimport * as path from 'path';\n\nconst installTasks = new WeakMap<SchematicContext, Set<string>>();\n\ninterface MinimalPackageManifest {\n  dependencies?: Record<string, string>;\n  devDependencies?: Record<string, string>;\n  peerDependencies?: Record<string, string>;\n}\n\n/**\n * An enum used to specify the type of a dependency found within a package manifest\n * file (`package.json`).\n */\nexport enum DependencyType {\n  Default = 'dependencies',\n  Dev = 'devDependencies',\n  Peer = 'peerDependencies',\n}\n\n/**\n * An enum used to specify the dependency installation behavior for the {@link addDependency}\n * schematics rule. The installation behavior affects if and when {@link NodePackageInstallTask}\n * will be scheduled when using the rule.\n */\nexport enum InstallBehavior {\n  /**\n   * No installation will occur as a result of the rule when specified.\n   *\n   * NOTE: This does not prevent other rules from scheduling a {@link NodePackageInstallTask}\n   * which may install the dependency.\n   */\n  None,\n  /**\n   * Automatically determine the need to schedule a {@link NodePackageInstallTask} based on\n   * previous usage of the {@link addDependency} within the schematic.\n   */\n  Auto,\n  /**\n   * Always schedule a {@link NodePackageInstallTask} when the rule is executed.\n   */\n  Always,\n}\n\n/**\n * An enum used to specify the existing dependency behavior for the {@link addDependency}\n * schematics rule. The existing behavior affects whether the named dependency will be added\n * to the `package.json` when the dependency is already present with a differing specifier.\n */\nexport enum ExistingBehavior {\n  /**\n   * The dependency will not be added or otherwise changed if it already exists.\n   */\n  Skip,\n  /**\n   * The dependency's existing specifier will be replaced with the specifier provided in the\n   * {@link addDependency} call. A warning will also be shown during schematic execution to\n   * notify the user of the replacement.\n   */\n  Replace,\n}\n\n/**\n * Adds a package as a dependency to a `package.json`. By default the `package.json` located\n * at the schematic's root will be used. The `manifestPath` option can be used to explicitly specify\n * a `package.json` in different location. The type of the dependency can also be specified instead\n * of the default of the `dependencies` section by using the `type` option for either `devDependencies`\n * or `peerDependencies`.\n *\n * When using this rule, {@link NodePackageInstallTask} does not need to be included directly by\n * a schematic. A package manager install task will be automatically scheduled as needed.\n *\n * @param name The name of the package to add.\n * @param specifier The package specifier for the package to add. Typically a SemVer range.\n * @param options An optional object that can contain the `type` of the dependency\n * and/or a path (`packageJsonPath`) of a manifest file (`package.json`) to modify.\n * @returns A Schematics {@link Rule}\n */\nexport function addDependency(\n  name: string,\n  specifier: string,\n  options: {\n    /**\n     * The type of the dependency determines the section of the `package.json` to which the\n     * dependency will be added. Defaults to {@link DependencyType.Default} (`dependencies`).\n     */\n    type?: DependencyType;\n    /**\n     * The path of the package manifest file (`package.json`) that will be modified.\n     * Defaults to `/package.json`.\n     */\n    packageJsonPath?: string;\n    /**\n     * The dependency installation behavior to use to determine whether a\n     * {@link NodePackageInstallTask} should be scheduled after adding the dependency.\n     * Defaults to {@link InstallBehavior.Auto}.\n     */\n    install?: InstallBehavior;\n    /**\n     * The behavior to use when the dependency already exists within the `package.json`.\n     * Defaults to {@link ExistingBehavior.Replace}.\n     */\n    existing?: ExistingBehavior;\n  } = {},\n): Rule {\n  const {\n    type = DependencyType.Default,\n    packageJsonPath = '/package.json',\n    install = InstallBehavior.Auto,\n    existing = ExistingBehavior.Replace,\n  } = options;\n\n  return (tree, context) => {\n    const manifest = tree.readJson(packageJsonPath) as MinimalPackageManifest;\n    const dependencySection = manifest[type];\n\n    if (!dependencySection) {\n      // Section is not present. The dependency can be added to a new object literal for the section.\n      manifest[type] = { [name]: specifier };\n    } else {\n      const existingSpecifier = dependencySection[name];\n\n      if (existingSpecifier === specifier) {\n        // Already present with same specifier\n        return;\n      }\n\n      if (existingSpecifier) {\n        // Already present but different specifier\n\n        if (existing === ExistingBehavior.Skip) {\n          return;\n        }\n\n        // ExistingBehavior.Replace is the only other behavior currently\n        context.logger.warn(\n          `Package dependency \"${name}\" already exists with a different specifier. ` +\n            `\"${existingSpecifier}\" will be replaced with \"${specifier}\".`,\n        );\n      }\n\n      // Add new dependency in alphabetical order\n      const entries = Object.entries(dependencySection);\n      entries.push([name, specifier]);\n      entries.sort((a, b) => a[0].localeCompare(b[0]));\n      manifest[type] = Object.fromEntries(entries);\n    }\n\n    tree.overwrite(packageJsonPath, JSON.stringify(manifest, null, 2));\n\n    const installPaths = installTasks.get(context) ?? new Set<string>();\n    if (\n      install === InstallBehavior.Always ||\n      (install === InstallBehavior.Auto && !installPaths.has(packageJsonPath))\n    ) {\n      context.addTask(\n        new NodePackageInstallTask({ workingDirectory: path.dirname(packageJsonPath) }),\n      );\n      installPaths.add(packageJsonPath);\n      installTasks.set(context, installPaths);\n    }\n  };\n}\n"]}
|
package/utility/index.d.ts
CHANGED
|
@@ -7,4 +7,5 @@
|
|
|
7
7
|
*/
|
|
8
8
|
export { ProjectDefinition, TargetDefinition, WorkspaceDefinition, getWorkspace as readWorkspace, updateWorkspace, writeWorkspace, } from './workspace';
|
|
9
9
|
export { Builders as AngularBuilder } from './workspace-models';
|
|
10
|
+
export * from './standalone';
|
|
10
11
|
export { DependencyType, ExistingBehavior, InstallBehavior, addDependency } from './dependency';
|