From 17932d4b22a43192988822aa07606d5c9a9c3978 Mon Sep 17 00:00:00 2001 From: Timofei Iatsenko Date: Mon, 9 Jan 2023 14:02:45 +0100 Subject: [PATCH] fix(conf) proper typings for LinguiConfig['runtimeConfigModule'] --- packages/conf/index.d.ts | 7 +++++-- packages/macro/src/index.ts | 6 ++---- 2 files changed, 7 insertions(+), 6 deletions(-) diff --git a/packages/conf/index.d.ts b/packages/conf/index.d.ts index 227fb8dbb..2d2c07084 100644 --- a/packages/conf/index.d.ts +++ b/packages/conf/index.d.ts @@ -49,7 +49,10 @@ export declare type LinguiConfig = { orderBy: OrderBy; pseudoLocale: string; rootDir: string; - runtimeConfigModule: [string, string?]; + runtimeConfigModule: [source: string, identifier?: string] | { + i18n?: [source: string, identifier?: string] + Trans?: [source: string, identifier?: string] + }; sourceLocale: string; service: CatalogService; }; @@ -77,7 +80,7 @@ export declare const configValidation: { orderBy: OrderBy; pseudoLocale: string; rootDir: string; - runtimeConfigModule: [string, string?]; + runtimeConfigModule: LinguiConfig['runtimeConfigModule']; sourceLocale: string; service: CatalogService; }; diff --git a/packages/macro/src/index.ts b/packages/macro/src/index.ts index 11e7808c0..55acefbde 100644 --- a/packages/macro/src/index.ts +++ b/packages/macro/src/index.ts @@ -6,7 +6,7 @@ import MacroJSX from "./macroJsx" const config = getConfig({ configPath: process.env.LINGUI_CONFIG }) -const getSymbolSource = (name: string) => { +const getSymbolSource = (name: 'i18n' | 'Trans'): [source: string, identifier?: string] => { if (Array.isArray(config.runtimeConfigModule)) { if (name === "i18n") { return config.runtimeConfigModule @@ -14,9 +14,7 @@ const getSymbolSource = (name: string) => { return ["@lingui/react", name] } } else { - if ( - Object.prototype.hasOwnProperty.call(config.runtimeConfigModule, name) - ) { + if (config.runtimeConfigModule[name]) { return config.runtimeConfigModule[name] } else { return ["@lingui/react", name]