UNPKG

@jsverse/transloco

Version:

The internationalization (i18n) library for Angular

106 lines 16 kB
import { assertInInjectionContext, computed, inject, Injector, isSignal, runInInjectionContext, } from '@angular/core'; import { toObservable, toSignal } from '@angular/core/rxjs-interop'; import { of, 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 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 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) { // Avoid async effect from toObservable for those that do not need it if (!isSignalKey(key) && !isSignalParams(params)) { return of({ key, params, }); } const computedKeys = isSignalKey(key) ? computerKeys(key) : computed(() => key); const computedParams = isSignalParams(params) ? computerParams(params) : computed(() => params); return toObservable(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 { Observable, of, switchMap } from 'rxjs';\n\nimport { TRANSLOCO_SCOPE } from './transloco-scope';\nimport { TranslocoService } from './transloco.service';\nimport { Translation, TranslocoScope } from './transloco.types';\nimport { HashMap } from './utils/type.utils';\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 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 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): Observable<{\n  key: string | string[];\n  params: HashMap | undefined;\n}> {\n  // Avoid async effect from toObservable for those that do not need it\n  if (!isSignalKey(key) && !isSignalParams(params)) {\n    return of({\n      key,\n      params,\n    });\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 toObservable(\n    computed(() => ({ key: computedKeys(), params: computedParams() })),\n  );\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"]}