Receive notifications about upcoming Intlayer releases
    Creation:2024-08-11Last update:2025-09-26

    Intlayer CLI

    Install Package

    Install the necessary packages using npm:

    npm install intlayer-cli -g

    If intlayer package is already installed, the cli is automatically installed. You can skip this step.

    intlayer-cli package

    intlayer-cli package intend to transpile your intlayer declarations into dictionaries.

    This package will transpile all intlayer files, such as src/**/*.content.{ts|js|mjs|cjs|json}. See how to declare your Intlayer declaration files.

    To interpret intlayer dictionaries you can interpreters, such as react-intlayer, or next-intlayer

    Configuration File Support

    Intlayer accepts multiple configuration file formats:

    • intlayer.config.ts
    • intlayer.config.js
    • intlayer.config.json
    • intlayer.config.cjs
    • intlayer.config.mjs
    • .intlayerrc

    To see how to configure available locales, or other parameters, refer to the configuration documentation here.

    Run intlayer commands

    Check CLI version

    npx intlayer --versionnpx intlayer version

    Both commands print the installed Intlayer CLI version.

    Build dictionaries

    To build your dictionaries, you can run the commands:

    npx intlayer build

    or in watch mode

    npx intlayer build --watch

    This command will find your declaration content files as default as ./src/**/*.content.{ts|js|mjs|cjs|json|tsx|jsx}. And build the dictionaries in the .intlayer directory.

    Aliases:
    • npx intlayer dictionaries build
    • npx intlayer dictionary build
    • npx intlayer dic build
    Arguments:
    • --base-dir: Specify the base directory for the project. To retrieve the intlayer configuration, the command will look for the intlayer.config.{ts,js,json,cjs,mjs} file in the base directory.

      Example: npx intlayer build --base-dir ./src

    • --env: Specify the environment (e.g., development, production). Useful in the case you use environment variables in your intlayer configuration file.

      Example: npx intlayer build --env production

    • --env-file: Provide a custom environment file to load variables from. Useful in the case you use environment variables in your intlayer configuration file.

      Example: npx intlayer build --env-file .env.production.local

    • --with: Start command in parallel with the build.

      Example: npx intlayer build --with "next dev --turbopack"

    • --skip-prepare: Skip the prepare step.

      Example: npx intlayer build --skip-prepare

    Watch dictionaries

    npx intlayer watch

    This command will watch for changes in your content declaration files and build the dictionaries in the .intlayer directory. This command is the equivalent of npx intlayer build --watch --skip-prepare.

    Aliases:
    • npx intlayer dictionaries watch
    • npx intlayer dictionary watch
    • npx intlayer dic watch
    Arguments:
    • --with: Start command in parallel with the watch.

      Example: npx intlayer watch --with "next dev --turbopack"

    Push dictionaries

    npx intlayer dictionary push

    If intlayer editor is installed, you can also push dictionaries to the editor. This command will allow to make the dictionaries available to the editor. By this way, you can share your dictionaries with your team and edit your content without editing the code of your application.

    Aliases:
    • npx intlayer dictionaries push
    • npx intlayer dictionary push
    • npx intlayer dic push
    Arguments:

    Dictionary options:

    • -d, --dictionaries: ids of the dictionaries to pull. If not specified, all dictionaries will be pushed.

      Example: npx intlayer dictionary push -d my-dictionary-id my-other-dictionary-id

    Configuration options:

    • --base-dir: Specify the base directory for the project. To retrieve the intlayer configuration, the command will look for the intlayer.config.{ts,js,json,cjs,mjs} file in the base directory.

      Example: npx intlayer dictionary push --env-file .env.production.local

    Environment variables options:

    • --env: Specify the environment (e.g., development, production). Useful in the case you use environment variables in your intlayer configuration file.
    • --env-file: Provide a custom environment file to load variables from. Useful in the case you use environment variables in your intlayer configuration file.

      Example: npx intlayer dictionary push --env-file .env.production.local

      Example: npx intlayer dictionary push --env production

    Output options:

    • -r, --delete-locale-dictionary: Skip the question that asking to delete the locales directories once the dictionaries are pushed, and remove them. By default, if the dictionary is defined locally, it will overwrite distant dictionaries content.

      Example: npx intlayer dictionary push -r

      Example: npx intlayer dictionary push --delete-locale-dictionary

    • -k, --keep-locale-dictionary: Skip the question that asking to delete the locales directories once the dictionaries are pushed, and keep them. By default, is the dictionary is defined locally, it will overwrite distant dictionaries content.

      Example: npx intlayer dictionary push -k

      Example: npx intlayer dictionary push --keep-locale-dictionary

    Log options:

    • --verbose: Enable verbose logging for debugging. (default to true using CLI)

    Git options:

    • --git-diff: Only run on dictionaries that includes changes from base (default origin/main) to current branch (default: HEAD).
    • --git-diff-base: Specify the base reference for git diff (default origin/main).
    • --git-diff-current: Specify the current reference for git diff (default: HEAD).
    • --uncommitted: Include uncommitted changes.
    • --unpushed: Include unpushed changes.
    • --untracked: Include untracked files.

      Example: npx intlayer dictionary push --git-diff --git-diff-base origin/main --git-diff-current HEAD

      Example: npx intlayer dictionary push --uncommitted --unpushed --untracked

    Pull distant dictionaries

    npx intlayer pull

    If intlayer editor is installed, you can also pull dictionaries from the editor. By this way, you can overwrite the content of your dictionaries for the need of your application.

    Aliases:
    • npx intlayer dictionaries pull
    • npx intlayer dictionary pull
    • npx intlayer dic pull
    Arguments:

    Dictionary options:

    • -d, --dictionaries: Ids of the dictionaries to pull. If not specified, all dictionaries will be pulled.

      Example: npx intlayer dictionary pull -d my-dictionary-id my-other-dictionary-id

    Configuration options:

    • --base-dir: Specify the base directory for the project. To retrieve the intlayer configuration, the command will look for the intlayer.config.{ts,js,json,cjs,mjs} file in the base directory.

      Example: npx intlayer dictionary push --env-file .env.production.local

    Environment variables options:

    • --env: Specify the environment (e.g., development, production).
    • --env-file: Provide a custom environment file to load variables from.
    • --base-dir: Specify the base directory for the project. To retrieve the intlayer configuration, the command will look for the intlayer.config.{ts,js,json,cjs,mjs} file in the base directory.

      Example: npx intlayer dictionary push --env-file .env.production.local

      Example: npx intlayer dictionary push --env production

    Output options:

    • **--new-dictionaries-path : Path to the directory where the new dictionaries will be saved. If not specified, the news dictionaries will be saved in the ./intlayer-dictionaries directory of the project. If a filePath fields is specified in your dictionary content, the dictionaries will not consider this argument and will be saved in the specified filePath directory.

    Log options:

    • --verbose: Enable verbose logging for debugging. (default to true using CLI)
    Example:
    npx intlayer dictionary pull --newDictionariesPath ./my-dictionaries-dir/

    Fill / audit / translate dictionaries

    npx intlayer fill

    This command analyzes your content declaration files for potential issues such as missing translations, structural inconsistencies, or type mismatches. If it finds any problems, intlayer fill will propose or apply updates to keep your dictionaries consistent and complete.

    Aliases:
    • npx intlayer dictionaries fill
    • npx intlayer dictionary fill
    • npx intlayer dic fill
    Arguments:

    Files list options:

    • -f, --file [files...]: A list of specific content declaration files to audit. If not provided, all discovered *.content.{ts,js,mjs,cjs,tsx,jsx,json} based on your configuration file setup will be audited.

      Example: npx intlayer dictionary fill -f src/home/app.content.ts

    • -k, --keys [keys...]: Filter dictionaries based on keys. If not provided, all dictionaries will be audited.

      Example: npx intlayer dictionary fill -k key1 key2

    • --excluded-keys [excludedKeys...]: Filter out dictionaries based on keys. If not provided, all dictionaries will be audited.

      Example: npx intlayer dictionary fill --excluded-keys key1 key2

    • --path-filter [pathFilters...]: Filter dictionaries based on glob pattern for file paths.

      Example: npx intlayer dictionary fill --path-filter "src/home/**"

    Entry output options:

    • --source-locale [sourceLocale]: The source locale to translate from. If not specified, the default locale from your configuration will be used.

    • --output-locales [outputLocales...]: Target locales to translate to. If not specified, all locales from your configuration will be used except the source locale.

    • --mode [mode]: Translation mode: complete, review. Default is complete. complete will fill all missing content, review will fill missing content and review existing keys.

    Git options:

    • --git-diff: Only run on dictionaries that includes changes from base (default origin/main) to current branch (default: HEAD).
    • --git-diff-base: Specify the base reference for git diff (default origin/main).
    • --git-diff-current: Specify the current reference for git diff (default: HEAD).
    • --uncommitted: Include uncommitted changes.
    • --unpushed: Include unpushed changes.
    • --untracked: Include untracked files.

      Example: npx intlayer doc translate --git-diff --git-diff-base origin/main --git-diff-current HEAD

      Example: npx intlayer doc translate --uncommitted --unpushed --untracked

    AI options:

    • --model [model]: The AI model to use for the translation (e.g., gpt-3.5-turbo).
    • --provider [provider]: The AI provider to use for the translation.
    • --temperature [temperature]: Temperature setting for the AI model.
    • --api-key [apiKey]: Provide your own API key for the AI service.
    • --custom-prompt [prompt]: Provide a custom prompt for your translation instructions.
    • --application-context [applicationContext]: Provide additional context for the AI translation.

      Example: npx intlayer fill --model gpt-3.5-turbo --provider openai --temperature 0.5 --api-key sk-1234567890 --application-context "My application is a cat store"

    Environment variables options:

    • --env: Specify the environment (e.g., development, production).
    • --env-file [envFile]: Provide a custom environment file to load variables from.

      Example: npx intlayer fill --env-file .env.production.local

      Example: npx intlayer fill --env production

    Configuration options:

    • --base-dir: Specify the base directory for the project.

      Example: npx intlayer fill --base-dir ./src

    Log options:

    • --verbose: Enable verbose logging for debugging. (default to true using CLI)
    Example:
    npx intlayer fill --file src/home/*.content.ts --source-locale en --output-locales fr es --model gpt-3.5-turbo

    This command will translate content from English to French and Spanish for all content declaration files in the src/home/ directory using the GPT-3.5 Turbo model.

    Test missing translations

    npx intlayer content test

    This command analyzes your content declaration files to identify missing translations across all configured locales. It provides a comprehensive report showing which translation keys are missing for which locales, helping you maintain consistency across your multilingual content.

    Example output:
    pnpm intlayer content testMissing translations: - home-page                      - tr         - src/components/HomePage/homePage.content.ts - server-component               - es, tr     - src/components/ServerComponent/serverComponent.content.ts - client-component               - pl, tr     - src/components/ClientComponent/clientComponent.content.tsLocales: en, ru, ja, fr, ko, zh, es, de, ar, it, en-GB, pt, hi, tr, plRequired locales: enMissing locales: pl, tr, esMissing required locales: -Total missing locales: 3Total missing required locales: 0
    Arguments:

    Configuration options:

    • --env: Specify the environment (e.g., development, production).
    • --env-file [envFile]: Provide a custom environment file to load variables from.
    • --base-dir: Specify the base directory for the project.

      Example: npx intlayer content test --base-dir ./src --env-file .env.production.local

    Log options:

    • --verbose: Enable verbose logging for debugging. (default to true using CLI)

      Example: npx intlayer content test --verbose

    Example:
    npx intlayer content test --verbose
    Example output:
    npx intlayer content listContent declaration files: - home-page        - src/components/HomePage/homePage.content.ts - server-component - src/components/ServerComponent/serverComponent.content.ts - client-component - src/components/ClientComponent/clientComponent.content.tsTotal content declaration files: 3

    This command will scan all your content declaration files and display:

    • A detailed list of missing translations with their keys, missing locales, and file paths
    • Summary statistics including total missing locales and missing required locales
    • Color-coded output for easy identification of issues

    The output helps you quickly identify which translations need to be completed to ensure your application works properly across all configured locales.

    List content declaration files

    npx intlayer content list

    This command displays all content declaration files in your project, showing their dictionary keys and file paths. It's useful for getting an overview of all your content files and verifying that they are properly discovered by Intlayer.

    Example:
    npx intlayer content list

    This command will output:

    • A formatted list of all content declaration files with their keys and relative file paths
    • The total count of content declaration files found

    The output helps you verify that all your content files are properly configured and discoverable by the Intlayer system.

    Manage Configuration

    Get Configuration

    The configuration get command retrieves the current configuration for Intlayer, particularly the locale settings. This is useful for verifying your setup.

    npx intlayer configuration get
    Aliases:
    • npx intlayer config get
    • npx intlayer conf get
    Arguments:
    • --env: Specify the environment (e.g., development, production).
    • --env-file: Provide a custom environment file to load variables from.
    • --base-dir: Specify the base directory for the project.
    • --verbose: Enable verbose logging for debugging. (default to true using CLI)

    Push Configuration

    The configuration push command uploads your configuration to the Intlayer CMS and editor. This step is necessary to enable the use of distant dictionaries in the Intlayer Visual Editor.

    npx intlayer configuration push
    Aliases:
    • npx intlayer config push
    • npx intlayer conf push
    Arguments:
    • --env: Specify the environment (e.g., development, production).
    • --env-file: Provide a custom environment file to load variables from.
    • --base-dir: Specify the base directory for the project.
    • --verbose: Enable verbose logging for debugging. (default to true using CLI)

    By pushing the configuration, your project is fully integrated with the Intlayer CMS, enabling seamless dictionary management across teams.

    Document Management

    The doc commands provide tools for managing and translating documentation files across multiple locales.

    Translate Document

    The doc translate command automatically translates documentation files from a base locale to target locales using AI translation services.

    npx intlayer doc translate
    Arguments:

    File list options:

    • --doc-pattern [docPattern...]: Glob patterns to match documentation files to translate.

      Example: npx intlayer doc translate --doc-pattern "docs/**/*.md" "src/**/*.mdx"

    • --excluded-glob-pattern [excludedGlobPattern...]: Glob patterns to exclude from translation.

      Example: npx intlayer doc translate --excluded-glob-pattern "docs/internal/**"

    • --skip-if-modified-before [skipIfModifiedBefore]: Skip the file if it has been modified before the given time.

      • Can be an absolute time as "2025-12-05" (string or Date)
      • Can be a relative time in ms 1 * 60 * 60 * 1000 (1 hour)
      • This option check update time of the file using the fs.stat method. So it could be impacted by Git or other tools that modify the file.

      Example: npx intlayer doc translate --skip-if-modified-before "2025-12-05"

    • --skip-if-modified-after [skipIfModifiedAfter]: Skip the file if it has been modified within the given time.

      • Can be an absolute time as "2025-12-05" (string or Date)
      • Can be a relative time in ms 1 * 60 * 60 * 1000 (1 hour)
      • This option check update time of the file using the fs.stat method. So it could be impacted by Git or other tools that modify the file.

      Example: npx intlayer doc translate --skip-if-modified-after "2025-12-05"

    Entry output options:

    • --locales [locales...]: Target locales to translate documentation to.

      Example: npx intlayer doc translate --locales fr es de

    • --base-locale [baseLocale]: Source locale to translate from.

      Example: npx intlayer doc translate --base-locale en

    File processing options:

    • --nb-simultaneous-file-processed [nbSimultaneousFileProcessed]: Number of files to process simultaneously for translation.

      Example: npx intlayer doc translate --nb-simultaneous-file-processed 5

    AI options:

    • --model [model]: The AI model to use for translation (e.g., gpt-3.5-turbo).
    • --provider [provider]: The AI provider to use for translation.
    • --temperature [temperature]: Temperature setting for the AI model.
    • --api-key [apiKey]: Provide your own API key for the AI service.
    • --application-context [applicationContext]: Provide additional context for the AI translation.
    • --custom-prompt [prompt]: Customize the base prompt used for translation. (Note: For most use cases, the --custom-instructions option is recommended instead as it provides better control over translation behavior.)

      Example: npx intlayer doc translate --model deepseek-chat --provider deepseek --temperature 0.5 --api-key sk-1234567890 --application-context "My application is a cat store"

    Environment variables options:

    • --env: Specify the environment (e.g., development, production).
    • --env-file [envFile]: Provide a custom environment file to load variables from.
    • --base-dir: Specify the base directory for the project.

      Example: npx intlayer doc translate --base-dir ./docs --env-file .env.production.local

    Log options:

    • --verbose: Enable verbose logging for debugging. (default to true using CLI)

      Example: npx intlayer doc translate --verbose

    Custom instructions options:

    • --custom-instructions [customInstructions]: Custom instructions added to the prompt. Usefull to apply specific rules regarding formatting, urls translation, etc.

      • Can be an absolute time as "2025-12-05" (string or Date)
      • Can be a relative time in ms 1 * 60 * 60 * 1000 (1 hour)
      • This option check update time of the file using the fs.stat method. So it could be impacted by Git or other tools that modify the file.

      Example: npx intlayer doc translate --custom-instructions "Avoid translating urls, and keep the markdown format"

      Example: npx intlayer doc translate --custom-instructions "$(cat ./instructions.md)"

    Git options:

    • --git-diff: Only run on dictionaries that includes changes from base (default origin/main) to current branch (default: HEAD).
    • --git-diff-base: Specify the base reference for git diff (default origin/main).
    • --git-diff-current: Specify the current reference for git diff (default: HEAD).
    • --uncommitted: Include uncommitted changes.
    • --unpushed: Include unpushed changes.
    • --untracked: Include untracked files.

      Example: npx intlayer doc translate --git-diff --git-diff-base origin/main --git-diff-current HEAD

      Example: npx intlayer doc translate --uncommitted --unpushed --untracked

    Note that the output file path will be determined by replacing the following patterns

    • /{{baseLocale}}/ by /{{locale}}/ (Unix)
    • {{baseLocale}}` by {{locale}}` (Windows)
    • _{{baseLocale}}. by _{{locale}}.
    • {{baseLocale}}_ by {{locale}}_
    • .{{baseLocaleName}}. by .{{localeName}}.

    If the pattern is not found, the output file will add the .{{locale}} at the extensions of the file. ./my/file.md will be translated to ./my/file.fr.md for the French locale.

    Review Document

    The doc review command analyzes documentation files for quality, consistency, and completeness across different locales.

    npx intlayer doc review

    It can be used to review files that are already translated, and to check if the translation is correct.

    For most use cases,

    • prefer using the doc translate when the translated version of this file is not available.
    • prefer using the doc review when the translated version of this file already exists.

    Note that the review process consumes more entry tokens than the translate process to review the same file entirely. However, the review process will optimize the chunks to review, and will skip the parts that are not changed.

    Arguments:

    The doc review command accepts the same arguments as doc translate, allowing you to review specific documentation files and apply quality checks.

    If you activated one of the git options, the command will only review the part of the files that getting changed. The script will process by chunking the file and review each chunk. If there is no changes in the chunk, the script will skip it to speed up the review process and limit the AI Provider API cost.

    Use intlayer commands in your package.json

    package.json
    "scripts": {  "intlayer:build": "npx intlayer build",  "intlayer:watch": "npx intlayer build --watch",  "intlayer:push": "npx intlayer push",  "intlayer:pull": "npx intlayer pull",  "intlayer:fill": "npx intlayer fill",  "intlayer:list": "npx intlayer content list",  "intlayer:test": "npx intlayer content test",  "intlayer:doc:translate": "npx intlayer doc translate",  "intlayer:doc:review": "npx intlayer doc review"}

    Editor commands

    The editor command rewrap the intlayer-editor commands.

    To be able to use the editor command, the intlayer-editor package must be installed. (See Intlayer Visual Editor)

    package.json
    "scripts": {  "intlayer:editor:start": "npx intlayer editor start --with 'next dev --turbopack'"}

    CLI SDK

    The CLI SDK is a library that allows you to use the Intlayer CLI in your own code.

    npm install @intlayer/cli --save-dev

    Example of usage:

    import {  push,  pull,  fill,  build,  listContentDeclaration,  testMissingTranslations,  docTranslate,  docReview,} from "@intlayer/cli";push();// ...pull();// ...fill();// ...build();// ...listContentDeclaration();// ...testMissingTranslations();// ...docTranslate();// ...docReview();// ...

    Debug intlayer command

    1. Ensure you're using the latest version

    Run:

    npx intlayer --version                  # current locale intlayer versionnpx intlayer@latest --version           # current latest intlayer version

    2. Check if the command is registered

    You can check with:

    npx intlayer --help                     # Shows the list of available commands and usage informationnpx intlayer dictionary build --help    # Shows the list of available options for a command

    3. Restart your terminal

    Sometimes a terminal restart is needed to recognize new commands.

    4. Clear npx cache (if you're stuck with an older version)

    npx clear-npx-cache

    Doc History

    Version Date Changes
    6.1.2 2025-09-26 Add version command
    6.1.0 2025-09-26 Set verbose option to default to true using CLI
    6.1.0 2025-09-23 Add watch command and with option
    6.0.1 2025-09-23 Add editor command
    6.0.0 2025-09-17 Add content test and list command
    5.5.11 2025-07-11 Update CLI command parameters documentation
    5.5.10 2025-06-29 Init history
    Receive notifications about upcoming Intlayer releases
    CLI | Intlayer