@scoutello/i18n-magic 0.15.0 → 0.15.2
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 +5 -2
- package/dist/i18n-magic.cjs.development.js +18 -11
- package/dist/i18n-magic.cjs.development.js.map +1 -1
- package/dist/i18n-magic.cjs.production.min.js +1 -1
- package/dist/i18n-magic.cjs.production.min.js.map +1 -1
- package/dist/i18n-magic.esm.js +18 -11
- package/dist/i18n-magic.esm.js.map +1 -1
- package/package.json +1 -1
- package/src/index.ts +10 -4
- package/src/lib/utils.ts +11 -3
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"i18n-magic.cjs.production.min.js","sources":["../src/lib/languges.ts","../src/lib/utils.ts","../src/commands/check-missing.ts","../src/commands/replace.ts","../src/commands/scan.ts","../src/commands/sync-locales.ts","../src/index.ts"],"sourcesContent":["export const languages = [\n {\n label: \"Deutsch\",\n name: \"German\",\n value: \"de\",\n },\n {\n label: \"English\",\n name: \"English\",\n value: \"en\",\n },\n {\n label: \"Español\",\n name: \"Spanish\",\n value: \"es\",\n },\n {\n label: \"Français\",\n name: \"French\",\n value: \"fr\",\n },\n {\n label: \"Dansk\",\n name: \"Danish\",\n value: \"dk\",\n },\n {\n label: \"中文\",\n name: \"Chinese\",\n value: \"cn\",\n },\n {\n label: \"Русский\",\n name: \"Russian\",\n value: \"ru\",\n },\n {\n label: \"Italiano\",\n name: \"Italian\",\n value: \"it\",\n },\n {\n label: \"Nederlands\",\n name: \"Dutch\",\n value: \"nl\",\n },\n {\n label: \"Português\",\n name: \"Portuguese\",\n value: \"pt\",\n },\n {\n label: \"Türkçe\",\n name: \"Turkish\",\n value: \"tr\",\n },\n {\n label: \"Polski\",\n name: \"Polish\",\n value: \"pl\",\n },\n {\n label: \"Українська\",\n name: \"Ukrainian\",\n value: \"ua\",\n },\n {\n label: \"Suomi\",\n name: \"Finnish\",\n value: \"fi\",\n },\n {\n label: \"Norsk\",\n name: \"Norwegian\",\n value: \"no\",\n },\n {\n label: \"Svenska\",\n name: \"Swedish\",\n value: \"sv\",\n },\n {\n label: \"Čeština\",\n name: \"Czech\",\n value: \"cz\",\n },\n {\n label: \"Ελληνικά\",\n name: \"Greek\",\n value: \"gr\",\n },\n {\n label: \"日本語\",\n name: \"Japanese\",\n value: \"jp\",\n },\n {\n label: \"한국어\",\n name: \"Korean\",\n value: \"kr\",\n },\n {\n label: \"Română\",\n name: \"Romanian\",\n value: \"ro\",\n },\n {\n label: \"Hrvatski\",\n name: \"Croatian\",\n value: \"hr\",\n },\n {\n label: \"Magyar\",\n name: \"Hungarian\",\n value: \"hu\",\n },\n {\n label: \"Slovensky\",\n name: \"Slovak\",\n value: \"sk\",\n },\n {\n label: \"हिन्दी\",\n name: \"Hindi\",\n value: \"hi\",\n },\n {\n label: \"தமிழ்\",\n name: \"Tamil\",\n value: \"ta\",\n },\n {\n label: \"Bahasa Indonesia\",\n name: \"Indonesian\",\n value: \"id\",\n },\n {\n label: \"Tiếng Việt\",\n name: \"Vietnamese\",\n value: \"vn\",\n },\n]\n","import glob from \"fast-glob\"\nimport { Parser } from \"i18next-scanner\"\nimport fs from \"node:fs\"\nimport path from \"node:path\"\nimport type OpenAI from \"openai\"\nimport prompts from \"prompts\"\nimport { languages } from \"./languges\"\nimport type { Configuration } from \"./types\"\n\nexport const loadConfig = ({\n configPath = \"i18n-magic.js\",\n}: { configPath: string }) => {\n const filePath = path.join(process.cwd(), configPath)\n\n if (!fs.existsSync(filePath)) {\n console.error(\"Config file does not exist:\", filePath)\n process.exit(1)\n }\n\n try {\n const config = require(filePath)\n // Validate config if needed\n return config\n } catch (error) {\n console.error(\"Error while loading config:\", error)\n process.exit(1)\n }\n}\n\nexport function removeDuplicatesFromArray<T>(arr: T[]): T[] {\n return arr.filter((item, index) => arr.indexOf(item) === index)\n}\n\nexport const translateKey = async ({\n inputLanguage,\n context,\n object,\n openai,\n outputLanguage,\n model,\n}: {\n object: Record<string, string>\n context: string\n inputLanguage: string\n outputLanguage: string\n model: string\n openai: OpenAI\n}) => {\n // Split object into chunks of 100 keys\n const entries = Object.entries(object)\n const chunks: Array<[string, string][]> = []\n\n for (let i = 0; i < entries.length; i += 100) {\n chunks.push(entries.slice(i, i + 100))\n }\n\n let result: Record<string, string> = {}\n\n const existingInput = languages.find((l) => l.value === inputLanguage)\n const existingOutput = languages.find((l) => l.value === outputLanguage)\n\n const input = existingInput?.label || inputLanguage\n const output = existingOutput?.label || outputLanguage\n\n // Translate each chunk\n for (const chunk of chunks) {\n const chunkObject = Object.fromEntries(chunk)\n const completion = await openai.beta.chat.completions.parse({\n model,\n messages: [\n {\n content: `You are a bot that translates the values of a locales JSON. ${\n context\n ? `The user provided some additional context or guidelines about what to fill in the blanks: \\\"${context}\\\". `\n : \"\"\n }The user provides you a JSON with a field named \"inputLanguage\", which defines the language the values of the JSON are defined in. It also has a field named \"outputLanguage\", which defines the language you should translate the values to. The last field is named \"data\", which includes the object with the values to translate. The keys of the values should never be changed. You output only a JSON, which has the same keys as the input, but with translated values. I give you an example input: {\"inputLanguage\": \"English\", outputLanguage: \"German\", \"keys\": {\"hello\": \"Hello\", \"world\": \"World\"}}. The output should be {\"hello\": \"Hallo\", \"world\": \"Welt\"}.`,\n role: \"system\",\n },\n {\n content: JSON.stringify({\n inputLanguage: input,\n outputLanguage: output,\n data: chunkObject,\n }),\n role: \"user\",\n },\n ],\n response_format: {\n type: \"json_object\",\n },\n })\n\n const translatedChunk = JSON.parse(\n completion.choices[0].message.content,\n ) as Record<string, string>\n\n // Merge translated chunk with result\n result = { ...result, ...translatedChunk }\n\n // Optional: Add a small delay between chunks to avoid rate limiting\n await new Promise((resolve) => setTimeout(resolve, 100))\n }\n\n return result\n}\n\nexport const loadLocalesFile = async (\n loadPath:\n | string\n | ((locale: string, namespace: string) => Promise<Record<string, string>>),\n locale: string,\n namespace: string,\n) => {\n if (typeof loadPath === \"string\") {\n const resolvedPath = loadPath\n .replace(\"{{lng}}\", locale)\n .replace(\"{{ns}}\", namespace)\n\n const content = fs.readFileSync(resolvedPath, \"utf-8\")\n const json = JSON.parse(content)\n\n return json as Record<string, string>\n }\n\n return loadPath(locale, namespace)\n}\n\nexport const writeLocalesFile = async (\n savePath:\n | string\n | ((\n locale: string,\n namespace: string,\n data: Record<string, string>,\n ) => Promise<void>),\n locale: string,\n namespace: string,\n data: Record<string, string>,\n) => {\n if (typeof savePath === \"string\") {\n const resolvedSavePath = savePath\n .replace(\"{{lng}}\", locale)\n .replace(\"{{ns}}\", namespace)\n\n fs.writeFileSync(resolvedSavePath, JSON.stringify(data, null, 2))\n\n return\n }\n\n await savePath(locale, namespace, data)\n}\n\nexport const getPureKey = (\n key: string,\n namespace?: string,\n isDefault?: boolean,\n) => {\n const splitted = key.split(\":\")\n\n if (splitted.length === 1) {\n if (isDefault) {\n return key\n }\n\n return null\n }\n\n if (splitted[0] === namespace) {\n return splitted[1]\n }\n\n return null\n}\n\nexport const getMissingKeys = async ({\n globPatterns,\n namespaces,\n defaultNamespace,\n defaultLocale,\n loadPath,\n}: Configuration) => {\n const parser = new Parser({\n nsSeparator: false,\n keySeparator: false,\n })\n\n const files = await glob([...globPatterns, \"!**/node_modules/**\"])\n\n const keys = []\n\n for (const file of files) {\n const content = fs.readFileSync(file, \"utf-8\")\n parser.parseFuncFromString(content, { list: [\"t\"] }, (key: string) => {\n keys.push(key)\n })\n }\n\n const uniqueKeys = removeDuplicatesFromArray(keys)\n\n const newKeys = []\n\n for (const namespace of namespaces) {\n const existingKeys = await loadLocalesFile(\n loadPath,\n defaultLocale,\n namespace,\n )\n\n console.log(Object.keys(existingKeys).length, \"existing keys\")\n\n for (const key of uniqueKeys) {\n const pureKey = getPureKey(key, namespace, namespace === defaultNamespace)\n\n if (!pureKey) {\n continue\n }\n\n if (!existingKeys[pureKey]) {\n newKeys.push({ key: pureKey, namespace })\n }\n }\n }\n\n return newKeys\n}\n\nexport const getTextInput = async (prompt: string) => {\n const input = await prompts({\n name: \"value\",\n type: \"text\",\n message: prompt,\n onState: (state) => {\n if (state.aborted) {\n process.nextTick(() => {\n process.exit(0)\n })\n }\n },\n })\n\n return input.value as string\n}\n\nexport const checkAllKeysExist = async ({\n namespaces,\n defaultLocale,\n loadPath,\n locales,\n context,\n openai,\n savePath,\n disableTranslation,\n model,\n}: Configuration) => {\n if (disableTranslation) {\n return\n }\n\n for (const namespace of namespaces) {\n const defaultLocaleKeys = await loadLocalesFile(\n loadPath,\n defaultLocale,\n namespace,\n )\n\n for (const locale of locales) {\n if (locale === defaultLocale) continue\n\n const localeKeys = await loadLocalesFile(loadPath, locale, namespace)\n const missingKeys: Record<string, string> = {}\n\n // Check which keys from default locale are missing in current locale\n for (const [key, value] of Object.entries(defaultLocaleKeys)) {\n if (!localeKeys[key]) {\n missingKeys[key] = value\n }\n }\n\n // If there are missing keys, translate them\n if (Object.keys(missingKeys).length > 0) {\n console.log(\n `Found ${Object.keys(missingKeys).length} missing keys in ${locale} (namespace: ${namespace})`,\n )\n\n const translatedValues = await translateKey({\n inputLanguage: defaultLocale,\n outputLanguage: locale,\n context,\n object: missingKeys,\n openai,\n model,\n })\n\n // Merge translated values with existing ones\n const updatedLocaleKeys = {\n ...localeKeys,\n ...translatedValues,\n }\n\n // Save the updated translations\n writeLocalesFile(savePath, locale, namespace, updatedLocaleKeys)\n console.log(\n `✓ Translated and saved missing keys for ${locale} (namespace: ${namespace})`,\n )\n }\n }\n }\n}\n\nexport class TranslationError extends Error {\n constructor(\n message: string,\n public locale?: string,\n public namespace?: string,\n public cause?: Error,\n ) {\n super(message)\n this.name = \"TranslationError\"\n }\n}\n","import type { Configuration } from \"../lib/types\"\nimport { getMissingKeys } from \"../lib/utils\"\n\nexport const checkMissing = async (config: Configuration) => {\n const newKeys = await getMissingKeys(config)\n\n if (newKeys.length > 0) {\n console.error(\"Error: Missing translations found!\")\n process.exit(1)\n }\n}\n","import type { Configuration } from \"../lib/types\"\nimport {\n getTextInput,\n loadLocalesFile,\n translateKey,\n writeLocalesFile,\n} from \"../lib/utils\"\n\nconst getKeyToReplace = async (keys: Record<string, string>) => {\n const keyToReplace = await getTextInput(\n \"Enter the key to replace the translation for: \",\n )\n\n if (!keys[keyToReplace]) {\n console.log(`The key \"${keyToReplace}\" does not exist.`)\n return await getKeyToReplace(keys)\n }\n\n console.log(`The key \"${keyToReplace}\" exists.`)\n return keyToReplace\n}\n\nexport const replaceTranslation = async (\n config: Configuration,\n key?: string,\n) => {\n const {\n loadPath,\n savePath,\n defaultLocale,\n defaultNamespace,\n namespaces,\n locales,\n globPatterns,\n context,\n openai,\n } = config\n\n const keys = await loadLocalesFile(\n config.loadPath,\n config.defaultLocale,\n config.defaultNamespace,\n )\n\n let keyToReplace: string\n\n if (key) {\n if (keys[key]) {\n keyToReplace = key\n console.log(`The key \"${keyToReplace}\" exists.`)\n } else {\n console.log(`The key \"${key}\" does not exist.`)\n keyToReplace = await getKeyToReplace(keys)\n }\n } else {\n keyToReplace = await getKeyToReplace(keys)\n }\n\n console.log(\n `The current translation in ${defaultLocale} for \"${keyToReplace}\" is \"${keys[keyToReplace]}\".`,\n )\n\n const newTranslation = await getTextInput(\"Enter the new translation: \")\n\n for (const locale of locales) {\n let newValue = \"\"\n if (locale === defaultLocale) {\n newValue = newTranslation\n } else {\n const translation = await translateKey({\n context,\n inputLanguage: defaultLocale,\n outputLanguage: locale,\n object: {\n [keyToReplace]: newTranslation,\n },\n openai,\n model: config.model,\n })\n\n newValue = translation[keyToReplace]\n }\n\n const existingKeys = await loadLocalesFile(\n loadPath,\n locale,\n defaultNamespace,\n )\n\n existingKeys[keyToReplace] = newValue\n\n writeLocalesFile(savePath, locale, defaultNamespace, existingKeys)\n\n console.log(\n `The new translation for \"${keyToReplace}\" in ${locale} is \"${newValue}\".`,\n )\n }\n}\n","import type { Configuration } from \"../lib/types\"\nimport {\n checkAllKeysExist,\n getMissingKeys,\n getTextInput,\n loadLocalesFile,\n translateKey,\n writeLocalesFile,\n} from \"../lib/utils\"\n\nexport const translateMissing = async (config: Configuration) => {\n const {\n loadPath,\n savePath,\n defaultLocale,\n namespaces,\n locales,\n context,\n openai,\n disableTranslation,\n } = config\n\n const newKeys = await getMissingKeys(config)\n\n if (newKeys.length === 0) {\n console.log(\"No new keys found.\")\n\n await checkAllKeysExist(config)\n\n return\n }\n\n console.log(\n `${newKeys.length} keys are missing. Please provide the values for the following keys in ${defaultLocale}:`,\n )\n\n const newKeysWithDefaultLocale = []\n\n for (const newKey of newKeys) {\n const answer = await getTextInput(newKey.key)\n\n newKeysWithDefaultLocale.push({\n key: newKey.key,\n namespace: newKey.namespace,\n value: answer,\n })\n }\n\n const newKeysObject = newKeysWithDefaultLocale.reduce((prev, next) => {\n prev[next.key] = next.value\n\n return prev\n }, {})\n\n const allLocales = disableTranslation ? [defaultLocale] : locales\n\n for (const locale of allLocales) {\n let translatedValues = {}\n\n if (locale === defaultLocale) {\n translatedValues = newKeysObject\n } else {\n translatedValues = await translateKey({\n inputLanguage: defaultLocale,\n outputLanguage: locale,\n context,\n object: newKeysObject,\n openai,\n model: config.model,\n })\n }\n\n for (const namespace of namespaces) {\n const existingKeys = await loadLocalesFile(loadPath, locale, namespace)\n\n const relevantKeys = newKeysWithDefaultLocale.filter(\n (key) => key.namespace === namespace,\n )\n\n if (relevantKeys.length === 0) {\n continue\n }\n\n for (const key of relevantKeys) {\n existingKeys[key.key] = translatedValues[key.key]\n }\n\n writeLocalesFile(savePath, locale, namespace, existingKeys)\n }\n }\n\n await checkAllKeysExist(config)\n\n console.log(`Successfully translated ${newKeys.length} keys.`)\n}\n","import type { Configuration } from \"../lib/types\"\nimport {\n TranslationError,\n loadLocalesFile,\n translateKey,\n writeLocalesFile,\n} from \"../lib/utils\"\n\nexport const syncLocales = async (config: Configuration) => {\n const {\n loadPath,\n savePath,\n defaultLocale,\n namespaces,\n locales,\n context,\n openai,\n } = config\n\n try {\n for (const namespace of namespaces) {\n let defaultLocaleKeys: Record<string, string>\n\n try {\n defaultLocaleKeys = await loadLocalesFile(\n loadPath,\n defaultLocale,\n namespace,\n )\n } catch (error) {\n throw new TranslationError(\n `Failed to load default locale file for namespace \"${namespace}\"`,\n defaultLocale,\n namespace,\n error instanceof Error ? error : undefined,\n )\n }\n\n for (const locale of locales) {\n if (locale === defaultLocale) continue\n\n let localeKeys: Record<string, string>\n try {\n localeKeys = await loadLocalesFile(loadPath, locale, namespace)\n } catch (error) {\n console.warn(\n `Warning: Could not load locale file for ${locale} (namespace: ${namespace}). Creating new file.`,\n )\n localeKeys = {}\n }\n\n const missingKeys: Record<string, string> = {}\n\n // Check which keys from default locale are missing in current locale\n for (const [key, value] of Object.entries(defaultLocaleKeys)) {\n if (!localeKeys[key]) {\n missingKeys[key] = value\n }\n }\n\n // If there are missing keys, translate them\n if (Object.keys(missingKeys).length > 0) {\n console.log(\n `Found ${Object.keys(missingKeys).length} missing keys in ${locale} (namespace: ${namespace})`,\n )\n\n let translatedValues: Record<string, string>\n try {\n translatedValues = await translateKey({\n inputLanguage: defaultLocale,\n outputLanguage: locale,\n context,\n object: missingKeys,\n openai,\n model: config.model,\n })\n } catch (error) {\n throw new TranslationError(\n `Failed to translate keys for locale \"${locale}\" (namespace: ${namespace})`,\n locale,\n namespace,\n error instanceof Error ? error : undefined,\n )\n }\n\n // Merge translated values with existing ones\n const updatedLocaleKeys = {\n ...localeKeys,\n ...translatedValues,\n }\n\n try {\n await writeLocalesFile(\n savePath,\n locale,\n namespace,\n updatedLocaleKeys,\n )\n } catch (error) {\n throw new TranslationError(\n `Failed to save translations for locale \"${locale}\" (namespace: ${namespace})`,\n locale,\n namespace,\n error instanceof Error ? error : undefined,\n )\n }\n\n console.log(\n `Successfully translated and saved ${Object.keys(missingKeys).length} keys for ${locale} (namespace: ${namespace})`,\n )\n } else {\n console.log(\n `No missing keys found for ${locale} (namespace: ${namespace})`,\n )\n }\n }\n }\n } catch (error) {\n if (error instanceof TranslationError) {\n throw error\n }\n throw new TranslationError(\n \"An unexpected error occurred during translation\",\n undefined,\n undefined,\n error instanceof Error ? error : undefined,\n )\n }\n}\n","import { Command } from \"commander\"\nimport dotenv from \"dotenv\"\nimport OpenAI from \"openai\"\nimport { checkMissing } from \"./commands/check-missing\"\nimport { replaceTranslation } from \"./commands/replace\"\nimport { translateMissing } from \"./commands/scan\"\nimport { syncLocales } from \"./commands/sync-locales\"\nimport type { CommandType, Configuration } from \"./lib/types\"\nimport { loadConfig } from \"./lib/utils\"\n\n// Only run CLI initialization when this file is executed directly\n\nconst program = new Command()\n\nprogram\n .name(\"i18n-magic\")\n .description(\n \"CLI to help you manage your locales JSON with translations, replacements, etc. with OpenAI.\",\n )\n .version(\"0.2.0\")\n .option(\"-c, --config <path>\", \"path to config file\")\n .option(\"-e, --env <path>\", \"path to .env file\")\n\nconst commands: CommandType[] = [\n {\n name: \"scan\",\n description:\n \"Scan for missing translations, get prompted for each, translate it to the other locales and save it to the JSON file.\",\n action: translateMissing,\n },\n {\n name: \"replace\",\n description:\n \"Replace a translation based on the key, and translate it to the other locales and save it to the JSON file.\",\n action: replaceTranslation,\n },\n {\n name: \"check-missing\",\n description:\n \"Check if there are any missing translations. Useful for a CI/CD pipeline or husky hook.\",\n action: checkMissing,\n },\n {\n name: \"sync\",\n description:\n \"Sync the translations from the default locale to the other locales. Useful for a CI/CD pipeline or husky hook.\",\n action: syncLocales,\n },\n]\n\nfor (const command of commands) {\n const cmd = program.command(command.name).description(command.description)\n\n // Add key option to replace command\n if (command.name === \"replace\") {\n cmd.option(\"-k, --key <key>\", \"translation key to replace\")\n }\n\n cmd.action(async (options) => {\n const res = dotenv.config({\n path: program.opts().env || \".env\",\n })\n\n const config: Configuration = await loadConfig({\n configPath: program.opts().config,\n })\n\n const isGemini = (config.model as string)?.includes(\"gemini\")\n\n // Get API key from environment or config\n const openaiKey = res.parsed.OPENAI_API_KEY || config.OPENAI_API_KEY\n const geminiKey = res.parsed.GEMINI_API_KEY || config.GEMINI_API_KEY\n\n // Select appropriate key based on model type\n const key = isGemini ? geminiKey : openaiKey\n\n if (!key) {\n const keyType = isGemini ? \"GEMINI_API_KEY\" : \"OPENAI_API_KEY\"\n console.error(\n `Please provide a${isGemini ? \" Gemini\" : \"n OpenAI\"} API key in your .env file or config, called ${keyType}.`,\n )\n process.exit(1)\n }\n\n const openai = new OpenAI({\n apiKey: key,\n ...(isGemini && {\n baseURL: \"https://generativelanguage.googleapis.com/v1beta/openai/\",\n }),\n })\n\n if (command.name === \"replace\" && options.key) {\n command.action({ ...config, openai }, options.key)\n } else {\n command.action({ ...config, openai })\n }\n })\n}\n\nprogram.parse(process.argv)\n"],"names":["languages","label","name","value","loadConfig","_ref","_ref$configPath","configPath","filePath","path","join","process","cwd","fs","existsSync","console","error","exit","require","removeDuplicatesFromArray","arr","filter","item","index","indexOf","translateKey","_ref3","_asyncToGenerator","_regeneratorRuntime","mark","_callee","_ref2","inputLanguage","context","openai","outputLanguage","model","entries","chunks","i","result","existingInput","existingOutput","input","output","_i","_chunks","chunkObject","translatedChunk","wrap","_context","prev","next","Object","object","length","push","slice","find","l","fromEntries","beta","chat","completions","parse","messages","content","role","JSON","stringify","data","response_format","type","sent","choices","message","_extends","Promise","resolve","setTimeout","abrupt","stop","_x","apply","this","arguments","loadLocalesFile","_ref4","_callee2","loadPath","locale","namespace","resolvedPath","json","_context2","replace","readFileSync","_x2","_x3","_x4","writeLocalesFile","_ref5","_callee3","savePath","resolvedSavePath","_context3","writeFileSync","_x5","_x6","_x7","_x8","getPureKey","key","isDefault","splitted","split","getMissingKeys","_ref7","_callee4","_ref6","globPatterns","namespaces","defaultNamespace","defaultLocale","parser","keys","_iterator","_step","uniqueKeys","newKeys","_iterator2","_step2","existingKeys","_iterator3","_step3","pureKey","_context4","Parser","nsSeparator","keySeparator","glob","concat","_createForOfIteratorHelperLoose","done","parseFuncFromString","list","log","_x9","getTextInput","_ref8","_callee5","prompt","_context5","prompts","onState","state","aborted","nextTick","_x10","checkAllKeysExist","_ref10","_callee6","_ref9","locales","_iterator4","_step4","defaultLocaleKeys","_iterator5","_step5","localeKeys","missingKeys","_i2","_Object$entries","_Object$entries$_i","updatedLocaleKeys","_context6","disableTranslation","_x11","TranslationError","_Error","cause","_this","call","_wrapNativeSuper","Error","checkMissing","config","getKeyToReplace","keyToReplace","replaceTranslation","newTranslation","newValue","_object","translateMissing","newKeysWithDefaultLocale","newKey","newKeysObject","translatedValues","_loop","reduce","relevantKeys","delegateYield","t0","syncLocales","undefined","t1","warn","t2","t3","t4","program","Command","description","version","option","command","_commands","cmd","action","options","_config$model","res","isGemini","openaiKey","geminiKey","dotenv","opts","env","includes","parsed","OPENAI_API_KEY","GEMINI_API_KEY","OpenAI","apiKey","baseURL","argv"],"mappings":"y9RAAO,IAAMA,EAAY,CACvB,CACEC,MAAO,UACPC,KAAM,SACNC,MAAO,MAET,CACEF,MAAO,UACPC,KAAM,UACNC,MAAO,MAET,CACEF,MAAO,UACPC,KAAM,UACNC,MAAO,MAET,CACEF,MAAO,WACPC,KAAM,SACNC,MAAO,MAET,CACEF,MAAO,QACPC,KAAM,SACNC,MAAO,MAET,CACEF,MAAO,KACPC,KAAM,UACNC,MAAO,MAET,CACEF,MAAO,UACPC,KAAM,UACNC,MAAO,MAET,CACEF,MAAO,WACPC,KAAM,UACNC,MAAO,MAET,CACEF,MAAO,aACPC,KAAM,QACNC,MAAO,MAET,CACEF,MAAO,YACPC,KAAM,aACNC,MAAO,MAET,CACEF,MAAO,SACPC,KAAM,UACNC,MAAO,MAET,CACEF,MAAO,SACPC,KAAM,SACNC,MAAO,MAET,CACEF,MAAO,aACPC,KAAM,YACNC,MAAO,MAET,CACEF,MAAO,QACPC,KAAM,UACNC,MAAO,MAET,CACEF,MAAO,QACPC,KAAM,YACNC,MAAO,MAET,CACEF,MAAO,UACPC,KAAM,UACNC,MAAO,MAET,CACEF,MAAO,UACPC,KAAM,QACNC,MAAO,MAET,CACEF,MAAO,WACPC,KAAM,QACNC,MAAO,MAET,CACEF,MAAO,MACPC,KAAM,WACNC,MAAO,MAET,CACEF,MAAO,MACPC,KAAM,SACNC,MAAO,MAET,CACEF,MAAO,SACPC,KAAM,WACNC,MAAO,MAET,CACEF,MAAO,WACPC,KAAM,WACNC,MAAO,MAET,CACEF,MAAO,SACPC,KAAM,YACNC,MAAO,MAET,CACEF,MAAO,YACPC,KAAM,SACNC,MAAO,MAET,CACEF,MAAO,SACPC,KAAM,QACNC,MAAO,MAET,CACEF,MAAO,QACPC,KAAM,QACNC,MAAO,MAET,CACEF,MAAO,mBACPC,KAAM,aACNC,MAAO,MAET,CACEF,MAAO,aACPC,KAAM,aACNC,MAAO,OClIEC,EAAa,SAAHC,GAEM,IAAAC,EAAAD,EAD3BE,WAAAA,OAAa,IAAHD,EAAG,gBAAeA,EAEtBE,EAAWC,EAAKC,KAAKC,QAAQC,MAAOL,GAErCM,E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"}
|
|
1
|
+
{"version":3,"file":"i18n-magic.cjs.production.min.js","sources":["../src/lib/languges.ts","../src/lib/utils.ts","../src/commands/check-missing.ts","../src/commands/replace.ts","../src/commands/scan.ts","../src/commands/sync-locales.ts","../src/index.ts"],"sourcesContent":["export const languages = [\n {\n label: \"Deutsch\",\n name: \"German\",\n value: \"de\",\n },\n {\n label: \"English\",\n name: \"English\",\n value: \"en\",\n },\n {\n label: \"Español\",\n name: \"Spanish\",\n value: \"es\",\n },\n {\n label: \"Français\",\n name: \"French\",\n value: \"fr\",\n },\n {\n label: \"Dansk\",\n name: \"Danish\",\n value: \"dk\",\n },\n {\n label: \"中文\",\n name: \"Chinese\",\n value: \"cn\",\n },\n {\n label: \"Русский\",\n name: \"Russian\",\n value: \"ru\",\n },\n {\n label: \"Italiano\",\n name: \"Italian\",\n value: \"it\",\n },\n {\n label: \"Nederlands\",\n name: \"Dutch\",\n value: \"nl\",\n },\n {\n label: \"Português\",\n name: \"Portuguese\",\n value: \"pt\",\n },\n {\n label: \"Türkçe\",\n name: \"Turkish\",\n value: \"tr\",\n },\n {\n label: \"Polski\",\n name: \"Polish\",\n value: \"pl\",\n },\n {\n label: \"Українська\",\n name: \"Ukrainian\",\n value: \"ua\",\n },\n {\n label: \"Suomi\",\n name: \"Finnish\",\n value: \"fi\",\n },\n {\n label: \"Norsk\",\n name: \"Norwegian\",\n value: \"no\",\n },\n {\n label: \"Svenska\",\n name: \"Swedish\",\n value: \"sv\",\n },\n {\n label: \"Čeština\",\n name: \"Czech\",\n value: \"cz\",\n },\n {\n label: \"Ελληνικά\",\n name: \"Greek\",\n value: \"gr\",\n },\n {\n label: \"日本語\",\n name: \"Japanese\",\n value: \"jp\",\n },\n {\n label: \"한국어\",\n name: \"Korean\",\n value: \"kr\",\n },\n {\n label: \"Română\",\n name: \"Romanian\",\n value: \"ro\",\n },\n {\n label: \"Hrvatski\",\n name: \"Croatian\",\n value: \"hr\",\n },\n {\n label: \"Magyar\",\n name: \"Hungarian\",\n value: \"hu\",\n },\n {\n label: \"Slovensky\",\n name: \"Slovak\",\n value: \"sk\",\n },\n {\n label: \"हिन्दी\",\n name: \"Hindi\",\n value: \"hi\",\n },\n {\n label: \"தமிழ்\",\n name: \"Tamil\",\n value: \"ta\",\n },\n {\n label: \"Bahasa Indonesia\",\n name: \"Indonesian\",\n value: \"id\",\n },\n {\n label: \"Tiếng Việt\",\n name: \"Vietnamese\",\n value: \"vn\",\n },\n]\n","import glob from \"fast-glob\"\nimport { Parser } from \"i18next-scanner\"\nimport fs from \"node:fs\"\nimport path from \"node:path\"\nimport type OpenAI from \"openai\"\nimport prompts from \"prompts\"\nimport { languages } from \"./languges\"\nimport type { Configuration } from \"./types\"\n\nexport const loadConfig = ({\n configPath = \"i18n-magic.js\",\n}: { configPath: string }) => {\n const filePath = path.join(process.cwd(), configPath)\n\n if (!fs.existsSync(filePath)) {\n console.error(\"Config file does not exist:\", filePath)\n process.exit(1)\n }\n\n try {\n const config = require(filePath)\n // Validate config if needed\n return config\n } catch (error) {\n console.error(\"Error while loading config:\", error)\n process.exit(1)\n }\n}\n\nexport function removeDuplicatesFromArray<T>(arr: T[]): T[] {\n return arr.filter((item, index) => arr.indexOf(item) === index)\n}\n\nexport const translateKey = async ({\n inputLanguage,\n context,\n object,\n openai,\n outputLanguage,\n model,\n}: {\n object: Record<string, string>\n context: string\n inputLanguage: string\n outputLanguage: string\n model: string\n openai: OpenAI\n}) => {\n // Split object into chunks of 100 keys\n const entries = Object.entries(object)\n const chunks: Array<[string, string][]> = []\n\n for (let i = 0; i < entries.length; i += 100) {\n chunks.push(entries.slice(i, i + 100))\n }\n\n let result: Record<string, string> = {}\n\n const existingInput = languages.find((l) => l.value === inputLanguage)\n const existingOutput = languages.find((l) => l.value === outputLanguage)\n\n const input = existingInput?.label || inputLanguage\n const output = existingOutput?.label || outputLanguage\n\n // Translate each chunk\n for (const chunk of chunks) {\n const chunkObject = Object.fromEntries(chunk)\n const completion = await openai.beta.chat.completions.parse({\n model,\n messages: [\n {\n content: `You are a bot that translates the values of a locales JSON. ${\n context\n ? `The user provided some additional context or guidelines about what to fill in the blanks: \\\"${context}\\\". `\n : \"\"\n }The user provides you a JSON with a field named \"inputLanguage\", which defines the language the values of the JSON are defined in. It also has a field named \"outputLanguage\", which defines the language you should translate the values to. The last field is named \"data\", which includes the object with the values to translate. The keys of the values should never be changed. You output only a JSON, which has the same keys as the input, but with translated values. I give you an example input: {\"inputLanguage\": \"English\", outputLanguage: \"German\", \"keys\": {\"hello\": \"Hello\", \"world\": \"World\"}}. The output should be {\"hello\": \"Hallo\", \"world\": \"Welt\"}.`,\n role: \"system\",\n },\n {\n content: JSON.stringify({\n inputLanguage: input,\n outputLanguage: output,\n data: chunkObject,\n }),\n role: \"user\",\n },\n ],\n response_format: {\n type: \"json_object\",\n },\n })\n\n const translatedChunk = JSON.parse(\n completion.choices[0].message.content,\n ) as Record<string, string>\n\n // Merge translated chunk with result\n result = { ...result, ...translatedChunk }\n\n // Optional: Add a small delay between chunks to avoid rate limiting\n await new Promise((resolve) => setTimeout(resolve, 100))\n }\n\n return result\n}\n\nexport const loadLocalesFile = async (\n loadPath:\n | string\n | ((locale: string, namespace: string) => Promise<Record<string, string>>),\n locale: string,\n namespace: string,\n) => {\n if (typeof loadPath === \"string\") {\n const resolvedPath = loadPath\n .replace(\"{{lng}}\", locale)\n .replace(\"{{ns}}\", namespace)\n\n const content = fs.readFileSync(resolvedPath, \"utf-8\")\n try {\n const json = JSON.parse(content)\n return json as Record<string, string>\n } catch (error) {\n throw new TranslationError(\n `Invalid JSON in locale file for ${locale}:${namespace}. Path: ${resolvedPath}`,\n locale,\n namespace,\n error instanceof Error ? error : undefined,\n )\n }\n }\n\n return loadPath(locale, namespace)\n}\n\nexport const writeLocalesFile = async (\n savePath:\n | string\n | ((\n locale: string,\n namespace: string,\n data: Record<string, string>,\n ) => Promise<void>),\n locale: string,\n namespace: string,\n data: Record<string, string>,\n) => {\n if (typeof savePath === \"string\") {\n const resolvedSavePath = savePath\n .replace(\"{{lng}}\", locale)\n .replace(\"{{ns}}\", namespace)\n\n fs.writeFileSync(resolvedSavePath, JSON.stringify(data, null, 2))\n\n return\n }\n\n await savePath(locale, namespace, data)\n}\n\nexport const getPureKey = (\n key: string,\n namespace?: string,\n isDefault?: boolean,\n) => {\n const splitted = key.split(\":\")\n\n if (splitted.length === 1) {\n if (isDefault) {\n return key\n }\n\n return null\n }\n\n if (splitted[0] === namespace) {\n return splitted[1]\n }\n\n return null\n}\n\nexport const getMissingKeys = async ({\n globPatterns,\n namespaces,\n defaultNamespace,\n defaultLocale,\n loadPath,\n}: Configuration) => {\n const parser = new Parser({\n nsSeparator: false,\n keySeparator: false,\n })\n\n const files = await glob([...globPatterns, \"!**/node_modules/**\"])\n\n const keys = []\n\n for (const file of files) {\n const content = fs.readFileSync(file, \"utf-8\")\n parser.parseFuncFromString(content, { list: [\"t\"] }, (key: string) => {\n keys.push(key)\n })\n }\n\n const uniqueKeys = removeDuplicatesFromArray(keys)\n\n const newKeys = []\n\n for (const namespace of namespaces) {\n const existingKeys = await loadLocalesFile(\n loadPath,\n defaultLocale,\n namespace,\n )\n\n console.log(Object.keys(existingKeys).length, \"existing keys\")\n\n for (const key of uniqueKeys) {\n const pureKey = getPureKey(key, namespace, namespace === defaultNamespace)\n\n if (!pureKey) {\n continue\n }\n\n if (!existingKeys[pureKey]) {\n newKeys.push({ key: pureKey, namespace })\n }\n }\n }\n\n return newKeys\n}\n\nexport const getTextInput = async (prompt: string) => {\n const input = await prompts({\n name: \"value\",\n type: \"text\",\n message: prompt,\n onState: (state) => {\n if (state.aborted) {\n process.nextTick(() => {\n process.exit(0)\n })\n }\n },\n })\n\n return input.value as string\n}\n\nexport const checkAllKeysExist = async ({\n namespaces,\n defaultLocale,\n loadPath,\n locales,\n context,\n openai,\n savePath,\n disableTranslation,\n model,\n}: Configuration) => {\n if (disableTranslation) {\n return\n }\n\n for (const namespace of namespaces) {\n const defaultLocaleKeys = await loadLocalesFile(\n loadPath,\n defaultLocale,\n namespace,\n )\n\n for (const locale of locales) {\n if (locale === defaultLocale) continue\n\n const localeKeys = await loadLocalesFile(loadPath, locale, namespace)\n const missingKeys: Record<string, string> = {}\n\n // Check which keys from default locale are missing in current locale\n for (const [key, value] of Object.entries(defaultLocaleKeys)) {\n if (!localeKeys[key]) {\n missingKeys[key] = value\n }\n }\n\n // If there are missing keys, translate them\n if (Object.keys(missingKeys).length > 0) {\n console.log(\n `Found ${Object.keys(missingKeys).length} missing keys in ${locale} (namespace: ${namespace})`,\n )\n\n const translatedValues = await translateKey({\n inputLanguage: defaultLocale,\n outputLanguage: locale,\n context,\n object: missingKeys,\n openai,\n model,\n })\n\n // Merge translated values with existing ones\n const updatedLocaleKeys = {\n ...localeKeys,\n ...translatedValues,\n }\n\n // Save the updated translations\n writeLocalesFile(savePath, locale, namespace, updatedLocaleKeys)\n console.log(\n `✓ Translated and saved missing keys for ${locale} (namespace: ${namespace})`,\n )\n }\n }\n }\n}\n\nexport class TranslationError extends Error {\n constructor(\n message: string,\n public locale?: string,\n public namespace?: string,\n public cause?: Error,\n ) {\n super(message)\n this.name = \"TranslationError\"\n }\n}\n","import type { Configuration } from \"../lib/types\"\nimport { getMissingKeys } from \"../lib/utils\"\n\nexport const checkMissing = async (config: Configuration) => {\n const newKeys = await getMissingKeys(config)\n\n if (newKeys.length > 0) {\n console.error(\"Error: Missing translations found!\")\n process.exit(1)\n }\n}\n","import type { Configuration } from \"../lib/types\"\nimport {\n getTextInput,\n loadLocalesFile,\n translateKey,\n writeLocalesFile,\n} from \"../lib/utils\"\n\nconst getKeyToReplace = async (keys: Record<string, string>) => {\n const keyToReplace = await getTextInput(\n \"Enter the key to replace the translation for: \",\n )\n\n if (!keys[keyToReplace]) {\n console.log(`The key \"${keyToReplace}\" does not exist.`)\n return await getKeyToReplace(keys)\n }\n\n console.log(`The key \"${keyToReplace}\" exists.`)\n return keyToReplace\n}\n\nexport const replaceTranslation = async (\n config: Configuration,\n key?: string,\n) => {\n const {\n loadPath,\n savePath,\n defaultLocale,\n defaultNamespace,\n namespaces,\n locales,\n globPatterns,\n context,\n openai,\n } = config\n\n const keys = await loadLocalesFile(\n config.loadPath,\n config.defaultLocale,\n config.defaultNamespace,\n )\n\n let keyToReplace: string\n\n if (key) {\n if (keys[key]) {\n keyToReplace = key\n console.log(`The key \"${keyToReplace}\" exists.`)\n } else {\n console.log(`The key \"${key}\" does not exist.`)\n keyToReplace = await getKeyToReplace(keys)\n }\n } else {\n keyToReplace = await getKeyToReplace(keys)\n }\n\n console.log(\n `The current translation in ${defaultLocale} for \"${keyToReplace}\" is \"${keys[keyToReplace]}\".`,\n )\n\n const newTranslation = await getTextInput(\"Enter the new translation: \")\n\n for (const locale of locales) {\n let newValue = \"\"\n if (locale === defaultLocale) {\n newValue = newTranslation\n } else {\n const translation = await translateKey({\n context,\n inputLanguage: defaultLocale,\n outputLanguage: locale,\n object: {\n [keyToReplace]: newTranslation,\n },\n openai,\n model: config.model,\n })\n\n newValue = translation[keyToReplace]\n }\n\n const existingKeys = await loadLocalesFile(\n loadPath,\n locale,\n defaultNamespace,\n )\n\n existingKeys[keyToReplace] = newValue\n\n writeLocalesFile(savePath, locale, defaultNamespace, existingKeys)\n\n console.log(\n `The new translation for \"${keyToReplace}\" in ${locale} is \"${newValue}\".`,\n )\n }\n}\n","import type { Configuration } from \"../lib/types\"\nimport {\n checkAllKeysExist,\n getMissingKeys,\n getTextInput,\n loadLocalesFile,\n translateKey,\n writeLocalesFile,\n} from \"../lib/utils\"\n\nexport const translateMissing = async (config: Configuration) => {\n const {\n loadPath,\n savePath,\n defaultLocale,\n namespaces,\n locales,\n context,\n openai,\n disableTranslation,\n } = config\n\n const newKeys = await getMissingKeys(config)\n\n if (newKeys.length === 0) {\n console.log(\"No new keys found.\")\n\n await checkAllKeysExist(config)\n\n return\n }\n\n console.log(\n `${newKeys.length} keys are missing. Please provide the values for the following keys in ${defaultLocale}:`,\n )\n\n const newKeysWithDefaultLocale = []\n\n for (const newKey of newKeys) {\n const answer = await getTextInput(newKey.key)\n\n newKeysWithDefaultLocale.push({\n key: newKey.key,\n namespace: newKey.namespace,\n value: answer,\n })\n }\n\n const newKeysObject = newKeysWithDefaultLocale.reduce((prev, next) => {\n prev[next.key] = next.value\n\n return prev\n }, {})\n\n const allLocales = disableTranslation ? [defaultLocale] : locales\n\n for (const locale of allLocales) {\n let translatedValues = {}\n\n if (locale === defaultLocale) {\n translatedValues = newKeysObject\n } else {\n translatedValues = await translateKey({\n inputLanguage: defaultLocale,\n outputLanguage: locale,\n context,\n object: newKeysObject,\n openai,\n model: config.model,\n })\n }\n\n for (const namespace of namespaces) {\n const existingKeys = await loadLocalesFile(loadPath, locale, namespace)\n\n const relevantKeys = newKeysWithDefaultLocale.filter(\n (key) => key.namespace === namespace,\n )\n\n if (relevantKeys.length === 0) {\n continue\n }\n\n for (const key of relevantKeys) {\n existingKeys[key.key] = translatedValues[key.key]\n }\n\n writeLocalesFile(savePath, locale, namespace, existingKeys)\n }\n }\n\n await checkAllKeysExist(config)\n\n console.log(`Successfully translated ${newKeys.length} keys.`)\n}\n","import type { Configuration } from \"../lib/types\"\nimport {\n TranslationError,\n loadLocalesFile,\n translateKey,\n writeLocalesFile,\n} from \"../lib/utils\"\n\nexport const syncLocales = async (config: Configuration) => {\n const {\n loadPath,\n savePath,\n defaultLocale,\n namespaces,\n locales,\n context,\n openai,\n } = config\n\n try {\n for (const namespace of namespaces) {\n let defaultLocaleKeys: Record<string, string>\n\n try {\n defaultLocaleKeys = await loadLocalesFile(\n loadPath,\n defaultLocale,\n namespace,\n )\n } catch (error) {\n throw new TranslationError(\n `Failed to load default locale file for namespace \"${namespace}\"`,\n defaultLocale,\n namespace,\n error instanceof Error ? error : undefined,\n )\n }\n\n for (const locale of locales) {\n if (locale === defaultLocale) continue\n\n let localeKeys: Record<string, string>\n try {\n localeKeys = await loadLocalesFile(loadPath, locale, namespace)\n } catch (error) {\n console.warn(\n `Warning: Could not load locale file for ${locale} (namespace: ${namespace}). Creating new file.`,\n )\n localeKeys = {}\n }\n\n const missingKeys: Record<string, string> = {}\n\n // Check which keys from default locale are missing in current locale\n for (const [key, value] of Object.entries(defaultLocaleKeys)) {\n if (!localeKeys[key]) {\n missingKeys[key] = value\n }\n }\n\n // If there are missing keys, translate them\n if (Object.keys(missingKeys).length > 0) {\n console.log(\n `Found ${Object.keys(missingKeys).length} missing keys in ${locale} (namespace: ${namespace})`,\n )\n\n let translatedValues: Record<string, string>\n try {\n translatedValues = await translateKey({\n inputLanguage: defaultLocale,\n outputLanguage: locale,\n context,\n object: missingKeys,\n openai,\n model: config.model,\n })\n } catch (error) {\n throw new TranslationError(\n `Failed to translate keys for locale \"${locale}\" (namespace: ${namespace})`,\n locale,\n namespace,\n error instanceof Error ? error : undefined,\n )\n }\n\n // Merge translated values with existing ones\n const updatedLocaleKeys = {\n ...localeKeys,\n ...translatedValues,\n }\n\n try {\n await writeLocalesFile(\n savePath,\n locale,\n namespace,\n updatedLocaleKeys,\n )\n } catch (error) {\n throw new TranslationError(\n `Failed to save translations for locale \"${locale}\" (namespace: ${namespace})`,\n locale,\n namespace,\n error instanceof Error ? error : undefined,\n )\n }\n\n console.log(\n `Successfully translated and saved ${Object.keys(missingKeys).length} keys for ${locale} (namespace: ${namespace})`,\n )\n } else {\n console.log(\n `No missing keys found for ${locale} (namespace: ${namespace})`,\n )\n }\n }\n }\n } catch (error) {\n if (error instanceof TranslationError) {\n throw error\n }\n throw new TranslationError(\n \"An unexpected error occurred during translation\",\n undefined,\n undefined,\n error instanceof Error ? error : undefined,\n )\n }\n}\n","import { Command } from \"commander\"\nimport dotenv from \"dotenv\"\nimport OpenAI from \"openai\"\nimport { checkMissing } from \"./commands/check-missing\"\nimport { replaceTranslation } from \"./commands/replace\"\nimport { translateMissing } from \"./commands/scan\"\nimport { syncLocales } from \"./commands/sync-locales\"\nimport type { CommandType, Configuration } from \"./lib/types\"\nimport { loadConfig } from \"./lib/utils\"\n\n// Only run CLI initialization when this file is executed directly\n\nconst program = new Command()\n\nprogram\n .name(\"i18n-magic\")\n .description(\n \"CLI to help you manage your locales JSON with translations, replacements, etc. with OpenAI.\",\n )\n .version(\"0.2.0\")\n .option(\"-c, --config <path>\", \"path to config file\")\n .option(\"-e, --env <path>\", \"path to .env file\")\n\nconst commands: CommandType[] = [\n {\n name: \"scan\",\n description:\n \"Scan for missing translations, get prompted for each, translate it to the other locales and save it to the JSON file.\",\n action: translateMissing,\n },\n {\n name: \"replace\",\n description:\n \"Replace a translation based on the key, and translate it to the other locales and save it to the JSON file.\",\n action: replaceTranslation,\n },\n {\n name: \"check-missing\",\n description:\n \"Check if there are any missing translations. Useful for a CI/CD pipeline or husky hook.\",\n action: checkMissing,\n },\n {\n name: \"sync\",\n description:\n \"Sync the translations from the default locale to the other locales. Useful for a CI/CD pipeline or husky hook.\",\n action: syncLocales,\n },\n]\n\nfor (const command of commands) {\n const cmd = program.command(command.name).description(command.description)\n\n // Add key option to replace command\n if (command.name === \"replace\") {\n cmd\n .option(\"-k, --key <key>\", \"translation key to replace\")\n .allowExcessArguments(true)\n .argument(\"[key]\", \"translation key to replace\")\n }\n\n cmd.action(async (arg, options) => {\n const res = dotenv.config({\n path: program.opts().env || \".env\",\n })\n\n const config: Configuration = await loadConfig({\n configPath: program.opts().config,\n })\n\n const isGemini = (config.model as string)?.includes(\"gemini\")\n\n // Get API key from environment or config\n const openaiKey = res.parsed.OPENAI_API_KEY || config.OPENAI_API_KEY\n const geminiKey = res.parsed.GEMINI_API_KEY || config.GEMINI_API_KEY\n\n // Select appropriate key based on model type\n const key = isGemini ? geminiKey : openaiKey\n\n if (!key) {\n const keyType = isGemini ? \"GEMINI_API_KEY\" : \"OPENAI_API_KEY\"\n console.error(\n `Please provide a${isGemini ? \" Gemini\" : \"n OpenAI\"} API key in your .env file or config, called ${keyType}.`,\n )\n process.exit(1)\n }\n\n const openai = new OpenAI({\n apiKey: key,\n ...(isGemini && {\n baseURL: \"https://generativelanguage.googleapis.com/v1beta/openai/\",\n }),\n })\n\n // For replace command, check for key in argument or option\n if (command.name === \"replace\") {\n // If key is provided as positional argument, use that first\n const keyToUse = typeof arg === \"string\" ? arg : options.key\n command.action({ ...config, openai }, keyToUse)\n } else {\n command.action({ ...config, openai })\n }\n })\n}\n\nprogram.parse(process.argv)\n"],"names":["languages","label","name","value","loadConfig","_ref","_ref$configPath","configPath","filePath","path","join","process","cwd","fs","existsSync","console","error","exit","require","removeDuplicatesFromArray","arr","filter","item","index","indexOf","translateKey","_ref3","_asyncToGenerator","_regeneratorRuntime","mark","_callee","_ref2","inputLanguage","context","openai","outputLanguage","model","entries","chunks","i","result","existingInput","existingOutput","input","output","_i","_chunks","chunkObject","translatedChunk","wrap","_context","prev","next","Object","object","length","push","slice","find","l","fromEntries","beta","chat","completions","parse","messages","content","role","JSON","stringify","data","response_format","type","sent","choices","message","_extends","Promise","resolve","setTimeout","abrupt","stop","_x","apply","this","arguments","loadLocalesFile","_ref4","_callee2","loadPath","locale","namespace","resolvedPath","json","_context2","replace","readFileSync","t0","TranslationError","Error","undefined","_x2","_x3","_x4","writeLocalesFile","_ref5","_callee3","savePath","resolvedSavePath","_context3","writeFileSync","_x5","_x6","_x7","_x8","getPureKey","key","isDefault","splitted","split","getMissingKeys","_ref7","_callee4","_ref6","globPatterns","namespaces","defaultNamespace","defaultLocale","parser","keys","_iterator","_step","uniqueKeys","newKeys","_iterator2","_step2","existingKeys","_iterator3","_step3","pureKey","_context4","Parser","nsSeparator","keySeparator","glob","concat","_createForOfIteratorHelperLoose","done","parseFuncFromString","list","log","_x9","getTextInput","_ref8","_callee5","prompt","_context5","prompts","onState","state","aborted","nextTick","_x10","checkAllKeysExist","_ref10","_callee6","_ref9","locales","_iterator4","_step4","defaultLocaleKeys","_iterator5","_step5","localeKeys","missingKeys","_i2","_Object$entries","_Object$entries$_i","updatedLocaleKeys","_context6","disableTranslation","_x11","_Error","cause","_this","call","_wrapNativeSuper","checkMissing","config","getKeyToReplace","keyToReplace","replaceTranslation","newTranslation","newValue","_object","translateMissing","newKeysWithDefaultLocale","newKey","newKeysObject","translatedValues","_loop","reduce","relevantKeys","delegateYield","syncLocales","t1","warn","t2","t3","t4","program","Command","description","version","option","command","_commands","cmd","allowExcessArguments","argument","action","arg","options","_config$model","res","isGemini","openaiKey","geminiKey","keyToUse","dotenv","opts","env","includes","parsed","OPENAI_API_KEY","GEMINI_API_KEY","OpenAI","apiKey","baseURL","argv"],"mappings":"y9RAAO,IAAMA,EAAY,CACvB,CACEC,MAAO,UACPC,KAAM,SACNC,MAAO,MAET,CACEF,MAAO,UACPC,KAAM,UACNC,MAAO,MAET,CACEF,MAAO,UACPC,KAAM,UACNC,MAAO,MAET,CACEF,MAAO,WACPC,KAAM,SACNC,MAAO,MAET,CACEF,MAAO,QACPC,KAAM,SACNC,MAAO,MAET,CACEF,MAAO,KACPC,KAAM,UACNC,MAAO,MAET,CACEF,MAAO,UACPC,KAAM,UACNC,MAAO,MAET,CACEF,MAAO,WACPC,KAAM,UACNC,MAAO,MAET,CACEF,MAAO,aACPC,KAAM,QACNC,MAAO,MAET,CACEF,MAAO,YACPC,KAAM,aACNC,MAAO,MAET,CACEF,MAAO,SACPC,KAAM,UACNC,MAAO,MAET,CACEF,MAAO,SACPC,KAAM,SACNC,MAAO,MAET,CACEF,MAAO,aACPC,KAAM,YACNC,MAAO,MAET,CACEF,MAAO,QACPC,KAAM,UACNC,MAAO,MAET,CACEF,MAAO,QACPC,KAAM,YACNC,MAAO,MAET,CACEF,MAAO,UACPC,KAAM,UACNC,MAAO,MAET,CACEF,MAAO,UACPC,KAAM,QACNC,MAAO,MAET,CACEF,MAAO,WACPC,KAAM,QACNC,MAAO,MAET,CACEF,MAAO,MACPC,KAAM,WACNC,MAAO,MAET,CACEF,MAAO,MACPC,KAAM,SACNC,MAAO,MAET,CACEF,MAAO,SACPC,KAAM,WACNC,MAAO,MAET,CACEF,MAAO,WACPC,KAAM,WACNC,MAAO,MAET,CACEF,MAAO,SACPC,KAAM,YACNC,MAAO,MAET,CACEF,MAAO,YACPC,KAAM,SACNC,MAAO,MAET,CACEF,MAAO,SACPC,KAAM,QACNC,MAAO,MAET,CACEF,MAAO,QACPC,KAAM,QACNC,MAAO,MAET,CACEF,MAAO,mBACPC,KAAM,aACNC,MAAO,MAET,CACEF,MAAO,aACPC,KAAM,aACNC,MAAO,OClIEC,EAAa,SAAHC,GAEM,IAAAC,EAAAD,EAD3BE,WAAAA,OAAa,IAAHD,EAAG,gBAAeA,EAEtBE,EAAWC,EAAKC,KAAKC,QAAQC,MAAOL,GAErCM,E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"}
|
package/dist/i18n-magic.esm.js
CHANGED
|
@@ -666,20 +666,25 @@ var loadLocalesFile = /*#__PURE__*/function () {
|
|
|
666
666
|
while (1) switch (_context2.prev = _context2.next) {
|
|
667
667
|
case 0:
|
|
668
668
|
if (!(typeof loadPath === "string")) {
|
|
669
|
-
_context2.next =
|
|
669
|
+
_context2.next = 11;
|
|
670
670
|
break;
|
|
671
671
|
}
|
|
672
672
|
resolvedPath = loadPath.replace("{{lng}}", locale).replace("{{ns}}", namespace);
|
|
673
673
|
content = fs.readFileSync(resolvedPath, "utf-8");
|
|
674
|
+
_context2.prev = 3;
|
|
674
675
|
json = JSON.parse(content);
|
|
675
676
|
return _context2.abrupt("return", json);
|
|
676
|
-
case
|
|
677
|
+
case 8:
|
|
678
|
+
_context2.prev = 8;
|
|
679
|
+
_context2.t0 = _context2["catch"](3);
|
|
680
|
+
throw new TranslationError("Invalid JSON in locale file for " + locale + ":" + namespace + ". Path: " + resolvedPath, locale, namespace, _context2.t0 instanceof Error ? _context2.t0 : undefined);
|
|
681
|
+
case 11:
|
|
677
682
|
return _context2.abrupt("return", loadPath(locale, namespace));
|
|
678
|
-
case
|
|
683
|
+
case 12:
|
|
679
684
|
case "end":
|
|
680
685
|
return _context2.stop();
|
|
681
686
|
}
|
|
682
|
-
}, _callee2);
|
|
687
|
+
}, _callee2, null, [[3, 8]]);
|
|
683
688
|
}));
|
|
684
689
|
return function loadLocalesFile(_x2, _x3, _x4) {
|
|
685
690
|
return _ref4.apply(this, arguments);
|
|
@@ -1387,12 +1392,12 @@ var _loop = function _loop() {
|
|
|
1387
1392
|
var cmd = program.command(command.name).description(command.description);
|
|
1388
1393
|
// Add key option to replace command
|
|
1389
1394
|
if (command.name === "replace") {
|
|
1390
|
-
cmd.option("-k, --key <key>", "translation key to replace");
|
|
1395
|
+
cmd.option("-k, --key <key>", "translation key to replace").allowExcessArguments(true).argument("[key]", "translation key to replace");
|
|
1391
1396
|
}
|
|
1392
1397
|
cmd.action( /*#__PURE__*/function () {
|
|
1393
|
-
var _ref = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime().mark(function _callee(options) {
|
|
1398
|
+
var _ref = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime().mark(function _callee(arg, options) {
|
|
1394
1399
|
var _config$model;
|
|
1395
|
-
var res, config, isGemini, openaiKey, geminiKey, key, keyType, openai;
|
|
1400
|
+
var res, config, isGemini, openaiKey, geminiKey, key, keyType, openai, keyToUse;
|
|
1396
1401
|
return _regeneratorRuntime().wrap(function _callee$(_context) {
|
|
1397
1402
|
while (1) switch (_context.prev = _context.next) {
|
|
1398
1403
|
case 0:
|
|
@@ -1418,11 +1423,13 @@ var _loop = function _loop() {
|
|
|
1418
1423
|
apiKey: key
|
|
1419
1424
|
}, isGemini && {
|
|
1420
1425
|
baseURL: "https://generativelanguage.googleapis.com/v1beta/openai/"
|
|
1421
|
-
}));
|
|
1422
|
-
if (command.name === "replace"
|
|
1426
|
+
})); // For replace command, check for key in argument or option
|
|
1427
|
+
if (command.name === "replace") {
|
|
1428
|
+
// If key is provided as positional argument, use that first
|
|
1429
|
+
keyToUse = typeof arg === "string" ? arg : options.key;
|
|
1423
1430
|
command.action(_extends({}, config, {
|
|
1424
1431
|
openai: openai
|
|
1425
|
-
}),
|
|
1432
|
+
}), keyToUse);
|
|
1426
1433
|
} else {
|
|
1427
1434
|
command.action(_extends({}, config, {
|
|
1428
1435
|
openai: openai
|
|
@@ -1434,7 +1441,7 @@ var _loop = function _loop() {
|
|
|
1434
1441
|
}
|
|
1435
1442
|
}, _callee);
|
|
1436
1443
|
}));
|
|
1437
|
-
return function (_x) {
|
|
1444
|
+
return function (_x, _x2) {
|
|
1438
1445
|
return _ref.apply(this, arguments);
|
|
1439
1446
|
};
|
|
1440
1447
|
}());
|