@jsverse/transloco
Version:
The internationalization (i18n) library for Angular
99 lines • 15.2 kB
JavaScript
import { assertInInjectionContext, computed, inject, Injector, isSignal, runInInjectionContext, } from '@angular/core';
import { toObservable, toSignal } from '@angular/core/rxjs-interop';
import { switchMap } from 'rxjs';
import { TRANSLOCO_SCOPE } from './transloco-scope';
import { TranslocoService } from './transloco.service';
/**
* Gets the translated value of a key as Signal
*
* @example
* text = translateSignal('hello');
* textList = translateSignal(['green', 'blue']);
* textVar = translateSignal('hello', { variable: 'world' });
* textSpanish = translateSignal('hello', { variable: 'world' }, 'es');
* textTodosScope = translateSignal('hello', { variable: 'world' }, { scope: 'todos' });
*
* @example
* dynamicKey = signal('hello');
* dynamicParam = signal({ variable: 'world' });
* text = translateSignal(this.dynamicKey, this.dynamicParam);
*
*/
export function translateSignal(key, params, lang, injector) {
if (!injector) {
assertInInjectionContext(translateSignal);
}
injector ??= inject(Injector);
const result = runInInjectionContext(injector, () => {
const service = inject(TranslocoService);
const scope = resolveScope(lang);
return toObservable(computerKeysAndParams(key, params)).pipe(switchMap((dynamic) => service.selectTranslate(dynamic.key, dynamic.params, scope)));
});
return toSignal(result, { initialValue: Array.isArray(key) ? [''] : '' });
}
/**
* Gets the translated object of a key as Signal
*
* @example
* object = translateObjectSignal('nested.object');
* title = object().title;
*
* @example
* dynamicKey = signal('nested.object');
* dynamicParam = signal({ variable: 'world' });
* object = translateObjectSignal(this.dynamicKey, this.dynamicParam);
*/
export function translateObjectSignal(key, params, lang, injector) {
if (!injector) {
assertInInjectionContext(translateObjectSignal);
}
injector ??= inject(Injector);
const result = runInInjectionContext(injector, () => {
const service = inject(TranslocoService);
const scope = resolveScope(lang);
return toObservable(computerKeysAndParams(key, params)).pipe(switchMap((dynamic) => service.selectTranslateObject(dynamic.key, dynamic.params, scope)));
});
return toSignal(result, { initialValue: Array.isArray(key) ? [] : {} });
}
function computerParams(params) {
if (isSignal(params)) {
return computed(() => params());
}
return computed(() => {
return Object.entries(params).reduce((acc, [key, value]) => {
acc[key] = isSignal(value) ? value() : value;
return acc;
}, {});
});
}
function computerKeys(keys) {
if (Array.isArray(keys)) {
return computed(() => keys.map((key) => (isSignal(key) ? key() : key)));
}
return computed(() => keys());
}
function isSignalKey(key) {
return Array.isArray(key) ? key.some(isSignal) : isSignal(key);
}
function isSignalParams(params) {
return params
? isSignal(params) || Object.values(params).some(isSignal)
: false;
}
function computerKeysAndParams(key, params) {
const computedKeys = isSignalKey(key)
? computerKeys(key)
: computed(() => key);
const computedParams = isSignalParams(params)
? computerParams(params)
: computed(() => params);
return computed(() => ({ key: computedKeys(), params: computedParams() }));
}
function resolveScope(scope) {
if (typeof scope === 'undefined' || scope === '') {
const translocoScope = inject(TRANSLOCO_SCOPE, { optional: true });
return translocoScope ?? undefined;
}
return scope;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"transloco.signal.js","sourceRoot":"","sources":["../../../../../libs/transloco/src/lib/transloco.signal.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  assertInInjectionContext,\n  computed,\n  inject,\n  Injector,\n  isSignal,\n  runInInjectionContext,\n  Signal,\n} from '@angular/core';\nimport { toObservable, toSignal } from '@angular/core/rxjs-interop';\nimport { switchMap } from 'rxjs';\n\nimport { TRANSLOCO_SCOPE } from './transloco-scope';\nimport { TranslocoService } from './transloco.service';\nimport { HashMap, Translation, TranslocoScope } from './types';\n\ntype ScopeType = string | TranslocoScope | TranslocoScope[];\ntype SignalKey = Signal<string> | Signal<string[]> | Signal<string>[];\ntype TranslateSignalKey = string | string[] | SignalKey;\ntype TranslateSignalParams =\n  | HashMap\n  | HashMap<Signal<string>>\n  | Signal<HashMap>;\ntype TranslateSignalRef<T> = T extends unknown[] | Signal<string[]>\n  ? Signal<string[]>\n  : Signal<string>;\ntype TranslateObjectSignalRef<T> = T extends unknown[] | Signal<string[]>\n  ? Signal<Translation[]>\n  : Signal<Translation>;\n\n/**\n * Gets the translated value of a key as Signal\n *\n * @example\n * text = translateSignal('hello');\n * textList = translateSignal(['green', 'blue']);\n * textVar = translateSignal('hello', { variable: 'world' });\n * textSpanish = translateSignal('hello', { variable: 'world' }, 'es');\n * textTodosScope = translateSignal('hello', { variable: 'world' }, { scope: 'todos' });\n *\n * @example\n * dynamicKey = signal('hello');\n * dynamicParam = signal({ variable: 'world' });\n * text = translateSignal(this.dynamicKey, this.dynamicParam);\n *\n */\nexport function translateSignal<T extends TranslateSignalKey>(\n  key: T,\n  params?: TranslateSignalParams,\n  lang?: ScopeType,\n  injector?: Injector,\n): TranslateSignalRef<T> {\n  if (!injector) {\n    assertInInjectionContext(translateSignal);\n  }\n  injector ??= inject(Injector);\n  const result = runInInjectionContext(injector, () => {\n    const service = inject(TranslocoService);\n    const scope = resolveScope(lang);\n    return toObservable(computerKeysAndParams(key, params)).pipe(\n      switchMap((dynamic) =>\n        service.selectTranslate(dynamic.key, dynamic.params, scope),\n      ),\n    );\n  });\n  return toSignal(result, { initialValue: Array.isArray(key) ? [''] : '' });\n}\n\n/**\n * Gets the translated object of a key as Signal\n *\n * @example\n * object = translateObjectSignal('nested.object');\n * title = object().title;\n *\n * @example\n * dynamicKey = signal('nested.object');\n * dynamicParam = signal({ variable: 'world' });\n * object = translateObjectSignal(this.dynamicKey, this.dynamicParam);\n */\nexport function translateObjectSignal<T extends TranslateSignalKey>(\n  key: T,\n  params?: TranslateSignalParams,\n  lang?: ScopeType,\n  injector?: Injector,\n): TranslateObjectSignalRef<T> {\n  if (!injector) {\n    assertInInjectionContext(translateObjectSignal);\n  }\n  injector ??= inject(Injector);\n  const result = runInInjectionContext(injector, () => {\n    const service = inject(TranslocoService);\n    const scope = resolveScope(lang);\n    return toObservable(computerKeysAndParams(key, params)).pipe(\n      switchMap((dynamic) =>\n        service.selectTranslateObject(\n          dynamic.key,\n          dynamic.params,\n          scope as string,\n        ),\n      ),\n    );\n  });\n  return toSignal(result, { initialValue: Array.isArray(key) ? [] : {} });\n}\n\nfunction computerParams(params: HashMap<Signal<string>> | Signal<HashMap>) {\n  if (isSignal(params)) {\n    return computed(() => params());\n  }\n  return computed(() => {\n    return Object.entries(params).reduce((acc, [key, value]) => {\n      acc[key] = isSignal(value) ? value() : value;\n      return acc;\n    }, {} as HashMap);\n  });\n}\n\nfunction computerKeys(\n  keys: Signal<string> | Signal<string[]> | Signal<string>[],\n) {\n  if (Array.isArray(keys)) {\n    return computed(() => keys.map((key) => (isSignal(key) ? key() : key)));\n  }\n  return computed(() => keys());\n}\n\nfunction isSignalKey(key: TranslateSignalKey): key is SignalKey {\n  return Array.isArray(key) ? key.some(isSignal) : isSignal(key);\n}\n\nfunction isSignalParams(\n  params?: HashMap,\n): params is HashMap<Signal<string>> | Signal<HashMap> {\n  return params\n    ? isSignal(params) || Object.values(params).some(isSignal)\n    : false;\n}\n\nfunction computerKeysAndParams(\n  key: TranslateSignalKey,\n  params?: TranslateSignalParams,\n) {\n  const computedKeys = isSignalKey(key)\n    ? computerKeys(key)\n    : computed(() => key);\n  const computedParams = isSignalParams(params)\n    ? computerParams(params)\n    : computed(() => params);\n  return computed(() => ({ key: computedKeys(), params: computedParams() }));\n}\n\nfunction resolveScope(scope?: ScopeType) {\n  if (typeof scope === 'undefined' || scope === '') {\n    const translocoScope = inject(TRANSLOCO_SCOPE, { optional: true });\n    return translocoScope ?? undefined;\n  }\n  return scope;\n}\n"]}