Movatterモバイル変換


[0]ホーム

URL:


Transloco v8 is now available in preview! Give it a try and share your feedback 🎉
Transloco Angular i18n
LogoLogo
CtrlK
On this page

Scoped Library Extractor

In some cases, you may need to include translations within your npm libraries, especially in a monorepo environment. This allows you to keep translation files inside the library's folder and package them together. However, loading translation files directly from the library can be challenging for two main reasons:

  1. The application’s public directory isn't directly accessible.

  2. Webpack dynamic imports don’t work with libraries.

To overcome these issues, the only option is to load the translation files from the application's public folder. This means you would need to manually copy the translation files from the library to the application's translation folder, which can be repetitive and error-prone.

This is where theScoped Library Extractor tool comes in, which automates this process for you.

Example Setup

Let's consider a monorepo with the following structure:

📦 projects ┣ 📂 core ┃ ┣ 📂 src ┃ ┃ ┣ 📂 lib ┃ ┃ ┃ ┣ core.component.ts ┃ ┃ ┃ ┣ core.module.ts ┃ ┃ ┃ ┣ 📂 i18n ┃ ┃ ┃ ┃ ┣ en.json ┃ ┃ ┃ ┃ ┗ es.json ┃ ┃ ┣ public-api.ts ┣ ng-package.json ┣ package.json📦 src ┣ 📂 app ┃ ┣ app.component.html ┃ ┣ app.component.ts ┃ ┣ app.module.ts ┃ ┗ transloco.loader.ts ┣ 📂 assets ┃ ┣ 📂 i18n ┃ ┃ ┣ en.json ┃ ┃ ┗ es.json

Here, we have acore library with its own translation files located underprojects/core/src/lib/i18n. To use these translations in our application, we need to configure the library’s translations in theCoreModule.

1

Declare the Translation Scope

In theCoreModule, provide the scope for the translations:

core.module.ts
import { provideTranslocoScope } from './transloco.providers';@NgModule({  declarations: [CoreComponent],  providers: [provideTranslocoScope('core')],  imports: [TranslocoModule],})export class CoreModule {}

Then, in theCoreComponent, use the translations with the defined scope:

lib-core.component.html
<ng-container *transloco="let t">  {{ t('core.title') }}</ng-container>
2

Install the Scoped Library Extractor

pnpm add @jsverse/transloco-scoped-libs --save-dev
yarn add @jsverse/transloco-scoped-libs --dev
npm install @jsverse/transloco-scoped-libs --save-dev
3

Configure the Library'spackage.json

In thecore library’spackage.json, add ani18n configuration that specifies the scope and translation path:

projects/core/package.json
{  "name": "@app/core",  "i18n": [    {      "scope": "core",      "path": "src/lib/i18n"    }  ]}
4

Configure the Global Transloco Config

In your globaltransloco.config.ts, add the path to the library in thescopedLibs configuration:

transloco.config.ts
const config: TranslocoGlobalConfig = {    scopedLibs: ['./projects/core/', '@lib/name']};

If you need to specify multiple destinations for the extracted files, you can also use an object configuration:

transloco.config.ts
const config: TranslocoGlobalConfig = {  scopedLibs: [    {      src: './projects/core',      dist: ['./projects/spa/src/assets/i18n', './src/assets/i18n/']    }  ]};
5

Add the Extractor Script

Finally, add a script to the mainpackage.json to run the extractor, you can also enable "watch mode" by adding the--watch flag:

package.json
"scripts": {  "transloco:extract-scoped-libs": "transloco-scoped-libs --watch"}
6

Run the Script

Now, run the script to extract the translation files from the library and copy them to the main project's translation folder:

pnpm transloco:extract-scoped-libs

This script will:

  • Extract the translation files from the library.

  • Copy them to the main project'ssrc/assets/i18n folder.

  • Add the library’s translation files to.gitignore (use the--skip-gitignore flag if you want to skip this step).

Join Strategies

The tool supports two strategies for handling translations:

  1. Default Strategy: The translation files from the library will be copied individually into the main project's translation folder.

  2. Join Strategy: All translation files from the library will be combined into a single file (e.g.,en.vendor.json), which can then be loaded alongside the main translation files.

To use theJoin Strategy, modify thepackage.json of the library:

projects/core/package.json
{  "name": "@app/core",  "i18n": [    {      "scope": "core",      "path": "src/lib/i18n",      "strategy": "join"    }  ]}

Then, in your application loader, you can use the following setup to load both the main and vendor translations:

// transloco-loader.ts@Injectable({ providedIn: 'root' })export class HttpLoader implements TranslocoLoader {  constructor(private http: HttpClient) {}  getTranslation(lang: string, { scope }) {    const base = this.http.get(`/assets/i18n/${lang}.json`);    if (scope) {      return base;    }    return forkJoin([      base,      this.http.get(`/assets/i18n/${lang}.vendor.json`),    ]).pipe(      map(([translation, vendor]) => {        return { ...translation, ...vendor };      }),    );  }}export const httpLoader = { provide: TRANSLOCO_LOADER, useClass: HttpLoader };

Use with Webpack

To add custom Webpack support, use a tool likengx-build-plus and include the plugin in yourwebpack.config.js:

const TranslocoScopedLibsWebpackPlugin = require('@jsverse/transloco-scoped-libs/webpack');module.exports = {  plugins: [new TranslocoScopedLibsWebpackPlugin()],};

This solution ensures that translation files from libraries are easily extracted, joined, and integrated into your application.

Last updated

Was this helpful?


[8]ページ先頭

©2009-2025 Movatter.jp