Icard/angular-clarity-master(work.../node_modules/@schematics/angular/library/index.js

172 lines
21 KiB
JavaScript

"use strict";
/**
* @license
* Copyright Google LLC All Rights Reserved.
*
* Use of this source code is governed by an MIT-style license that can be
* found in the LICENSE file at https://angular.io/license
*/
Object.defineProperty(exports, "__esModule", { value: true });
const core_1 = require("@angular-devkit/core");
const schematics_1 = require("@angular-devkit/schematics");
const tasks_1 = require("@angular-devkit/schematics/tasks");
const dependencies_1 = require("../utility/dependencies");
const json_file_1 = require("../utility/json-file");
const latest_versions_1 = require("../utility/latest-versions");
const paths_1 = require("../utility/paths");
const workspace_1 = require("../utility/workspace");
const workspace_models_1 = require("../utility/workspace-models");
function updateTsConfig(packageName, ...paths) {
return (host) => {
if (!host.exists('tsconfig.json')) {
return host;
}
const file = new json_file_1.JSONFile(host, 'tsconfig.json');
const jsonPath = ['compilerOptions', 'paths', packageName];
const value = file.get(jsonPath);
file.modify(jsonPath, Array.isArray(value) ? [...value, ...paths] : paths);
};
}
function addDependenciesToPackageJson() {
return (host) => {
[
{
type: dependencies_1.NodeDependencyType.Dev,
name: '@angular/compiler-cli',
version: latest_versions_1.latestVersions.Angular,
},
{
type: dependencies_1.NodeDependencyType.Dev,
name: '@angular-devkit/build-angular',
version: latest_versions_1.latestVersions.DevkitBuildAngular,
},
{
type: dependencies_1.NodeDependencyType.Dev,
name: 'ng-packagr',
version: latest_versions_1.latestVersions['ng-packagr'],
},
{
type: dependencies_1.NodeDependencyType.Default,
name: 'tslib',
version: latest_versions_1.latestVersions['tslib'],
},
{
type: dependencies_1.NodeDependencyType.Dev,
name: 'typescript',
version: latest_versions_1.latestVersions['typescript'],
},
].forEach((dependency) => (0, dependencies_1.addPackageJsonDependency)(host, dependency));
return host;
};
}
function addLibToWorkspaceFile(options, projectRoot, projectName) {
return (0, workspace_1.updateWorkspace)((workspace) => {
workspace.projects.add({
name: projectName,
root: projectRoot,
sourceRoot: `${projectRoot}/src`,
projectType: workspace_models_1.ProjectType.Library,
prefix: options.prefix,
targets: {
build: {
builder: workspace_models_1.Builders.NgPackagr,
defaultConfiguration: 'production',
options: {
project: `${projectRoot}/ng-package.json`,
},
configurations: {
production: {
tsConfig: `${projectRoot}/tsconfig.lib.prod.json`,
},
development: {
tsConfig: `${projectRoot}/tsconfig.lib.json`,
},
},
},
test: {
builder: workspace_models_1.Builders.Karma,
options: {
tsConfig: `${projectRoot}/tsconfig.spec.json`,
polyfills: ['zone.js', 'zone.js/testing'],
},
},
},
});
});
}
function default_1(options) {
return async (host) => {
const prefix = options.prefix;
// If scoped project (i.e. "@foo/bar"), convert projectDir to "foo/bar".
const packageName = options.name;
if (/^@.*\/.*/.test(options.name)) {
const [, name] = options.name.split('/');
options.name = name;
}
const workspace = await (0, workspace_1.getWorkspace)(host);
const newProjectRoot = workspace.extensions.newProjectRoot || '';
let folderName = packageName.startsWith('@') ? packageName.slice(1) : packageName;
if (/[A-Z]/.test(folderName)) {
folderName = schematics_1.strings.dasherize(folderName);
}
const libDir = options.projectRoot !== undefined
? (0, core_1.normalize)(options.projectRoot)
: (0, core_1.join)((0, core_1.normalize)(newProjectRoot), folderName);
const distRoot = `dist/${folderName}`;
const sourceDir = `${libDir}/src/lib`;
const templateSource = (0, schematics_1.apply)((0, schematics_1.url)('./files'), [
(0, schematics_1.applyTemplates)({
...schematics_1.strings,
...options,
packageName,
libDir,
distRoot,
relativePathToWorkspaceRoot: (0, paths_1.relativePathToWorkspaceRoot)(libDir),
prefix,
angularLatestVersion: latest_versions_1.latestVersions.Angular.replace(/~|\^/, ''),
tsLibLatestVersion: latest_versions_1.latestVersions['tslib'].replace(/~|\^/, ''),
folderName,
}),
(0, schematics_1.move)(libDir),
]);
return (0, schematics_1.chain)([
(0, schematics_1.mergeWith)(templateSource),
addLibToWorkspaceFile(options, libDir, packageName),
options.skipPackageJson ? (0, schematics_1.noop)() : addDependenciesToPackageJson(),
options.skipTsConfig ? (0, schematics_1.noop)() : updateTsConfig(packageName, distRoot),
options.standalone
? (0, schematics_1.noop)()
: (0, schematics_1.schematic)('module', {
name: options.name,
commonModule: false,
flat: true,
path: sourceDir,
project: packageName,
}),
(0, schematics_1.schematic)('component', {
name: options.name,
selector: `${prefix}-${options.name}`,
inlineStyle: true,
inlineTemplate: true,
flat: true,
path: sourceDir,
export: true,
standalone: options.standalone,
project: packageName,
}),
(0, schematics_1.schematic)('service', {
name: options.name,
flat: true,
path: sourceDir,
project: packageName,
}),
(_tree, context) => {
if (!options.skipPackageJson && !options.skipInstall) {
context.addTask(new tasks_1.NodePackageInstallTask());
}
},
]);
};
}
exports.default = default_1;
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../../../packages/schematics/angular/library/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 { join, normalize } from '@angular-devkit/core';\nimport {\n  Rule,\n  SchematicContext,\n  Tree,\n  apply,\n  applyTemplates,\n  chain,\n  mergeWith,\n  move,\n  noop,\n  schematic,\n  strings,\n  url,\n} from '@angular-devkit/schematics';\nimport { NodePackageInstallTask } from '@angular-devkit/schematics/tasks';\nimport { NodeDependencyType, addPackageJsonDependency } from '../utility/dependencies';\nimport { JSONFile } from '../utility/json-file';\nimport { latestVersions } from '../utility/latest-versions';\nimport { relativePathToWorkspaceRoot } from '../utility/paths';\nimport { getWorkspace, updateWorkspace } from '../utility/workspace';\nimport { Builders, ProjectType } from '../utility/workspace-models';\nimport { Schema as LibraryOptions } from './schema';\n\nfunction updateTsConfig(packageName: string, ...paths: string[]) {\n  return (host: Tree) => {\n    if (!host.exists('tsconfig.json')) {\n      return host;\n    }\n\n    const file = new JSONFile(host, 'tsconfig.json');\n    const jsonPath = ['compilerOptions', 'paths', packageName];\n    const value = file.get(jsonPath);\n    file.modify(jsonPath, Array.isArray(value) ? [...value, ...paths] : paths);\n  };\n}\n\nfunction addDependenciesToPackageJson() {\n  return (host: Tree) => {\n    [\n      {\n        type: NodeDependencyType.Dev,\n        name: '@angular/compiler-cli',\n        version: latestVersions.Angular,\n      },\n      {\n        type: NodeDependencyType.Dev,\n        name: '@angular-devkit/build-angular',\n        version: latestVersions.DevkitBuildAngular,\n      },\n      {\n        type: NodeDependencyType.Dev,\n        name: 'ng-packagr',\n        version: latestVersions['ng-packagr'],\n      },\n      {\n        type: NodeDependencyType.Default,\n        name: 'tslib',\n        version: latestVersions['tslib'],\n      },\n      {\n        type: NodeDependencyType.Dev,\n        name: 'typescript',\n        version: latestVersions['typescript'],\n      },\n    ].forEach((dependency) => addPackageJsonDependency(host, dependency));\n\n    return host;\n  };\n}\n\nfunction addLibToWorkspaceFile(\n  options: LibraryOptions,\n  projectRoot: string,\n  projectName: string,\n): Rule {\n  return updateWorkspace((workspace) => {\n    workspace.projects.add({\n      name: projectName,\n      root: projectRoot,\n      sourceRoot: `${projectRoot}/src`,\n      projectType: ProjectType.Library,\n      prefix: options.prefix,\n      targets: {\n        build: {\n          builder: Builders.NgPackagr,\n          defaultConfiguration: 'production',\n          options: {\n            project: `${projectRoot}/ng-package.json`,\n          },\n          configurations: {\n            production: {\n              tsConfig: `${projectRoot}/tsconfig.lib.prod.json`,\n            },\n            development: {\n              tsConfig: `${projectRoot}/tsconfig.lib.json`,\n            },\n          },\n        },\n        test: {\n          builder: Builders.Karma,\n          options: {\n            tsConfig: `${projectRoot}/tsconfig.spec.json`,\n            polyfills: ['zone.js', 'zone.js/testing'],\n          },\n        },\n      },\n    });\n  });\n}\n\nexport default function (options: LibraryOptions): Rule {\n  return async (host: Tree) => {\n    const prefix = options.prefix;\n\n    // If scoped project (i.e. \"@foo/bar\"), convert projectDir to \"foo/bar\".\n    const packageName = options.name;\n    if (/^@.*\\/.*/.test(options.name)) {\n      const [, name] = options.name.split('/');\n      options.name = name;\n    }\n\n    const workspace = await getWorkspace(host);\n    const newProjectRoot = (workspace.extensions.newProjectRoot as string | undefined) || '';\n\n    let folderName = packageName.startsWith('@') ? packageName.slice(1) : packageName;\n    if (/[A-Z]/.test(folderName)) {\n      folderName = strings.dasherize(folderName);\n    }\n\n    const libDir =\n      options.projectRoot !== undefined\n        ? normalize(options.projectRoot)\n        : join(normalize(newProjectRoot), folderName);\n\n    const distRoot = `dist/${folderName}`;\n    const sourceDir = `${libDir}/src/lib`;\n\n    const templateSource = apply(url('./files'), [\n      applyTemplates({\n        ...strings,\n        ...options,\n        packageName,\n        libDir,\n        distRoot,\n        relativePathToWorkspaceRoot: relativePathToWorkspaceRoot(libDir),\n        prefix,\n        angularLatestVersion: latestVersions.Angular.replace(/~|\\^/, ''),\n        tsLibLatestVersion: latestVersions['tslib'].replace(/~|\\^/, ''),\n        folderName,\n      }),\n      move(libDir),\n    ]);\n\n    return chain([\n      mergeWith(templateSource),\n      addLibToWorkspaceFile(options, libDir, packageName),\n      options.skipPackageJson ? noop() : addDependenciesToPackageJson(),\n      options.skipTsConfig ? noop() : updateTsConfig(packageName, distRoot),\n      options.standalone\n        ? noop()\n        : schematic('module', {\n            name: options.name,\n            commonModule: false,\n            flat: true,\n            path: sourceDir,\n            project: packageName,\n          }),\n      schematic('component', {\n        name: options.name,\n        selector: `${prefix}-${options.name}`,\n        inlineStyle: true,\n        inlineTemplate: true,\n        flat: true,\n        path: sourceDir,\n        export: true,\n        standalone: options.standalone,\n        project: packageName,\n      }),\n      schematic('service', {\n        name: options.name,\n        flat: true,\n        path: sourceDir,\n        project: packageName,\n      }),\n      (_tree: Tree, context: SchematicContext) => {\n        if (!options.skipPackageJson && !options.skipInstall) {\n          context.addTask(new NodePackageInstallTask());\n        }\n      },\n    ]);\n  };\n}\n"]}