A tool to generate i18n language translations using AI.
To install the TranslateGPT package, use the following command:
npm install translategpt
Before using the package, make sure to set up the configuration files and environment variables.
Create a .env
file in the root directory of your project and provide the following variables:
OPENAI_API_KEY=<your_openai_api_key>
OPENAI_MODEL=<openai_model>
TRANSLATEGPT_JS_PATH="<path_to_translateGPT.mjs>"
TRANSLATEGPT_OUTPUT_DIRECTORY="<path_to_output_directory>"
TRANSLATEGPT_MAX_QUERIES=<number of max queries to the OpenAI API per translation, as a safeguard for hallucinations>
TRANSLATEGPT_VERBOSE=<boolean true or false to suppress excess console logs>
Note: Do not share your OpenAI API key with anyone and ensure that the .env
file is added to the .gitignore
file.
Note 2: You can find the valid list of model names in the official docs
Create a translateGPT.mjs
file in the translations
directory of your project and define the translation configuration using the config
object. Here's an example:
// Example of how to structure your translations file, for an e-commerce site
export const config = {
sourceLanguage: "en",
languages: [
{
language: "dutch spoken informally specifically using je instead of u",
abbreviation: "nl",
},
{
language: `german using the informal "duzen"`,
abbreviation: "de",
sourceLanguage: "nl",
},
{
language: "japanese",
abbreviation: "jp",
},
{
language: "cat meows",
abbreviation: "cat",
},
{
language: "english with a hamster accent",
abbreviation: "hamster",
},
],
namespaces: ["app", "shop"],
context: "An innovative e-commerce platform offering a wide range of products from electronics to fashion. The website is designed to provide a seamless shopping experience with a focus on user convenience, security, and satisfaction"
};
Note: if you want to set a different
sourceLanguage
for one of your languages than the default, make sure this language is listed AFTER its source language. For example, German's source language (listed second) is Dutch (listed first)
Modify the configuration according to your project's needs.
Create translation JSON files for each namespace and language in the translations
directory of your project. Here's an example:
{
"Confirm": "Confirm",
"Shop": "Shop",
"Hamster Dance": "Hamster Dance",
"The hamsters are currently {{hamsterStatus}}, if you watch for {{time}}, maybe they'll do something else?": "The hamsters are currently {{hamsterStatus}}, if you watch for {{time}}, maybe they'll do something else?"
}
{
"If you look hard enough, you'll find our mascot- Hambone the Hamster King!": "If you look hard enough, you'll find our mascot- Hambone the Hamster King!",
"My favorite animal is a {{animal}}.": "My favorite animal is a {{animal}}."
}
Create translation files for each language and modify the content accordingly.
Once you have set up the configuration and environment variables, you can generate the translation files using the translategpt
command:
translategpt
The package will generate translations for the specified languages and namespaces, based on the source languages defined in the translateGPT.mjs
configuration file.
This package is licensed under the MIT license. See the license file for more information.