Skip to content

Commit

Permalink
feat(@schematics/angular): augment universal schematics to import `…
Browse files Browse the repository at this point in the history
…platform-server` shims

In angular/angular#40559, a new `@angular/platform-server/init`
entry-point was introduced, which can be used to initialize the server
environment by providing shims for APIs normally provided by the browser
(such as DOM globals).

If the project is using a version of Angular (and thus
`@angular/platform-server`) that is known to include this new
entry-point, the newly generated `main.server.ts` file should import it
at the top in order to ensure that the shims will be available as soon
as possible (before other direct or transitive imports that may rely on
them). See also angular/angular#40559 for more details.

NOTE:
This `universal` schematic is the base for `app-shell`,
`@nguniversal/express-engine` and `@nguniversal/hapi-engine`.

Fixes angular/angular#40559
  • Loading branch information
gkalpak committed Feb 12, 2021
1 parent 1bbdbaf commit c96ad79
Show file tree
Hide file tree
Showing 2 changed files with 14 additions and 2 deletions.
Original file line number Diff line number Diff line change
@@ -1,6 +1,15 @@
<% if (hasLocalizePackage) { %>/***************************************************************************************************
<% if (hasPlatformServerInit) { %>/***************************************************************************************************
* Initialize the server environment - for example, adding DOM built-in types to the global scope.
*
* NOTE:
* This import must come before any imports (direct or transitive) that rely on DOM built-ins being
* available, such as `@angular/elements`.
*/
import '@angular/localize/init';

<% } %><% if (hasLocalizePackage) { %>/***************************************************************************************************
* Load `$localize` onto the global scope - used if i18n tags appear in Angular templates.
*/
*/
import '@angular/localize/init';

<% } %>import { enableProdMode } from '@angular/core';
Expand Down
3 changes: 3 additions & 0 deletions packages/schematics/angular/universal/index.ts
Original file line number Diff line number Diff line change
Expand Up @@ -248,6 +248,8 @@ export default function (options: UniversalOptions): Rule {
// and we don't want to break the 'ng add @nguniversal/express-engine schematics'
const rootInSrc = clientProject.root === '' && clientTsConfig.includes('src/');
const tsConfigDirectory = join(normalize(clientProject.root), rootInSrc ? 'src' : '');
const ngVersion = getPackageJsonDependency(host, '@angular/core')?.version ?? '0.0.0';
const ngMajorVersion = ngVersion.match(/^[^~>=]*(\d+)/)?.[1] ?? '0';

if (!options.skipInstall) {
context.addTask(new NodePackageInstallTask());
Expand All @@ -259,6 +261,7 @@ export default function (options: UniversalOptions): Rule {
...options as object,
stripTsExtension: (s: string) => s.replace(/\.ts$/, ''),
hasLocalizePackage: !!getPackageJsonDependency(host, '@angular/localize'),
hasPlatformServerInit: Number(ngMajorVersion) >= 12,
}),
move(join(normalize(clientProject.root), 'src')),
]);
Expand Down

0 comments on commit c96ad79

Please sign in to comment.