@angular/ssr 0.0.0-PLACEHOLDER → 17.0.0-next.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/esm2022/index.mjs +9 -0
- package/esm2022/public_api.mjs +9 -0
- package/esm2022/src/common-engine.mjs +131 -0
- package/esm2022/src/inline-css-processor.mjs +170 -0
- package/fesm2022/ssr.mjs +289 -0
- package/fesm2022/ssr.mjs.map +1 -0
- package/index.d.ts +44 -0
- package/package.json +26 -3
- package/schematics/collection.json +9 -0
- package/schematics/ng-add/files/server.ts.template +67 -0
- package/schematics/ng-add/index.d.ts +10 -0
- package/schematics/ng-add/index.js +278 -0
- package/schematics/ng-add/index.mjs +252 -0
- package/schematics/ng-add/schema.d.ts +22 -0
- package/schematics/ng-add/schema.js +5 -0
- package/schematics/ng-add/schema.json +39 -0
- package/schematics/ng-add/schema.mjs +4 -0
- package/schematics/package.json +3 -0
- package/schematics/schematics.externs.js +0 -0
- package/schematics/utility/latest-versions/index.d.ts +8 -0
- package/schematics/utility/latest-versions/index.js +16 -0
- package/schematics/utility/latest-versions/index.mjs +13 -0
- package/schematics/utility/latest-versions/package.json +9 -0
- package/schematics/utility/utils.d.ts +22 -0
- package/schematics/utility/utils.js +127 -0
- package/schematics/utility/utils.mjs +95 -0
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
// THIS FILE IS AUTOMATICALLY GENERATED. TO UPDATE THIS FILE YOU NEED TO CHANGE THE
|
|
3
|
+
// CORRESPONDING JSON SCHEMA FILE, THEN RUN devkit-admin build (or bazel build ...).
|
|
4
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
5
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2NoZW1hLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvYW5ndWxhci9zc3Ivc2NoZW1hdGljcy9uZy1hZGQvc2NoZW1hLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFDQSxtRkFBbUY7QUFDbkYsb0ZBQW9GIiwic291cmNlc0NvbnRlbnQiOlsiXG4vLyBUSElTIEZJTEUgSVMgQVVUT01BVElDQUxMWSBHRU5FUkFURUQuIFRPIFVQREFURSBUSElTIEZJTEUgWU9VIE5FRUQgVE8gQ0hBTkdFIFRIRVxuLy8gQ09SUkVTUE9ORElORyBKU09OIFNDSEVNQSBGSUxFLCBUSEVOIFJVTiBkZXZraXQtYWRtaW4gYnVpbGQgKG9yIGJhemVsIGJ1aWxkIC4uLikuXG5cbmV4cG9ydCBpbnRlcmZhY2UgU2NoZW1hIHtcbiAgICAvKipcbiAgICAgKiBUaGUgbmFtZSBvZiB0aGUgbWFpbiBlbnRyeS1wb2ludCBmaWxlLlxuICAgICAqL1xuICAgIG1haW4/OiBzdHJpbmc7XG4gICAgLyoqXG4gICAgICogVGhlIG5hbWUgb2YgdGhlIHByb2plY3QuXG4gICAgICovXG4gICAgcHJvamVjdDogc3RyaW5nO1xuICAgIC8qKlxuICAgICAqIFRoZSBuYW1lIG9mIHRoZSByb290IG1vZHVsZSBjbGFzcy5cbiAgICAgKi9cbiAgICByb290TW9kdWxlQ2xhc3NOYW1lPzogc3RyaW5nO1xuICAgIC8qKlxuICAgICAqIFRoZSBuYW1lIG9mIHRoZSByb290IG1vZHVsZSBmaWxlXG4gICAgICovXG4gICAgcm9vdE1vZHVsZUZpbGVOYW1lPzogc3RyaW5nO1xuICAgIC8qKlxuICAgICAqIFNraXAgaW5zdGFsbGluZyBkZXBlbmRlbmN5IHBhY2thZ2VzLlxuICAgICAqL1xuICAgIHNraXBJbnN0YWxsPzogYm9vbGVhbjtcbn1cbiJdfQ==
|
|
@@ -0,0 +1,39 @@
|
|
|
1
|
+
{
|
|
2
|
+
"$schema": "http://json-schema.org/draft-07/schema",
|
|
3
|
+
"$id": "SchematicsAngularSSRAdd",
|
|
4
|
+
"title": "Angular SSR Options Schema",
|
|
5
|
+
"type": "object",
|
|
6
|
+
"properties": {
|
|
7
|
+
"project": {
|
|
8
|
+
"type": "string",
|
|
9
|
+
"description": "The name of the project.",
|
|
10
|
+
"$default": {
|
|
11
|
+
"$source": "projectName"
|
|
12
|
+
}
|
|
13
|
+
},
|
|
14
|
+
"main": {
|
|
15
|
+
"type": "string",
|
|
16
|
+
"format": "path",
|
|
17
|
+
"description": "The name of the main entry-point file.",
|
|
18
|
+
"default": "main.server.ts"
|
|
19
|
+
},
|
|
20
|
+
"rootModuleFileName": {
|
|
21
|
+
"type": "string",
|
|
22
|
+
"format": "path",
|
|
23
|
+
"description": "The name of the root module file",
|
|
24
|
+
"default": "app.server.module.ts"
|
|
25
|
+
},
|
|
26
|
+
"rootModuleClassName": {
|
|
27
|
+
"type": "string",
|
|
28
|
+
"description": "The name of the root module class.",
|
|
29
|
+
"default": "AppServerModule"
|
|
30
|
+
},
|
|
31
|
+
"skipInstall": {
|
|
32
|
+
"description": "Skip installing dependency packages.",
|
|
33
|
+
"type": "boolean",
|
|
34
|
+
"default": false
|
|
35
|
+
}
|
|
36
|
+
},
|
|
37
|
+
"required": ["project"],
|
|
38
|
+
"additionalProperties": false
|
|
39
|
+
}
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
// THIS FILE IS AUTOMATICALLY GENERATED. TO UPDATE THIS FILE YOU NEED TO CHANGE THE
|
|
2
|
+
// CORRESPONDING JSON SCHEMA FILE, THEN RUN devkit-admin build (or bazel build ...).
|
|
3
|
+
export {};
|
|
4
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2NoZW1hLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvYW5ndWxhci9zc3Ivc2NoZW1hdGljcy9uZy1hZGQvc2NoZW1hLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUNBLG1GQUFtRjtBQUNuRixvRkFBb0YiLCJzb3VyY2VzQ29udGVudCI6WyJcbi8vIFRISVMgRklMRSBJUyBBVVRPTUFUSUNBTExZIEdFTkVSQVRFRC4gVE8gVVBEQVRFIFRISVMgRklMRSBZT1UgTkVFRCBUTyBDSEFOR0UgVEhFXG4vLyBDT1JSRVNQT05ESU5HIEpTT04gU0NIRU1BIEZJTEUsIFRIRU4gUlVOIGRldmtpdC1hZG1pbiBidWlsZCAob3IgYmF6ZWwgYnVpbGQgLi4uKS5cblxuZXhwb3J0IGludGVyZmFjZSBTY2hlbWEge1xuICAgIC8qKlxuICAgICAqIFRoZSBuYW1lIG9mIHRoZSBtYWluIGVudHJ5LXBvaW50IGZpbGUuXG4gICAgICovXG4gICAgbWFpbj86IHN0cmluZztcbiAgICAvKipcbiAgICAgKiBUaGUgbmFtZSBvZiB0aGUgcHJvamVjdC5cbiAgICAgKi9cbiAgICBwcm9qZWN0OiBzdHJpbmc7XG4gICAgLyoqXG4gICAgICogVGhlIG5hbWUgb2YgdGhlIHJvb3QgbW9kdWxlIGNsYXNzLlxuICAgICAqL1xuICAgIHJvb3RNb2R1bGVDbGFzc05hbWU/OiBzdHJpbmc7XG4gICAgLyoqXG4gICAgICogVGhlIG5hbWUgb2YgdGhlIHJvb3QgbW9kdWxlIGZpbGVcbiAgICAgKi9cbiAgICByb290TW9kdWxlRmlsZU5hbWU/OiBzdHJpbmc7XG4gICAgLyoqXG4gICAgICogU2tpcCBpbnN0YWxsaW5nIGRlcGVuZGVuY3kgcGFja2FnZXMuXG4gICAgICovXG4gICAgc2tpcEluc3RhbGw/OiBib29sZWFuO1xufVxuIl19
|
|
File without changes
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @license
|
|
3
|
+
* Copyright Google LLC All Rights Reserved.
|
|
4
|
+
*
|
|
5
|
+
* Use of this source code is governed by an MIT-style license that can be
|
|
6
|
+
* found in the LICENSE file at https://angular.io/license
|
|
7
|
+
*/
|
|
8
|
+
export declare const latestVersions: Record<string, string>;
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
/**
|
|
3
|
+
* @license
|
|
4
|
+
* Copyright Google LLC All Rights Reserved.
|
|
5
|
+
*
|
|
6
|
+
* Use of this source code is governed by an MIT-style license that can be
|
|
7
|
+
* found in the LICENSE file at https://angular.io/license
|
|
8
|
+
*/
|
|
9
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
10
|
+
exports.latestVersions = void 0;
|
|
11
|
+
exports.latestVersions = {
|
|
12
|
+
// We could have used TypeScripts' `resolveJsonModule` to make the `latestVersion` object typesafe,
|
|
13
|
+
// but ts_library doesn't support JSON inputs.
|
|
14
|
+
...require('./package.json')['dependencies'],
|
|
15
|
+
};
|
|
16
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9hbmd1bGFyL3Nzci9zY2hlbWF0aWNzL3V0aWxpdHkvbGF0ZXN0LXZlcnNpb25zL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQTs7Ozs7O0dBTUc7OztBQUVVLFFBQUEsY0FBYyxHQUEyQjtJQUNwRCxtR0FBbUc7SUFDbkcsOENBQThDO0lBQzlDLEdBQUcsT0FBTyxDQUFDLGdCQUFnQixDQUFDLENBQUMsY0FBYyxDQUFDO0NBQzdDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEBsaWNlbnNlXG4gKiBDb3B5cmlnaHQgR29vZ2xlIExMQyBBbGwgUmlnaHRzIFJlc2VydmVkLlxuICpcbiAqIFVzZSBvZiB0aGlzIHNvdXJjZSBjb2RlIGlzIGdvdmVybmVkIGJ5IGFuIE1JVC1zdHlsZSBsaWNlbnNlIHRoYXQgY2FuIGJlXG4gKiBmb3VuZCBpbiB0aGUgTElDRU5TRSBmaWxlIGF0IGh0dHBzOi8vYW5ndWxhci5pby9saWNlbnNlXG4gKi9cblxuZXhwb3J0IGNvbnN0IGxhdGVzdFZlcnNpb25zOiBSZWNvcmQ8c3RyaW5nLCBzdHJpbmc+ID0ge1xuICAvLyBXZSBjb3VsZCBoYXZlIHVzZWQgVHlwZVNjcmlwdHMnIGByZXNvbHZlSnNvbk1vZHVsZWAgdG8gbWFrZSB0aGUgYGxhdGVzdFZlcnNpb25gIG9iamVjdCB0eXBlc2FmZSxcbiAgLy8gYnV0IHRzX2xpYnJhcnkgZG9lc24ndCBzdXBwb3J0IEpTT04gaW5wdXRzLlxuICAuLi5yZXF1aXJlKCcuL3BhY2thZ2UuanNvbicpWydkZXBlbmRlbmNpZXMnXSxcbn07XG4iXX0=
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @license
|
|
3
|
+
* Copyright Google LLC All Rights Reserved.
|
|
4
|
+
*
|
|
5
|
+
* Use of this source code is governed by an MIT-style license that can be
|
|
6
|
+
* found in the LICENSE file at https://angular.io/license
|
|
7
|
+
*/
|
|
8
|
+
export const latestVersions = {
|
|
9
|
+
// We could have used TypeScripts' `resolveJsonModule` to make the `latestVersion` object typesafe,
|
|
10
|
+
// but ts_library doesn't support JSON inputs.
|
|
11
|
+
...require('./package.json')['dependencies'],
|
|
12
|
+
};
|
|
13
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9hbmd1bGFyL3Nzci9zY2hlbWF0aWNzL3V0aWxpdHkvbGF0ZXN0LXZlcnNpb25zL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOzs7Ozs7R0FNRztBQUVILE1BQU0sQ0FBQyxNQUFNLGNBQWMsR0FBMkI7SUFDcEQsbUdBQW1HO0lBQ25HLDhDQUE4QztJQUM5QyxHQUFHLE9BQU8sQ0FBQyxnQkFBZ0IsQ0FBQyxDQUFDLGNBQWMsQ0FBQztDQUM3QyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBAbGljZW5zZVxuICogQ29weXJpZ2h0IEdvb2dsZSBMTEMgQWxsIFJpZ2h0cyBSZXNlcnZlZC5cbiAqXG4gKiBVc2Ugb2YgdGhpcyBzb3VyY2UgY29kZSBpcyBnb3Zlcm5lZCBieSBhbiBNSVQtc3R5bGUgbGljZW5zZSB0aGF0IGNhbiBiZVxuICogZm91bmQgaW4gdGhlIExJQ0VOU0UgZmlsZSBhdCBodHRwczovL2FuZ3VsYXIuaW8vbGljZW5zZVxuICovXG5cbmV4cG9ydCBjb25zdCBsYXRlc3RWZXJzaW9uczogUmVjb3JkPHN0cmluZywgc3RyaW5nPiA9IHtcbiAgLy8gV2UgY291bGQgaGF2ZSB1c2VkIFR5cGVTY3JpcHRzJyBgcmVzb2x2ZUpzb25Nb2R1bGVgIHRvIG1ha2UgdGhlIGBsYXRlc3RWZXJzaW9uYCBvYmplY3QgdHlwZXNhZmUsXG4gIC8vIGJ1dCB0c19saWJyYXJ5IGRvZXNuJ3Qgc3VwcG9ydCBKU09OIGlucHV0cy5cbiAgLi4ucmVxdWlyZSgnLi9wYWNrYWdlLmpzb24nKVsnZGVwZW5kZW5jaWVzJ10sXG59O1xuIl19
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @license
|
|
3
|
+
* Copyright Google LLC All Rights Reserved.
|
|
4
|
+
*
|
|
5
|
+
* Use of this source code is governed by an MIT-style license that can be
|
|
6
|
+
* found in the LICENSE file at https://angular.io/license
|
|
7
|
+
*/
|
|
8
|
+
import { workspaces } from '@angular-devkit/core';
|
|
9
|
+
import { Tree } from '@angular-devkit/schematics';
|
|
10
|
+
import * as ts from 'typescript';
|
|
11
|
+
export declare function getProject(host: Tree, projectName: string): Promise<workspaces.ProjectDefinition>;
|
|
12
|
+
export declare function stripTsExtension(file: string): string;
|
|
13
|
+
export declare function getOutputPath(host: Tree, projectName: string, target: 'server' | 'build'): Promise<string>;
|
|
14
|
+
export declare function findImport(sourceFile: ts.SourceFile, moduleName: string, symbolName: string): ts.NamedImports | null;
|
|
15
|
+
export type Import = {
|
|
16
|
+
name: string;
|
|
17
|
+
importModule: string;
|
|
18
|
+
node: ts.ImportDeclaration;
|
|
19
|
+
};
|
|
20
|
+
/** Gets import information about the specified identifier by using the Type checker. */
|
|
21
|
+
export declare function getImportOfIdentifier(typeChecker: ts.TypeChecker, node: ts.Identifier): Import | null;
|
|
22
|
+
export declare function addInitialNavigation(node: ts.CallExpression): ts.CallExpression;
|
|
@@ -0,0 +1,127 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
/**
|
|
3
|
+
* @license
|
|
4
|
+
* Copyright Google LLC All Rights Reserved.
|
|
5
|
+
*
|
|
6
|
+
* Use of this source code is governed by an MIT-style license that can be
|
|
7
|
+
* found in the LICENSE file at https://angular.io/license
|
|
8
|
+
*/
|
|
9
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
12
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
13
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
14
|
+
}
|
|
15
|
+
Object.defineProperty(o, k2, desc);
|
|
16
|
+
}) : (function(o, m, k, k2) {
|
|
17
|
+
if (k2 === undefined) k2 = k;
|
|
18
|
+
o[k2] = m[k];
|
|
19
|
+
}));
|
|
20
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
21
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
22
|
+
}) : function(o, v) {
|
|
23
|
+
o["default"] = v;
|
|
24
|
+
});
|
|
25
|
+
var __importStar = (this && this.__importStar) || function (mod) {
|
|
26
|
+
if (mod && mod.__esModule) return mod;
|
|
27
|
+
var result = {};
|
|
28
|
+
if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
|
|
29
|
+
__setModuleDefault(result, mod);
|
|
30
|
+
return result;
|
|
31
|
+
};
|
|
32
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
33
|
+
exports.addInitialNavigation = exports.getImportOfIdentifier = exports.findImport = exports.getOutputPath = exports.stripTsExtension = exports.getProject = void 0;
|
|
34
|
+
const schematics_1 = require("@angular-devkit/schematics");
|
|
35
|
+
const utility_1 = require("@schematics/angular/utility");
|
|
36
|
+
const ts = __importStar(require("typescript"));
|
|
37
|
+
async function getProject(host, projectName) {
|
|
38
|
+
const workspace = await (0, utility_1.readWorkspace)(host);
|
|
39
|
+
const project = workspace.projects.get(projectName);
|
|
40
|
+
if (!project || project.extensions.projectType !== 'application') {
|
|
41
|
+
throw new schematics_1.SchematicsException(`Universal requires a project type of 'application'.`);
|
|
42
|
+
}
|
|
43
|
+
return project;
|
|
44
|
+
}
|
|
45
|
+
exports.getProject = getProject;
|
|
46
|
+
function stripTsExtension(file) {
|
|
47
|
+
return file.replace(/\.ts$/, '');
|
|
48
|
+
}
|
|
49
|
+
exports.stripTsExtension = stripTsExtension;
|
|
50
|
+
async function getOutputPath(host, projectName, target) {
|
|
51
|
+
// Generate new output paths
|
|
52
|
+
const project = await getProject(host, projectName);
|
|
53
|
+
const serverTarget = project.targets.get(target);
|
|
54
|
+
if (!serverTarget || !serverTarget.options) {
|
|
55
|
+
throw new schematics_1.SchematicsException(`Cannot find 'options' for ${projectName} ${target} target.`);
|
|
56
|
+
}
|
|
57
|
+
const { outputPath } = serverTarget.options;
|
|
58
|
+
if (typeof outputPath !== 'string') {
|
|
59
|
+
throw new schematics_1.SchematicsException(`outputPath for ${projectName} ${target} target is not a string.`);
|
|
60
|
+
}
|
|
61
|
+
return outputPath;
|
|
62
|
+
}
|
|
63
|
+
exports.getOutputPath = getOutputPath;
|
|
64
|
+
function findImport(sourceFile, moduleName, symbolName) {
|
|
65
|
+
// Only look through the top-level imports.
|
|
66
|
+
for (const node of sourceFile.statements) {
|
|
67
|
+
if (!ts.isImportDeclaration(node) ||
|
|
68
|
+
!ts.isStringLiteral(node.moduleSpecifier) ||
|
|
69
|
+
node.moduleSpecifier.text !== moduleName) {
|
|
70
|
+
continue;
|
|
71
|
+
}
|
|
72
|
+
const namedBindings = node.importClause && node.importClause.namedBindings;
|
|
73
|
+
if (!namedBindings || !ts.isNamedImports(namedBindings)) {
|
|
74
|
+
continue;
|
|
75
|
+
}
|
|
76
|
+
if (namedBindings.elements.some((element) => element.name.text === symbolName)) {
|
|
77
|
+
return namedBindings;
|
|
78
|
+
}
|
|
79
|
+
}
|
|
80
|
+
return null;
|
|
81
|
+
}
|
|
82
|
+
exports.findImport = findImport;
|
|
83
|
+
/** Gets import information about the specified identifier by using the Type checker. */
|
|
84
|
+
function getImportOfIdentifier(typeChecker, node) {
|
|
85
|
+
const symbol = typeChecker.getSymbolAtLocation(node);
|
|
86
|
+
if (!symbol || !symbol.declarations?.length) {
|
|
87
|
+
return null;
|
|
88
|
+
}
|
|
89
|
+
const decl = symbol.declarations[0];
|
|
90
|
+
if (!ts.isImportSpecifier(decl)) {
|
|
91
|
+
return null;
|
|
92
|
+
}
|
|
93
|
+
const importDecl = decl.parent.parent.parent;
|
|
94
|
+
if (!ts.isStringLiteral(importDecl.moduleSpecifier)) {
|
|
95
|
+
return null;
|
|
96
|
+
}
|
|
97
|
+
return {
|
|
98
|
+
// Handles aliased imports: e.g. "import {Component as myComp} from ...";
|
|
99
|
+
name: decl.propertyName ? decl.propertyName.text : decl.name.text,
|
|
100
|
+
importModule: importDecl.moduleSpecifier.text,
|
|
101
|
+
node: importDecl,
|
|
102
|
+
};
|
|
103
|
+
}
|
|
104
|
+
exports.getImportOfIdentifier = getImportOfIdentifier;
|
|
105
|
+
function addInitialNavigation(node) {
|
|
106
|
+
const existingOptions = node.arguments[1];
|
|
107
|
+
// If the user has explicitly set initialNavigation, we respect that
|
|
108
|
+
if (existingOptions &&
|
|
109
|
+
existingOptions.properties.some((exp) => ts.isPropertyAssignment(exp) &&
|
|
110
|
+
ts.isIdentifier(exp.name) &&
|
|
111
|
+
exp.name.text === 'initialNavigation')) {
|
|
112
|
+
return node;
|
|
113
|
+
}
|
|
114
|
+
const enabledLiteral = ts.factory.createStringLiteral('enabledBlocking');
|
|
115
|
+
// TypeScript will emit the Node with double quotes.
|
|
116
|
+
// In schematics we usually write code with a single quotes
|
|
117
|
+
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
118
|
+
enabledLiteral.singleQuote = true;
|
|
119
|
+
const initialNavigationProperty = ts.factory.createPropertyAssignment('initialNavigation', enabledLiteral);
|
|
120
|
+
const routerOptions = existingOptions
|
|
121
|
+
? ts.factory.updateObjectLiteralExpression(existingOptions, ts.factory.createNodeArray([...existingOptions.properties, initialNavigationProperty]))
|
|
122
|
+
: ts.factory.createObjectLiteralExpression([initialNavigationProperty], true);
|
|
123
|
+
const args = [node.arguments[0], routerOptions];
|
|
124
|
+
return ts.factory.createCallExpression(node.expression, node.typeArguments, args);
|
|
125
|
+
}
|
|
126
|
+
exports.addInitialNavigation = addInitialNavigation;
|
|
127
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"utils.js","sourceRoot":"","sources":["../../../../../../../../packages/angular/ssr/schematics/utility/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 { workspaces } from '@angular-devkit/core';\nimport { SchematicsException, Tree } from '@angular-devkit/schematics';\nimport { readWorkspace } from '@schematics/angular/utility';\nimport * as ts from 'typescript';\n\nexport async function getProject(\n  host: Tree,\n  projectName: string,\n): Promise<workspaces.ProjectDefinition> {\n  const workspace = await readWorkspace(host);\n  const project = workspace.projects.get(projectName);\n\n  if (!project || project.extensions.projectType !== 'application') {\n    throw new SchematicsException(`Universal requires a project type of 'application'.`);\n  }\n\n  return project;\n}\n\nexport function stripTsExtension(file: string): string {\n  return file.replace(/\\.ts$/, '');\n}\n\nexport async function getOutputPath(\n  host: Tree,\n  projectName: string,\n  target: 'server' | 'build',\n): Promise<string> {\n  // Generate new output paths\n  const project = await getProject(host, projectName);\n  const serverTarget = project.targets.get(target);\n  if (!serverTarget || !serverTarget.options) {\n    throw new SchematicsException(`Cannot find 'options' for ${projectName} ${target} target.`);\n  }\n\n  const { outputPath } = serverTarget.options;\n  if (typeof outputPath !== 'string') {\n    throw new SchematicsException(\n      `outputPath for ${projectName} ${target} target is not a string.`,\n    );\n  }\n\n  return outputPath;\n}\n\nexport function findImport(\n  sourceFile: ts.SourceFile,\n  moduleName: string,\n  symbolName: string,\n): ts.NamedImports | null {\n  // Only look through the top-level imports.\n  for (const node of sourceFile.statements) {\n    if (\n      !ts.isImportDeclaration(node) ||\n      !ts.isStringLiteral(node.moduleSpecifier) ||\n      node.moduleSpecifier.text !== moduleName\n    ) {\n      continue;\n    }\n\n    const namedBindings = node.importClause && node.importClause.namedBindings;\n\n    if (!namedBindings || !ts.isNamedImports(namedBindings)) {\n      continue;\n    }\n\n    if (namedBindings.elements.some((element) => element.name.text === symbolName)) {\n      return namedBindings;\n    }\n  }\n\n  return null;\n}\n\nexport type Import = {\n  name: string;\n  importModule: string;\n  node: ts.ImportDeclaration;\n};\n\n/** Gets import information about the specified identifier by using the Type checker. */\nexport function getImportOfIdentifier(\n  typeChecker: ts.TypeChecker,\n  node: ts.Identifier,\n): Import | null {\n  const symbol = typeChecker.getSymbolAtLocation(node);\n\n  if (!symbol || !symbol.declarations?.length) {\n    return null;\n  }\n\n  const decl = symbol.declarations[0];\n\n  if (!ts.isImportSpecifier(decl)) {\n    return null;\n  }\n\n  const importDecl = decl.parent.parent.parent;\n\n  if (!ts.isStringLiteral(importDecl.moduleSpecifier)) {\n    return null;\n  }\n\n  return {\n    // Handles aliased imports: e.g. \"import {Component as myComp} from ...\";\n    name: decl.propertyName ? decl.propertyName.text : decl.name.text,\n    importModule: importDecl.moduleSpecifier.text,\n    node: importDecl,\n  };\n}\n\nexport function addInitialNavigation(node: ts.CallExpression): ts.CallExpression {\n  const existingOptions = node.arguments[1] as ts.ObjectLiteralExpression | undefined;\n\n  // If the user has explicitly set initialNavigation, we respect that\n  if (\n    existingOptions &&\n    existingOptions.properties.some(\n      (exp) =>\n        ts.isPropertyAssignment(exp) &&\n        ts.isIdentifier(exp.name) &&\n        exp.name.text === 'initialNavigation',\n    )\n  ) {\n    return node;\n  }\n\n  const enabledLiteral = ts.factory.createStringLiteral('enabledBlocking');\n  // TypeScript will emit the Node with double quotes.\n  // In schematics we usually write code with a single quotes\n  // eslint-disable-next-line @typescript-eslint/no-explicit-any\n  (enabledLiteral as any).singleQuote = true;\n\n  const initialNavigationProperty = ts.factory.createPropertyAssignment(\n    'initialNavigation',\n    enabledLiteral,\n  );\n  const routerOptions = existingOptions\n    ? ts.factory.updateObjectLiteralExpression(\n        existingOptions,\n        ts.factory.createNodeArray([...existingOptions.properties, initialNavigationProperty]),\n      )\n    : ts.factory.createObjectLiteralExpression([initialNavigationProperty], true);\n  const args = [node.arguments[0], routerOptions];\n\n  return ts.factory.createCallExpression(node.expression, node.typeArguments, args);\n}\n"]}
|
|
@@ -0,0 +1,95 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @license
|
|
3
|
+
* Copyright Google LLC All Rights Reserved.
|
|
4
|
+
*
|
|
5
|
+
* Use of this source code is governed by an MIT-style license that can be
|
|
6
|
+
* found in the LICENSE file at https://angular.io/license
|
|
7
|
+
*/
|
|
8
|
+
import { SchematicsException } from '@angular-devkit/schematics';
|
|
9
|
+
import { readWorkspace } from '@schematics/angular/utility';
|
|
10
|
+
import * as ts from 'typescript';
|
|
11
|
+
export async function getProject(host, projectName) {
|
|
12
|
+
const workspace = await readWorkspace(host);
|
|
13
|
+
const project = workspace.projects.get(projectName);
|
|
14
|
+
if (!project || project.extensions.projectType !== 'application') {
|
|
15
|
+
throw new SchematicsException(`Universal requires a project type of 'application'.`);
|
|
16
|
+
}
|
|
17
|
+
return project;
|
|
18
|
+
}
|
|
19
|
+
export function stripTsExtension(file) {
|
|
20
|
+
return file.replace(/\.ts$/, '');
|
|
21
|
+
}
|
|
22
|
+
export async function getOutputPath(host, projectName, target) {
|
|
23
|
+
// Generate new output paths
|
|
24
|
+
const project = await getProject(host, projectName);
|
|
25
|
+
const serverTarget = project.targets.get(target);
|
|
26
|
+
if (!serverTarget || !serverTarget.options) {
|
|
27
|
+
throw new SchematicsException(`Cannot find 'options' for ${projectName} ${target} target.`);
|
|
28
|
+
}
|
|
29
|
+
const { outputPath } = serverTarget.options;
|
|
30
|
+
if (typeof outputPath !== 'string') {
|
|
31
|
+
throw new SchematicsException(`outputPath for ${projectName} ${target} target is not a string.`);
|
|
32
|
+
}
|
|
33
|
+
return outputPath;
|
|
34
|
+
}
|
|
35
|
+
export function findImport(sourceFile, moduleName, symbolName) {
|
|
36
|
+
// Only look through the top-level imports.
|
|
37
|
+
for (const node of sourceFile.statements) {
|
|
38
|
+
if (!ts.isImportDeclaration(node) ||
|
|
39
|
+
!ts.isStringLiteral(node.moduleSpecifier) ||
|
|
40
|
+
node.moduleSpecifier.text !== moduleName) {
|
|
41
|
+
continue;
|
|
42
|
+
}
|
|
43
|
+
const namedBindings = node.importClause && node.importClause.namedBindings;
|
|
44
|
+
if (!namedBindings || !ts.isNamedImports(namedBindings)) {
|
|
45
|
+
continue;
|
|
46
|
+
}
|
|
47
|
+
if (namedBindings.elements.some((element) => element.name.text === symbolName)) {
|
|
48
|
+
return namedBindings;
|
|
49
|
+
}
|
|
50
|
+
}
|
|
51
|
+
return null;
|
|
52
|
+
}
|
|
53
|
+
/** Gets import information about the specified identifier by using the Type checker. */
|
|
54
|
+
export function getImportOfIdentifier(typeChecker, node) {
|
|
55
|
+
const symbol = typeChecker.getSymbolAtLocation(node);
|
|
56
|
+
if (!symbol || !symbol.declarations?.length) {
|
|
57
|
+
return null;
|
|
58
|
+
}
|
|
59
|
+
const decl = symbol.declarations[0];
|
|
60
|
+
if (!ts.isImportSpecifier(decl)) {
|
|
61
|
+
return null;
|
|
62
|
+
}
|
|
63
|
+
const importDecl = decl.parent.parent.parent;
|
|
64
|
+
if (!ts.isStringLiteral(importDecl.moduleSpecifier)) {
|
|
65
|
+
return null;
|
|
66
|
+
}
|
|
67
|
+
return {
|
|
68
|
+
// Handles aliased imports: e.g. "import {Component as myComp} from ...";
|
|
69
|
+
name: decl.propertyName ? decl.propertyName.text : decl.name.text,
|
|
70
|
+
importModule: importDecl.moduleSpecifier.text,
|
|
71
|
+
node: importDecl,
|
|
72
|
+
};
|
|
73
|
+
}
|
|
74
|
+
export function addInitialNavigation(node) {
|
|
75
|
+
const existingOptions = node.arguments[1];
|
|
76
|
+
// If the user has explicitly set initialNavigation, we respect that
|
|
77
|
+
if (existingOptions &&
|
|
78
|
+
existingOptions.properties.some((exp) => ts.isPropertyAssignment(exp) &&
|
|
79
|
+
ts.isIdentifier(exp.name) &&
|
|
80
|
+
exp.name.text === 'initialNavigation')) {
|
|
81
|
+
return node;
|
|
82
|
+
}
|
|
83
|
+
const enabledLiteral = ts.factory.createStringLiteral('enabledBlocking');
|
|
84
|
+
// TypeScript will emit the Node with double quotes.
|
|
85
|
+
// In schematics we usually write code with a single quotes
|
|
86
|
+
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
87
|
+
enabledLiteral.singleQuote = true;
|
|
88
|
+
const initialNavigationProperty = ts.factory.createPropertyAssignment('initialNavigation', enabledLiteral);
|
|
89
|
+
const routerOptions = existingOptions
|
|
90
|
+
? ts.factory.updateObjectLiteralExpression(existingOptions, ts.factory.createNodeArray([...existingOptions.properties, initialNavigationProperty]))
|
|
91
|
+
: ts.factory.createObjectLiteralExpression([initialNavigationProperty], true);
|
|
92
|
+
const args = [node.arguments[0], routerOptions];
|
|
93
|
+
return ts.factory.createCallExpression(node.expression, node.typeArguments, args);
|
|
94
|
+
}
|
|
95
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"utils.js","sourceRoot":"","sources":["../../../../../../../../packages/angular/ssr/schematics/utility/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 { workspaces } from '@angular-devkit/core';\nimport { SchematicsException, Tree } from '@angular-devkit/schematics';\nimport { readWorkspace } from '@schematics/angular/utility';\nimport * as ts from 'typescript';\n\nexport async function getProject(\n  host: Tree,\n  projectName: string,\n): Promise<workspaces.ProjectDefinition> {\n  const workspace = await readWorkspace(host);\n  const project = workspace.projects.get(projectName);\n\n  if (!project || project.extensions.projectType !== 'application') {\n    throw new SchematicsException(`Universal requires a project type of 'application'.`);\n  }\n\n  return project;\n}\n\nexport function stripTsExtension(file: string): string {\n  return file.replace(/\\.ts$/, '');\n}\n\nexport async function getOutputPath(\n  host: Tree,\n  projectName: string,\n  target: 'server' | 'build',\n): Promise<string> {\n  // Generate new output paths\n  const project = await getProject(host, projectName);\n  const serverTarget = project.targets.get(target);\n  if (!serverTarget || !serverTarget.options) {\n    throw new SchematicsException(`Cannot find 'options' for ${projectName} ${target} target.`);\n  }\n\n  const { outputPath } = serverTarget.options;\n  if (typeof outputPath !== 'string') {\n    throw new SchematicsException(\n      `outputPath for ${projectName} ${target} target is not a string.`,\n    );\n  }\n\n  return outputPath;\n}\n\nexport function findImport(\n  sourceFile: ts.SourceFile,\n  moduleName: string,\n  symbolName: string,\n): ts.NamedImports | null {\n  // Only look through the top-level imports.\n  for (const node of sourceFile.statements) {\n    if (\n      !ts.isImportDeclaration(node) ||\n      !ts.isStringLiteral(node.moduleSpecifier) ||\n      node.moduleSpecifier.text !== moduleName\n    ) {\n      continue;\n    }\n\n    const namedBindings = node.importClause && node.importClause.namedBindings;\n\n    if (!namedBindings || !ts.isNamedImports(namedBindings)) {\n      continue;\n    }\n\n    if (namedBindings.elements.some((element) => element.name.text === symbolName)) {\n      return namedBindings;\n    }\n  }\n\n  return null;\n}\n\nexport type Import = {\n  name: string;\n  importModule: string;\n  node: ts.ImportDeclaration;\n};\n\n/** Gets import information about the specified identifier by using the Type checker. */\nexport function getImportOfIdentifier(\n  typeChecker: ts.TypeChecker,\n  node: ts.Identifier,\n): Import | null {\n  const symbol = typeChecker.getSymbolAtLocation(node);\n\n  if (!symbol || !symbol.declarations?.length) {\n    return null;\n  }\n\n  const decl = symbol.declarations[0];\n\n  if (!ts.isImportSpecifier(decl)) {\n    return null;\n  }\n\n  const importDecl = decl.parent.parent.parent;\n\n  if (!ts.isStringLiteral(importDecl.moduleSpecifier)) {\n    return null;\n  }\n\n  return {\n    // Handles aliased imports: e.g. \"import {Component as myComp} from ...\";\n    name: decl.propertyName ? decl.propertyName.text : decl.name.text,\n    importModule: importDecl.moduleSpecifier.text,\n    node: importDecl,\n  };\n}\n\nexport function addInitialNavigation(node: ts.CallExpression): ts.CallExpression {\n  const existingOptions = node.arguments[1] as ts.ObjectLiteralExpression | undefined;\n\n  // If the user has explicitly set initialNavigation, we respect that\n  if (\n    existingOptions &&\n    existingOptions.properties.some(\n      (exp) =>\n        ts.isPropertyAssignment(exp) &&\n        ts.isIdentifier(exp.name) &&\n        exp.name.text === 'initialNavigation',\n    )\n  ) {\n    return node;\n  }\n\n  const enabledLiteral = ts.factory.createStringLiteral('enabledBlocking');\n  // TypeScript will emit the Node with double quotes.\n  // In schematics we usually write code with a single quotes\n  // eslint-disable-next-line @typescript-eslint/no-explicit-any\n  (enabledLiteral as any).singleQuote = true;\n\n  const initialNavigationProperty = ts.factory.createPropertyAssignment(\n    'initialNavigation',\n    enabledLiteral,\n  );\n  const routerOptions = existingOptions\n    ? ts.factory.updateObjectLiteralExpression(\n        existingOptions,\n        ts.factory.createNodeArray([...existingOptions.properties, initialNavigationProperty]),\n      )\n    : ts.factory.createObjectLiteralExpression([initialNavigationProperty], true);\n  const args = [node.arguments[0], routerOptions];\n\n  return ts.factory.createCallExpression(node.expression, node.typeArguments, args);\n}\n"]}
|