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

141 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 latest_versions_1 = require("../utility/latest-versions");
const ng_ast_utils_1 = require("../utility/ng-ast-utils");
const paths_1 = require("../utility/paths");
const project_targets_1 = require("../utility/project-targets");
const workspace_1 = require("../utility/workspace");
const workspace_models_1 = require("../utility/workspace-models");
function updateConfigFile(options, tsConfigDirectory) {
return (0, workspace_1.updateWorkspace)((workspace) => {
const clientProject = workspace.projects.get(options.project);
if (clientProject) {
// In case the browser builder hashes the assets
// we need to add this setting to the server builder
// as otherwise when assets it will be requested twice.
// One for the server which will be unhashed, and other on the client which will be hashed.
const getServerOptions = (options = {}) => {
return {
buildOptimizer: options?.buildOptimizer,
outputHashing: options?.outputHashing === 'all' ? 'media' : options?.outputHashing,
fileReplacements: options?.fileReplacements,
optimization: options?.optimization === undefined ? undefined : !!options?.optimization,
sourceMap: options?.sourceMap,
localization: options?.localization,
stylePreprocessorOptions: options?.stylePreprocessorOptions,
resourcesOutputPath: options?.resourcesOutputPath,
deployUrl: options?.deployUrl,
i18nMissingTranslation: options?.i18nMissingTranslation,
preserveSymlinks: options?.preserveSymlinks,
extractLicenses: options?.extractLicenses,
inlineStyleLanguage: options?.inlineStyleLanguage,
vendorChunk: options?.vendorChunk,
};
};
const buildTarget = clientProject.targets.get('build');
if (buildTarget?.options) {
buildTarget.options.outputPath = `dist/${options.project}/browser`;
}
const buildConfigurations = buildTarget?.configurations;
const configurations = {};
if (buildConfigurations) {
for (const [key, options] of Object.entries(buildConfigurations)) {
configurations[key] = getServerOptions(options);
}
}
const mainPath = options.main;
const sourceRoot = clientProject.sourceRoot ?? (0, core_1.join)((0, core_1.normalize)(clientProject.root), 'src');
const serverTsConfig = (0, core_1.join)(tsConfigDirectory, 'tsconfig.server.json');
clientProject.targets.add({
name: 'server',
builder: workspace_models_1.Builders.Server,
defaultConfiguration: 'production',
options: {
outputPath: `dist/${options.project}/server`,
main: (0, core_1.join)((0, core_1.normalize)(sourceRoot), mainPath.endsWith('.ts') ? mainPath : mainPath + '.ts'),
tsConfig: serverTsConfig,
...(buildTarget?.options ? getServerOptions(buildTarget?.options) : {}),
},
configurations,
});
}
});
}
function addDependencies() {
return (host) => {
const coreDep = (0, dependencies_1.getPackageJsonDependency)(host, '@angular/core');
if (coreDep === null) {
throw new schematics_1.SchematicsException('Could not find version.');
}
const platformServerDep = {
...coreDep,
name: '@angular/platform-server',
};
(0, dependencies_1.addPackageJsonDependency)(host, platformServerDep);
(0, dependencies_1.addPackageJsonDependency)(host, {
type: dependencies_1.NodeDependencyType.Dev,
name: '@types/node',
version: latest_versions_1.latestVersions['@types/node'],
});
};
}
function default_1(options) {
return async (host, context) => {
const workspace = await (0, workspace_1.getWorkspace)(host);
const clientProject = workspace.projects.get(options.project);
if (!clientProject || clientProject.extensions.projectType !== 'application') {
throw new schematics_1.SchematicsException(`Universal requires a project type of "application".`);
}
const clientBuildTarget = clientProject.targets.get('build');
if (!clientBuildTarget) {
throw (0, project_targets_1.targetBuildNotFoundError)();
}
const clientBuildOptions = (clientBuildTarget.options ||
{});
if (!options.skipInstall) {
context.addTask(new tasks_1.NodePackageInstallTask());
}
const isStandalone = (0, ng_ast_utils_1.isStandaloneApp)(host, clientBuildOptions.main);
const templateSource = (0, schematics_1.apply)((0, schematics_1.url)(isStandalone ? './files/standalone-src' : './files/src'), [
(0, schematics_1.applyTemplates)({
...schematics_1.strings,
...options,
stripTsExtension: (s) => s.replace(/\.ts$/, ''),
}),
(0, schematics_1.move)((0, core_1.join)((0, core_1.normalize)(clientProject.root), 'src')),
]);
const clientTsConfig = (0, core_1.normalize)(clientBuildOptions.tsConfig);
const tsConfigExtends = (0, core_1.basename)(clientTsConfig);
const tsConfigDirectory = (0, core_1.dirname)(clientTsConfig);
const rootSource = (0, schematics_1.apply)((0, schematics_1.url)('./files/root'), [
(0, schematics_1.applyTemplates)({
...schematics_1.strings,
...options,
stripTsExtension: (s) => s.replace(/\.ts$/, ''),
tsConfigExtends,
hasLocalizePackage: !!(0, dependencies_1.getPackageJsonDependency)(host, '@angular/localize'),
relativePathToWorkspaceRoot: (0, paths_1.relativePathToWorkspaceRoot)(tsConfigDirectory),
}),
(0, schematics_1.move)(tsConfigDirectory),
]);
return (0, schematics_1.chain)([
(0, schematics_1.mergeWith)(templateSource),
(0, schematics_1.mergeWith)(rootSource),
addDependencies(),
updateConfigFile(options, tsConfigDirectory),
]);
};
}
exports.default = default_1;
//# 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"]}