From 940fbbb014ce124ccd076ad8940b6dfea493e394 Mon Sep 17 00:00:00 2001 From: Kapunahele Wong Date: Thu, 10 Oct 2019 16:08:59 -0400 Subject: [PATCH] docs: add localize migration doc (#33086) PR Close #33086 --- .github/CODEOWNERS | 4 +- aio/content/guide/deprecations.md | 7 +++ aio/content/guide/migration-localize.md | 72 +++++++++++++++++++++++++ 3 files changed, 81 insertions(+), 2 deletions(-) create mode 100644 aio/content/guide/migration-localize.md diff --git a/.github/CODEOWNERS b/.github/CODEOWNERS index 5085e74d16..0c2b7c0f5e 100644 --- a/.github/CODEOWNERS +++ b/.github/CODEOWNERS @@ -882,9 +882,9 @@ testing/** @angular/fw-test /aio/content/guide/deprecations.md @angular/fw-docs-packaging @angular/framework-global-approvers @angular/framework-global-approvers-for-docs-only-changes /aio/content/guide/migration-renderer.md @angular/fw-docs-packaging @angular/framework-global-approvers @angular/framework-global-approvers-for-docs-only-changes /aio/content/guide/migration-undecorated-classes.md @angular/fw-docs-packaging @angular/framework-global-approvers @angular/framework-global-approvers-for-docs-only-changes -/aio/content/guide/migration-dynamic-flag.md @angular/fw-docs-packaging @angular/framework-global-approvers @angular/framework-global-approvers-for-docs-only-changes +/aio/content/guide/migration-dynamic-flag.md @angular/fw-docs-packaging @angular/framework-global-approvers @angular/framework-global-approvers-for-docs-only-changes /aio/content/guide/migration-injectable.md @angular/fw-docs-packaging @angular/framework-global-approvers @angular/framework-global-approvers-for-docs-only-changes - +/aio/content/guide/migration-localize.md @angular/fw-docs-packaging @angular/framework-global-approvers @angular/framework-global-approvers-for-docs-only-changes # ================================================ diff --git a/aio/content/guide/deprecations.md b/aio/content/guide/deprecations.md index 2e9cb96e66..c6fc6547d8 100644 --- a/aio/content/guide/deprecations.md +++ b/aio/content/guide/deprecations.md @@ -347,6 +347,13 @@ See the [dedicated migration guide for adding missing `@Injectable` decorators]( See the [dedicated migration guide for dynamic queries](guide/migration-dynamic-flag). +{@a localize-migration} +### Migrating to the new `$localize` i18n support + + See the [dedicated migration guide for `$localize`](guide/migration-localize). + + + {@a removed} ## Removed APIs diff --git a/aio/content/guide/migration-localize.md b/aio/content/guide/migration-localize.md new file mode 100644 index 0000000000..95ae9ea64e --- /dev/null +++ b/aio/content/guide/migration-localize.md @@ -0,0 +1,72 @@ +# `$localize` Global Import Migration + +## What does this schematic do? + +If you're using i18n, this schematic adds an import statement for `@angular/localize` to `polyfills.ts` that will look something like this: + +```ts +/****************************************************************** + * Load `$localize` - used if i18n tags appear in Angular templates. + */ +import '@angular/localize/init'; +``` + +It also lists `@angular/localize` as a dependency in your app's `package.json` to ensure the import is found. + +```json + +"dependencies": { + ... + "@angular/localize": "...", + ... +} + +``` + +`@angular/localize` is a new package that supports i18n of messages in Ivy applications. +This package requires a global `$localize` symbol to exist. +The symbol is loaded by importing the `@angular/localize/init` module, which has the side-effect of attaching it to the global scope. + +## Why is this migration necessary? + +Prior to Angular version 9, Angular's internationalization (i18n) system inlined translated messages into the compiled output as part of this template compilation. This approach required running the template compiler once per target locale, often leading to slow production build times. + +In the new i18n system, the Angular compiler tags i18n messages in the compiled code with a global `$localize` handler. +The inlining of translations then occurs as a post-compilation step for each locale. +Because the application does not need to be built again for each locale, this makes the process much faster. + +The post-compilation inlining step is optional—for example during development or if the translations will be inlined at runtime. +Therefore this global `$localize` must be available on the global scope at runtime. +To make `$localize` available on the global scope, each application must now import the `@angular/localize/init` module. +This has the side-effect of attaching a minimal implementation of `$localize` to the global scope. + +If this import is missing, you will see an error message like this: + +``` +Error: The global function `$localize` is missing. +Please add `import '@angular/localize/init';` to your polyfills.ts file. +``` + +This schematic automatically adds the `@angular/localize/init` import for you +if your app uses Angular's i18n APIs. + + +## Why is my tslint failing? + +The import of `@angular/localize/init` may cause a tslint error for `no-import-side-effect` because it adds to the global context (that is, a side effect). To fix this error, add the following to your `tslint.config`: + +```json + +"no-import-side-effect": [ + true, + { + "ignore-module": "(core-js/.*|zone\\.js/.*|@angular\/localize)$" + } +] + +``` + + +## Do I need to change how I write i18n in my Angular templates? + +The template syntax for i18n has not changed, so you will still want to use the `i18n` attribute as you did before.