From a9ff48e67fc3fbc4bebec2de179687c4e342ccd0 Mon Sep 17 00:00:00 2001 From: Pete Bacon Darwin Date: Thu, 5 Sep 2019 11:40:00 +0100 Subject: [PATCH] fix(core): improve the "missing `$localize`" error message (#32491) We need to be clearer to developers who upgrade to v9 (next) and get this error, why they have a problem and what they have to do about it. Once we have a better CLI schematics story, where this import will be included by default in new applications and a CLI migration will add it when upgrading apps to v9, we could simplify or remove this error message. PR Close #32491 --- integration/side-effects/snapshots/core/esm2015.js | 2 +- integration/side-effects/snapshots/core/esm5.js | 2 +- packages/core/src/core.ts | 4 +++- 3 files changed, 5 insertions(+), 3 deletions(-) diff --git a/integration/side-effects/snapshots/core/esm2015.js b/integration/side-effects/snapshots/core/esm2015.js index 47de5e87133b38..3c9b0a8fee2e95 100644 --- a/integration/side-effects/snapshots/core/esm2015.js +++ b/integration/side-effects/snapshots/core/esm2015.js @@ -13,5 +13,5 @@ const __global = "undefined" !== typeof global && global; const _global = __globalThis || __global || __window || __self; if (ngDevMode) _global.$localize = _global.$localize || function() { - throw new Error("The global function `$localize` is missing. Please add `import '@angular/localize';` to your polyfills.ts file."); + throw new Error("It looks like your application or one of its dependencies is using i18n.\n" + "Angular 9 introduced a global `$localize()` function that needs to be loaded.\n" + "Please add `import '@angular/localize';` to your polyfills.ts file."); }; diff --git a/integration/side-effects/snapshots/core/esm5.js b/integration/side-effects/snapshots/core/esm5.js index d5fd28b2d86ecb..ba58f35bd71c13 100644 --- a/integration/side-effects/snapshots/core/esm5.js +++ b/integration/side-effects/snapshots/core/esm5.js @@ -15,5 +15,5 @@ var __global = "undefined" !== typeof global && global; var _global = __globalThis || __global || __window || __self; if (ngDevMode) _global.$localize = _global.$localize || function() { - throw new Error("The global function `$localize` is missing. Please add `import '@angular/localize';` to your polyfills.ts file."); + throw new Error("It looks like your application or one of its dependencies is using i18n.\n" + "Angular 9 introduced a global `$localize()` function that needs to be loaded.\n" + "Please add `import '@angular/localize';` to your polyfills.ts file."); }; diff --git a/packages/core/src/core.ts b/packages/core/src/core.ts index 598d681e4b7287..4b66d5f5f3b279 100644 --- a/packages/core/src/core.ts +++ b/packages/core/src/core.ts @@ -45,6 +45,8 @@ if (ngDevMode) { // tslint:disable-next-line: no-toplevel-property-access global.$localize = global.$localize || function() { throw new Error( - 'The global function `$localize` is missing. Please add `import \'@angular/localize\';` to your polyfills.ts file.'); + 'It looks like your application or one of its dependencies is using i18n.\n' + + 'Angular 9 introduced a global `$localize()` function that needs to be loaded.\n' + + 'Please add `import \'@angular/localize\';` to your polyfills.ts file.'); }; }