From b2d4415caa486bebe55e6147a153f120cf08b070 Mon Sep 17 00:00:00 2001 From: Alan Agius Date: Fri, 9 Dec 2022 08:08:54 +0000 Subject: [PATCH] fix(@angular-devkit/build-angular): update locale setting snippet to use `globalThis`. This commit changes how we set the `LOCALE_ID` when using the `localize` option - We now include the locale setting snippet only in the main bundle. - We use `globalThis` to set the the value globally and be accessible across module boundaries. This is important as in some causes such as when using MF `@angular/core` can be located in a bundles others than `main` and `vendor`. (cherry picked from commit afe9feaa45913cbebe7f22c678d693d96f38584a) --- .../angular_devkit/build_angular/src/utils/i18n-inlining.ts | 2 +- .../angular_devkit/build_angular/src/utils/process-bundle.ts | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/packages/angular_devkit/build_angular/src/utils/i18n-inlining.ts b/packages/angular_devkit/build_angular/src/utils/i18n-inlining.ts index beb5734db539..4c32203e67f3 100644 --- a/packages/angular_devkit/build_angular/src/utils/i18n-inlining.ts +++ b/packages/angular_devkit/build_angular/src/utils/i18n-inlining.ts @@ -42,7 +42,7 @@ function emittedFilesToInlineOptions( code: fs.readFileSync(originalPath, 'utf8'), outputPath, missingTranslation, - setLocale: emittedFile.name === 'main' || emittedFile.name === 'vendor', + setLocale: emittedFile.name === 'main', }; originalFiles.push(originalPath); diff --git a/packages/angular_devkit/build_angular/src/utils/process-bundle.ts b/packages/angular_devkit/build_angular/src/utils/process-bundle.ts index 3017163e7ce4..90beec2d0b07 100644 --- a/packages/angular_devkit/build_angular/src/utils/process-bundle.ts +++ b/packages/angular_devkit/build_angular/src/utils/process-bundle.ts @@ -272,7 +272,7 @@ async function inlineLocalesDirect(ast: ParseResult, options: InlineOptions) { let outputSource: import('webpack').sources.Source = content; if (options.setLocale) { - const setLocaleText = `var $localize=Object.assign(void 0===$localize?{}:$localize,{locale:"${locale}"});\n`; + const setLocaleText = `globalThis.$localize=Object.assign(globalThis.$localize || {},{locale:"${locale}"});\n`; // If locale data is provided, load it and prepend to file let localeDataSource;