@igo2/sdg-i18n 1.0.0-next.93

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/README.md ADDED
@@ -0,0 +1,3 @@
1
+ # I18n
2
+
3
+ This is base on @ngx-translate
@@ -0,0 +1,234 @@
1
+ import * as i0 from '@angular/core';
2
+ import { inject, PLATFORM_ID, signal, Injectable, makeEnvironmentProviders, provideAppInitializer } from '@angular/core';
3
+ import { of } from 'rxjs';
4
+ import * as i2 from '@angular/common';
5
+ import { DOCUMENT, isPlatformServer } from '@angular/common';
6
+ import { TitleResolver } from '@igo2/sdg-core';
7
+ import * as i3 from '@ngx-translate/core';
8
+ import { TranslateLoader, provideTranslateService, TRANSLATE_SERVICE_CONFIG } from '@ngx-translate/core';
9
+ export { TranslatePipe as TranslationPipe } from '@ngx-translate/core';
10
+ import { HttpBackend } from '@angular/common/http';
11
+ import { TRANSLATE_HTTP_LOADER_CONFIG, TranslateHttpLoader } from '@ngx-translate/http-loader';
12
+ import * as i1 from '@angular/router';
13
+
14
+ function provideTranslateHttpLoader(config = {}) {
15
+ return [
16
+ {
17
+ provide: TRANSLATE_HTTP_LOADER_CONFIG,
18
+ useFactory: provideHttpLoaderFactory(config)
19
+ },
20
+ {
21
+ provide: TranslateLoader,
22
+ useClass: TranslateHttpLoader,
23
+ deps: [HttpBackend, TRANSLATE_HTTP_LOADER_CONFIG]
24
+ }
25
+ ];
26
+ }
27
+ function provideHttpLoaderFactory(config) {
28
+ return () => {
29
+ const document = inject(DOCUMENT);
30
+ const platformId = inject(PLATFORM_ID);
31
+ const baseUrl = isPlatformServer(platformId) ? getServerUrl(document) : '';
32
+ return {
33
+ ...config,
34
+ prefix: `${baseUrl}${config.prefix ?? ''}`
35
+ };
36
+ };
37
+ }
38
+ function getServerUrl(document) {
39
+ const origin = document.location.origin;
40
+ return origin.endsWith('/') ? origin.slice(0, -1) : origin;
41
+ }
42
+
43
+ /**
44
+ *
45
+ * @param routerUrl
46
+ * @param lang
47
+ * @param strategy default to 'segment' set the first segment of the path (e.g., '/en/alerts' => 'en')
48
+ */
49
+ function parseUrlWithLanguage(routerUrl, lang) {
50
+ // eslint-disable-next-line prefer-const
51
+ let [url, params] = routerUrl.split('?');
52
+ const urlParts = url.split('/');
53
+ if (urlParts.length > 1) {
54
+ urlParts[1] = lang;
55
+ }
56
+ url = urlParts.join('/');
57
+ return [url, params];
58
+ }
59
+
60
+ class TranslationService {
61
+ router;
62
+ location;
63
+ translate;
64
+ lang = signal('fr');
65
+ constructor(router, location, translate) {
66
+ this.router = router;
67
+ this.location = location;
68
+ this.translate = translate;
69
+ this.lang.set(this.translate.getFallbackLang());
70
+ }
71
+ get currentLoader() {
72
+ return this.translate.currentLoader;
73
+ }
74
+ get(key, interpolateParams) {
75
+ return this.translate.instant(key, interpolateParams);
76
+ }
77
+ getAsync(key, interpolateParams) {
78
+ return this.translate.get(key, interpolateParams);
79
+ }
80
+ setLanguage(lang) {
81
+ const [url, params] = parseUrlWithLanguage(this.router.url, lang);
82
+ this.location.go(url, params);
83
+ window.location.reload();
84
+ }
85
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "19.2.14", ngImport: i0, type: TranslationService, deps: [{ token: i1.Router }, { token: i2.Location }, { token: i3.TranslateService }], target: i0.ɵɵFactoryTarget.Injectable });
86
+ static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "19.2.14", ngImport: i0, type: TranslationService, providedIn: 'root' });
87
+ }
88
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.2.14", ngImport: i0, type: TranslationService, decorators: [{
89
+ type: Injectable,
90
+ args: [{
91
+ providedIn: 'root'
92
+ }]
93
+ }], ctorParameters: () => [{ type: i1.Router }, { type: i2.Location }, { type: i3.TranslateService }] });
94
+
95
+ var TranslationFeatureKind;
96
+ (function (TranslationFeatureKind) {
97
+ TranslationFeatureKind[TranslationFeatureKind["Translation"] = 0] = "Translation";
98
+ TranslationFeatureKind[TranslationFeatureKind["RouterTitleResolver"] = 1] = "RouterTitleResolver";
99
+ TranslationFeatureKind[TranslationFeatureKind["DefaultLanguage"] = 2] = "DefaultLanguage";
100
+ TranslationFeatureKind[TranslationFeatureKind["WaitOnLoading"] = 3] = "WaitOnLoading";
101
+ })(TranslationFeatureKind || (TranslationFeatureKind = {}));
102
+ function provideTranslatedLabels(token, key) {
103
+ return {
104
+ provide: token,
105
+ useFactory: (translationService) => translationService.get(key),
106
+ deps: [TranslationService]
107
+ };
108
+ }
109
+ function provideTranslation(features, config) {
110
+ const providers = [];
111
+ for (const feature of features) {
112
+ providers.push(...feature.providers);
113
+ }
114
+ return makeEnvironmentProviders([
115
+ provideTranslateService({
116
+ ...(config ?? {}),
117
+ loader: getLoader(config?.loader)
118
+ }),
119
+ ...providers
120
+ ]);
121
+ }
122
+ function getLoader(loader) {
123
+ return loader && isProvider(loader)
124
+ ? loader
125
+ : provideTranslateHttpLoader({
126
+ prefix: '/locale/',
127
+ suffix: '.json',
128
+ useHttpBackend: true,
129
+ ...(loader ?? {})
130
+ });
131
+ }
132
+ function isProvider(obj) {
133
+ return obj.provide !== undefined;
134
+ }
135
+ /**
136
+ * Provide a translater for the Route title.
137
+ * Some components is base on the title of the route and
138
+ * this Resolver will allow to automatically resolve the translation
139
+ **/
140
+ function withRouterTitleResolver(resolver) {
141
+ return {
142
+ kind: TranslationFeatureKind.RouterTitleResolver,
143
+ providers: [
144
+ {
145
+ provide: (TitleResolver),
146
+ useClass: resolver
147
+ }
148
+ ]
149
+ };
150
+ }
151
+ /**
152
+ * Get the first segment of the path (e.g., '/en/alerts' => 'en')
153
+ * @param allowedLanguages default to ['fr', 'en']
154
+ */
155
+ function withLanguageFromUrl(fallbackLang, allowedLanguages = ['fr', 'en']) {
156
+ return {
157
+ kind: TranslationFeatureKind.DefaultLanguage,
158
+ providers: [
159
+ {
160
+ provide: TRANSLATE_SERVICE_CONFIG,
161
+ useFactory: defaultLanguageSegmentFactory(allowedLanguages, fallbackLang)
162
+ }
163
+ ]
164
+ };
165
+ }
166
+ function withWaitOnI18nReady() {
167
+ return {
168
+ kind: TranslationFeatureKind.WaitOnLoading,
169
+ providers: [
170
+ provideAppInitializer(() => {
171
+ const translationService = inject(TranslationService);
172
+ return translationService.translate.use(translationService.lang());
173
+ })
174
+ ]
175
+ };
176
+ }
177
+ function defaultLanguageSegmentFactory(allowedLanguages, fallbackLang) {
178
+ return () => {
179
+ const defaultConfig = {
180
+ extend: true
181
+ };
182
+ const doc = inject(DOCUMENT);
183
+ const url = new URL(doc.location.href);
184
+ const langInSegment = url.pathname.split('/').filter(Boolean)[0];
185
+ if (allowedLanguages.includes(langInSegment)) {
186
+ return {
187
+ ...defaultConfig,
188
+ lang: langInSegment,
189
+ fallbackLang: langInSegment
190
+ };
191
+ }
192
+ return {
193
+ ...defaultConfig,
194
+ lang: fallbackLang,
195
+ fallbackLang: fallbackLang ?? 'fr'
196
+ };
197
+ };
198
+ }
199
+
200
+ function withTranslationMock() {
201
+ return {
202
+ kind: TranslationFeatureKind.Translation,
203
+ providers: [
204
+ { provide: TranslationService, useClass: TranslationServiceMock }
205
+ ]
206
+ };
207
+ }
208
+ class TranslationServiceMock extends TranslationService {
209
+ lang = signal('fr');
210
+ get(key) {
211
+ return Array.isArray(key) ? key[0] : key;
212
+ }
213
+ getAsync(key) {
214
+ return of(Array.isArray(key) ? key[0] : key);
215
+ }
216
+ setLanguage() {
217
+ window.location.reload();
218
+ }
219
+ }
220
+
221
+ function labelAttribute(value, defaultValue = {}) {
222
+ return value ? { ...defaultValue, ...value } : defaultValue;
223
+ }
224
+
225
+ /*
226
+ * Public API Surface of i18n
227
+ */
228
+
229
+ /**
230
+ * Generated bundle index. Do not edit.
231
+ */
232
+
233
+ export { TranslationFeatureKind, TranslationService, TranslationServiceMock, labelAttribute, parseUrlWithLanguage, provideTranslatedLabels, provideTranslation, withLanguageFromUrl, withRouterTitleResolver, withTranslationMock, withWaitOnI18nReady };
234
+ //# sourceMappingURL=igo2-sdg-i18n.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"igo2-sdg-i18n.mjs","sources":["../../../packages/i18n/src/translation-loader.ts","../../../packages/i18n/src/translation.utils.ts","../../../packages/i18n/src/translation.service.ts","../../../packages/i18n/src/translation.provider.ts","../../../packages/i18n/src/translation-mock.provider.ts","../../../packages/i18n/src/utils/coercion.ts","../../../packages/i18n/src/public-api.ts","../../../packages/i18n/src/igo2-sdg-i18n.ts"],"sourcesContent":["import { DOCUMENT, isPlatformServer } from '@angular/common';\nimport { HttpBackend } from '@angular/common/http';\nimport { PLATFORM_ID, inject } from '@angular/core';\n\nimport { TranslateLoader } from '@ngx-translate/core';\nimport {\n TranslateHttpLoaderConfig as NgxTranslateHttpLoaderConfig,\n TRANSLATE_HTTP_LOADER_CONFIG,\n TranslateHttpLoader\n} from '@ngx-translate/http-loader';\n\nexport type TranslateHttpLoaderConfig = NgxTranslateHttpLoaderConfig;\n\nexport function provideTranslateHttpLoader(\n config: Partial<TranslateHttpLoaderConfig> = {}\n) {\n return [\n {\n provide: TRANSLATE_HTTP_LOADER_CONFIG,\n useFactory: provideHttpLoaderFactory(config)\n },\n {\n provide: TranslateLoader,\n useClass: TranslateHttpLoader,\n deps: [HttpBackend, TRANSLATE_HTTP_LOADER_CONFIG]\n }\n ];\n}\n\nfunction provideHttpLoaderFactory(config: Partial<TranslateHttpLoaderConfig>) {\n return () => {\n const document = inject(DOCUMENT);\n const platformId = inject(PLATFORM_ID);\n const baseUrl = isPlatformServer(platformId) ? getServerUrl(document) : '';\n return {\n ...config,\n prefix: `${baseUrl}${config.prefix ?? ''}`\n };\n };\n}\nfunction getServerUrl(document: Document) {\n const origin = document.location.origin;\n return origin.endsWith('/') ? origin.slice(0, -1) : origin;\n}\n","/**\n *\n * @param routerUrl\n * @param lang\n * @param strategy default to 'segment' set the first segment of the path (e.g., '/en/alerts' => 'en')\n */\nexport function parseUrlWithLanguage(\n routerUrl: string,\n lang: string\n): [url: string, params: string | undefined] {\n // eslint-disable-next-line prefer-const\n let [url, params] = routerUrl.split('?');\n\n const urlParts = url.split('/');\n if (urlParts.length > 1) {\n urlParts[1] = lang;\n }\n\n url = urlParts.join('/');\n\n return [url, params];\n}\n","import { Location } from '@angular/common';\nimport { Injectable, WritableSignal, signal } from '@angular/core';\nimport { Router } from '@angular/router';\n\nimport {\n TranslateService,\n Translation,\n TranslationObject\n} from '@ngx-translate/core';\nimport { Observable } from 'rxjs';\n\nimport { Language } from './translation.interface';\nimport { parseUrlWithLanguage } from './translation.utils';\n\n@Injectable({\n providedIn: 'root'\n})\nexport class TranslationService {\n lang: WritableSignal<Language> = signal('fr');\n\n constructor(\n public router: Router,\n public location: Location,\n public translate: TranslateService\n ) {\n this.lang.set(this.translate.getFallbackLang() as Language);\n }\n\n get currentLoader() {\n return this.translate.currentLoader;\n }\n\n get(\n key: string | string[],\n interpolateParams?: Record<string, unknown>\n ): Translation | TranslationObject {\n return this.translate.instant(key, interpolateParams);\n }\n\n getAsync(\n key: string | string[],\n interpolateParams?: Record<string, unknown>\n ): Observable<Translation | TranslationObject> {\n return this.translate.get(key, interpolateParams);\n }\n\n setLanguage(lang: string) {\n const [url, params] = parseUrlWithLanguage(this.router.url, lang);\n this.location.go(url, params);\n window.location.reload();\n }\n}\n","import { DOCUMENT } from '@angular/common';\nimport {\n EnvironmentProviders,\n InjectionToken,\n Provider,\n Type,\n inject,\n makeEnvironmentProviders,\n provideAppInitializer\n} from '@angular/core';\n\nimport { TitleResolver } from '@igo2/sdg-core';\n\nimport {\n Language,\n RootTranslateServiceConfig,\n TRANSLATE_SERVICE_CONFIG,\n TranslateServiceConfig,\n provideTranslateService\n} from '@ngx-translate/core';\n\nimport {\n TranslateHttpLoaderConfig,\n provideTranslateHttpLoader\n} from './translation-loader';\nimport { TranslationService } from './translation.service';\n\nexport interface TranslationFeature<KindT extends TranslationFeatureKind> {\n kind: KindT;\n providers: (Provider | EnvironmentProviders)[];\n}\n\nexport enum TranslationFeatureKind {\n Translation = 0,\n RouterTitleResolver = 1,\n DefaultLanguage = 2,\n WaitOnLoading = 3\n}\n\nexport function provideTranslatedLabels(\n token: InjectionToken<unknown>,\n key: string\n) {\n return {\n provide: token,\n useFactory: (translationService: TranslationService) =>\n translationService.get(key),\n deps: [TranslationService]\n };\n}\n\nexport function provideTranslation(\n features: TranslationFeature<TranslationFeatureKind>[],\n config?: RootTranslateServiceConfig & {\n loader: Partial<TranslateHttpLoaderConfig>;\n }\n) {\n const providers: (Provider | EnvironmentProviders)[] = [];\n\n for (const feature of features) {\n providers.push(...feature.providers);\n }\n\n return makeEnvironmentProviders([\n provideTranslateService({\n ...(config ?? {}),\n loader: getLoader(config?.loader)\n }),\n ...providers\n ]);\n}\n\nfunction getLoader(\n loader: Provider | Partial<TranslateHttpLoaderConfig> | undefined\n) {\n return loader && isProvider(loader)\n ? loader\n : provideTranslateHttpLoader({\n prefix: '/locale/',\n suffix: '.json',\n useHttpBackend: true,\n ...(loader ?? {})\n });\n}\n\nfunction isProvider(obj: any): obj is Provider {\n return (obj as any).provide !== undefined;\n}\n\n/**\n * Provide a translater for the Route title.\n * Some components is base on the title of the route and\n * this Resolver will allow to automatically resolve the translation\n **/\nexport function withRouterTitleResolver<T>(\n resolver: Type<TitleResolver<T>>\n): TranslationFeature<TranslationFeatureKind.RouterTitleResolver> {\n return {\n kind: TranslationFeatureKind.RouterTitleResolver,\n providers: [\n {\n provide: TitleResolver<T>,\n useClass: resolver\n }\n ]\n };\n}\n\n/**\n * Get the first segment of the path (e.g., '/en/alerts' => 'en')\n * @param allowedLanguages default to ['fr', 'en']\n */\nexport function withLanguageFromUrl(\n fallbackLang?: Language,\n allowedLanguages: Language[] = ['fr', 'en']\n): TranslationFeature<TranslationFeatureKind.DefaultLanguage> {\n return {\n kind: TranslationFeatureKind.DefaultLanguage,\n providers: [\n {\n provide: TRANSLATE_SERVICE_CONFIG,\n useFactory: defaultLanguageSegmentFactory(\n allowedLanguages,\n fallbackLang\n )\n }\n ]\n };\n}\n\nexport function withWaitOnI18nReady(): TranslationFeature<TranslationFeatureKind.WaitOnLoading> {\n return {\n kind: TranslationFeatureKind.WaitOnLoading,\n providers: [\n provideAppInitializer(() => {\n const translationService = inject(TranslationService);\n return translationService.translate.use(translationService.lang());\n })\n ]\n };\n}\n\nfunction defaultLanguageSegmentFactory(\n allowedLanguages: Language[],\n fallbackLang?: Language\n): () => TranslateServiceConfig {\n return () => {\n const defaultConfig = {\n extend: true\n } satisfies TranslateServiceConfig;\n const doc = inject(DOCUMENT);\n const url = new URL(doc.location.href);\n\n const langInSegment = url.pathname.split('/').filter(Boolean)[0];\n if (allowedLanguages.includes(langInSegment)) {\n return {\n ...defaultConfig,\n lang: langInSegment,\n fallbackLang: langInSegment\n };\n }\n\n return {\n ...defaultConfig,\n lang: fallbackLang,\n fallbackLang: fallbackLang ?? 'fr'\n };\n };\n}\n","import { WritableSignal, signal } from '@angular/core';\n\nimport { Observable, of } from 'rxjs';\n\nimport { Language } from './translation.interface';\nimport {\n TranslationFeature,\n TranslationFeatureKind\n} from './translation.provider';\nimport { TranslationService } from './translation.service';\n\nexport function withTranslationMock(): TranslationFeature<TranslationFeatureKind.Translation> {\n return {\n kind: TranslationFeatureKind.Translation,\n providers: [\n { provide: TranslationService, useClass: TranslationServiceMock }\n ]\n };\n}\n\nexport class TranslationServiceMock extends TranslationService {\n override lang: WritableSignal<Language> = signal('fr');\n\n override get(key: string | string[]): string {\n return Array.isArray(key) ? key[0] : key;\n }\n\n override getAsync(key: string | string[]): Observable<string> {\n return of(Array.isArray(key) ? key[0] : key);\n }\n\n override setLanguage() {\n window.location.reload();\n }\n}\n","import { Translation, TranslationObject } from '../translation.interface';\n\nexport function labelAttribute(\n value: Translation | TranslationObject,\n defaultValue: Translation | TranslationObject = {}\n): Translation | TranslationObject {\n return value ? { ...defaultValue, ...value } : defaultValue;\n}\n","/*\n * Public API Surface of i18n\n */\n\nexport * from './translation-mock.provider';\nexport * from './translation.interface';\nexport * from './translation.provider';\nexport * from './translation.service';\nexport * from './translation.utils';\nexport * from './utils';\n\nexport { TranslatePipe as TranslationPipe } from '@ngx-translate/core';\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './public-api';\n"],"names":[],"mappings":"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"}
package/index.d.ts ADDED
@@ -0,0 +1,5 @@
1
+ /**
2
+ * Generated bundle index. Do not edit.
3
+ */
4
+ /// <amd-module name="@igo2/sdg-i18n" />
5
+ export * from './public-api';
package/package.json ADDED
@@ -0,0 +1,32 @@
1
+ {
2
+ "name": "@igo2/sdg-i18n",
3
+ "version": "1.0.0-next.93",
4
+ "license": "LiLiQ-R",
5
+ "repository": {
6
+ "type": "git",
7
+ "url": "git+https://github.com/infra-geo-ouverte/sdg.git",
8
+ "directory": "packages/i18n"
9
+ },
10
+ "exports": {
11
+ ".": {
12
+ "types": "./index.d.ts",
13
+ "default": "./fesm2022/igo2-sdg-i18n.mjs"
14
+ },
15
+ "./package.json": {
16
+ "default": "./package.json"
17
+ }
18
+ },
19
+ "peerDependencies": {
20
+ "@angular/common": "^19.2.0",
21
+ "@angular/core": "^19.2.0",
22
+ "@igo2/sdg-core": "^1.0.0-next.93",
23
+ "@ngx-translate/core": "^17.0.0",
24
+ "@ngx-translate/http-loader": "^17.0.0"
25
+ },
26
+ "dependencies": {
27
+ "tslib": "^2.3.0"
28
+ },
29
+ "sideEffects": false,
30
+ "module": "fesm2022/igo2-sdg-i18n.mjs",
31
+ "typings": "index.d.ts"
32
+ }
@@ -0,0 +1,7 @@
1
+ export * from './translation-mock.provider';
2
+ export * from './translation.interface';
3
+ export * from './translation.provider';
4
+ export * from './translation.service';
5
+ export * from './translation.utils';
6
+ export * from './utils';
7
+ export { TranslatePipe as TranslationPipe } from '@ngx-translate/core';
@@ -0,0 +1,20 @@
1
+ import { HttpBackend } from '@angular/common/http';
2
+ import { TranslateLoader } from '@ngx-translate/core';
3
+ import { TranslateHttpLoaderConfig as NgxTranslateHttpLoaderConfig, TranslateHttpLoader } from '@ngx-translate/http-loader';
4
+ export type TranslateHttpLoaderConfig = NgxTranslateHttpLoaderConfig;
5
+ export declare function provideTranslateHttpLoader(config?: Partial<TranslateHttpLoaderConfig>): ({
6
+ provide: import("@angular/core").InjectionToken<Partial<NgxTranslateHttpLoaderConfig>>;
7
+ useFactory: () => {
8
+ prefix: string;
9
+ suffix?: string | undefined;
10
+ enforceLoading?: boolean | undefined;
11
+ useHttpBackend?: boolean | undefined;
12
+ };
13
+ useClass?: undefined;
14
+ deps?: undefined;
15
+ } | {
16
+ provide: typeof TranslateLoader;
17
+ useClass: typeof TranslateHttpLoader;
18
+ deps: (import("@angular/core").InjectionToken<Partial<NgxTranslateHttpLoaderConfig>> | typeof HttpBackend)[];
19
+ useFactory?: undefined;
20
+ })[];
@@ -0,0 +1,12 @@
1
+ import { WritableSignal } from '@angular/core';
2
+ import { Observable } from 'rxjs';
3
+ import { Language } from './translation.interface';
4
+ import { TranslationFeature, TranslationFeatureKind } from './translation.provider';
5
+ import { TranslationService } from './translation.service';
6
+ export declare function withTranslationMock(): TranslationFeature<TranslationFeatureKind.Translation>;
7
+ export declare class TranslationServiceMock extends TranslationService {
8
+ lang: WritableSignal<Language>;
9
+ get(key: string | string[]): string;
10
+ getAsync(key: string | string[]): Observable<string>;
11
+ setLanguage(): void;
12
+ }
@@ -0,0 +1,5 @@
1
+ export type Language = 'fr' | 'en';
2
+ export type Translation = string | Translation[] | TranslationObject | any;
3
+ export interface TranslationObject {
4
+ [key: string]: Translation;
5
+ }
@@ -0,0 +1,35 @@
1
+ import { EnvironmentProviders, InjectionToken, Provider, Type } from '@angular/core';
2
+ import { TitleResolver } from '@igo2/sdg-core';
3
+ import { Language, RootTranslateServiceConfig } from '@ngx-translate/core';
4
+ import { TranslateHttpLoaderConfig } from './translation-loader';
5
+ import { TranslationService } from './translation.service';
6
+ export interface TranslationFeature<KindT extends TranslationFeatureKind> {
7
+ kind: KindT;
8
+ providers: (Provider | EnvironmentProviders)[];
9
+ }
10
+ export declare enum TranslationFeatureKind {
11
+ Translation = 0,
12
+ RouterTitleResolver = 1,
13
+ DefaultLanguage = 2,
14
+ WaitOnLoading = 3
15
+ }
16
+ export declare function provideTranslatedLabels(token: InjectionToken<unknown>, key: string): {
17
+ provide: InjectionToken<unknown>;
18
+ useFactory: (translationService: TranslationService) => any;
19
+ deps: (typeof TranslationService)[];
20
+ };
21
+ export declare function provideTranslation(features: TranslationFeature<TranslationFeatureKind>[], config?: RootTranslateServiceConfig & {
22
+ loader: Partial<TranslateHttpLoaderConfig>;
23
+ }): EnvironmentProviders;
24
+ /**
25
+ * Provide a translater for the Route title.
26
+ * Some components is base on the title of the route and
27
+ * this Resolver will allow to automatically resolve the translation
28
+ **/
29
+ export declare function withRouterTitleResolver<T>(resolver: Type<TitleResolver<T>>): TranslationFeature<TranslationFeatureKind.RouterTitleResolver>;
30
+ /**
31
+ * Get the first segment of the path (e.g., '/en/alerts' => 'en')
32
+ * @param allowedLanguages default to ['fr', 'en']
33
+ */
34
+ export declare function withLanguageFromUrl(fallbackLang?: Language, allowedLanguages?: Language[]): TranslationFeature<TranslationFeatureKind.DefaultLanguage>;
35
+ export declare function withWaitOnI18nReady(): TranslationFeature<TranslationFeatureKind.WaitOnLoading>;
@@ -0,0 +1,20 @@
1
+ import { Location } from '@angular/common';
2
+ import { WritableSignal } from '@angular/core';
3
+ import { Router } from '@angular/router';
4
+ import { TranslateService, Translation, TranslationObject } from '@ngx-translate/core';
5
+ import { Observable } from 'rxjs';
6
+ import { Language } from './translation.interface';
7
+ import * as i0 from "@angular/core";
8
+ export declare class TranslationService {
9
+ router: Router;
10
+ location: Location;
11
+ translate: TranslateService;
12
+ lang: WritableSignal<Language>;
13
+ constructor(router: Router, location: Location, translate: TranslateService);
14
+ get currentLoader(): import("@ngx-translate/core").TranslateLoader;
15
+ get(key: string | string[], interpolateParams?: Record<string, unknown>): Translation | TranslationObject;
16
+ getAsync(key: string | string[], interpolateParams?: Record<string, unknown>): Observable<Translation | TranslationObject>;
17
+ setLanguage(lang: string): void;
18
+ static ɵfac: i0.ɵɵFactoryDeclaration<TranslationService, never>;
19
+ static ɵprov: i0.ɵɵInjectableDeclaration<TranslationService>;
20
+ }
@@ -0,0 +1,7 @@
1
+ /**
2
+ *
3
+ * @param routerUrl
4
+ * @param lang
5
+ * @param strategy default to 'segment' set the first segment of the path (e.g., '/en/alerts' => 'en')
6
+ */
7
+ export declare function parseUrlWithLanguage(routerUrl: string, lang: string): [url: string, params: string | undefined];
@@ -0,0 +1,2 @@
1
+ import { Translation, TranslationObject } from '../translation.interface';
2
+ export declare function labelAttribute(value: Translation | TranslationObject, defaultValue?: Translation | TranslationObject): Translation | TranslationObject;
@@ -0,0 +1 @@
1
+ export * from './coercion';