Terima notifikasi tentang rilis Intlayer yang akan datang
    Dibuat:2024-08-13Terakhir diperbarui:2025-10-25

    Intlayer Configuration Documentation

    Overview

    Intlayer configuration files allow customization of various aspects of the plugin, such as internationalization, middleware, and content handling. This document provides a detailed description of each property in the configuration.


    Configuration File Support

    Intlayer accepts JSON, JS, MJS, and TS configuration file formats:

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

    Example config file

    intlayer.config.ts
    import { Locales, type IntlayerConfig } from "intlayer";const config: IntlayerConfig = {  internationalization: {    locales: [Locales.ENGLISH],  },  content: {    contentDir: ["src", "../ui-library"],  },  dictionary: {    fill: "./{{fileName}}.content.json",  },  routing: {    mode: "prefix-no-default",    storage: "cookie",  },  editor: {    applicationURL: "https://example.com",  },  ai: {    apiKey: process.env.OPENAI_API_KEY,    applicationContext: "This is a test application",  },  build: {    importMode: "dynamic",  },};export default config;

    Configuration Reference

    The following sections describe the various configuration settings available for Intlayer.


    Internationalization Configuration

    Defines settings related to internationalization, including available locales and the default locale for the application.

    Properties

    • locales:

      • Type: string[]
      • Default: ['en']
      • Description: The list of supported locales in the application.
      • Example: ['en', 'fr', 'es']
    • requiredLocales:
      • Type: string[]
      • Default: []
      • Description: The list of required locales in the application.
      • Example: []
      • Note: If empty, all locales are required in strict mode.
      • Note: Ensure required locales are also defined in the locales field.
    • strictMode:

      • Type: string
      • Default: inclusive
      • Description: Ensure strong implementations of internationalized content using typescript.
      • Note: If set to "strict", the translation t function will require each declared locales to be defined. If one locale is missing, or if a locale is not declared in your config, it will throw an error.
      • Note: If set to "inclusive", the translation t function will require each declared locales to be defined. If one locale is missing, it will throw a warning. But will accept if a locale is not declared in your config, but exists.
      • Note: If set to "loose", the translation t function will accept any existing locale.
    • defaultLocale:

      • Type: string
      • Default: 'en'
      • Description: The default locale used as a fallback if the requested locale is not found.
      • Example: 'en'
      • Note: This is used to determine the locale when none is specified in the URL, cookie, or header.

    Editor Configuration

    Defines settings related to the integrated editor, including server port and active status.

    Properties

    • applicationURL:

      • Type: string
      • Default: http://localhost:3000
      • Description: The URL of the application. Used to restrict the origin of the editor for security reasons.
      • Example:
        • 'http://localhost:3000'
        • 'https://example.com'
        • process.env.INTLAYER_EDITOR_URL
      • Note: The URL of the application. Used to restrict the origin of the editor for security reasons. If set to '*', the editor is accessible from any origin.
    • port:

      • Type: number
      • Default: 8000
      • Description: The port used by the visual editor server.
    • editorURL:

      • Type: string
      • Default: 'http://localhost:8000'
      • Description: The URL of the editor server. Used to restrict the origin of the editor for security reasons.
        • 'http://localhost:3000'
        • 'https://example.com'
        • process.env.INTLAYER_EDITOR_URL
      • Note: The URL of the editor server to reach from the application. Used to restrict the origins that can interact with the application for security reasons. If set to '*', the editor is accessible from any origin. Should be set if port is changed, or if the editor is hosted on a different domain.
    • cmsURL:

      • Type: string
      • Default: 'https://intlayer.org'
      • Description: The URL of the Intlayer CMS.
      • Example: 'https://intlayer.org'
      • Note: The URL of the Intlayer CMS.
    • backendURL:

      • Type: string
      • Default: https://back.intlayer.org
      • Description: The URL of the backend server.
      • Example: http://localhost:4000
    • enabled:

      • Type: boolean
      • Default: true
      • Description: Indicates if the application interact with the visual editor.
      • Example: process.env.NODE_ENV !== 'production'
      • Note: If true, the editor will be able to interact with the application. If false, the editor will not be able to interact with the application. In any case, the editor can only be enabled by the visual editor. Disabling the editor for specific environments is a way to enforce the security.
    • clientId:

      • Type: string | undefined
      • Default: undefined
      • Description: clientId and clientSecret allow the intlayer packages to authenticate with the backend using oAuth2 authentication. An access token is used to authenticate the user related to the project. To get an access token, go to https://intlayer.org/dashboard/project and create an account.
      • Example: true
      • Note: Important: The clientId and clientSecret should be kept secret and not shared publicly. Please ensure to keep them in a secure location, such as environment variables.
    • clientSecret:

      • Type: string | undefined
      • Default: undefined
      • Description: clientId and clientSecret allow the intlayer packages to authenticate with the backend using oAuth2 authentication. An access token is used to authenticate the user related to the project. To get an access token, go to https://intlayer.org/dashboard/project and create an account.
      • Example: true
      • Note: Important: The clientId and clientSecret should be kept secret and not shared publicly. Please ensure to keep them in a secure location, such as environment variables.
    • dictionaryPriorityStrategy:

      • Type: string
      • Default: 'local_first'
      • Description: The strategy to prioritize dictionaries in the case of both local and distant dictionaries being present. If set to 'distant_first', the application will prioritize distant dictionaries over local dictionaries. If set to 'local_first', the application will prioritize local dictionaries over distant dictionaries.
      • Example: 'distant_first'
    • liveSync:

      • Type: boolean
      • Default: false
      • Description: Indicates if the application server should hot reload the content of the application when a change is detected on the CMS / Visual Editor / Backend.
      • Example: true
      • Note: For example, when a new dictionary is added or updated, the application will update the content to display in the page.
      • Note: Live sync need to externalize the content of the application to another server. That means that it can slightly impact the performance of the application. To limit this, we recommand to host the application and the live sync server on the same machine. Also, the combination of live sync and optimize can apply a consequent number of requests to the live sync server. Depending of your infrastructure, we recommand to test both options and their combination.
    • liveSyncPort:

      • Type: number
      • Default: 4000
      • Description: The port of the live sync server.
      • Example: 4000
      • Note: The port of the live sync server.
    • liveSyncURL:

      • Type: string
      • Default: 'http://localhost:{liveSyncPort}'
      • Description: The URL of the live sync server.
      • Example: 'https://example.com'
      • Note: Point to localhost by default but can be changed to any URL in the case of a remote live sync server.

    Routing Configuration

    Settings that control routing behavior, including URL structure, locale storage, and middleware handling.

    Properties

    • mode:

      • Type: 'prefix-no-default' | 'prefix-all' | 'no-prefix' | 'search-params'
      • Default: 'prefix-no-default'
      • Description: URL routing mode for locale handling.
      • Examples:
        • 'prefix-no-default': /dashboard (en) or /fr/dashboard (fr)
        • 'prefix-all': /en/dashboard (en) or /fr/dashboard (fr)
        • 'no-prefix': /dashboard (locale handled via other means)
        • 'search-params': /dashboard?locale=fr
      • Note: This setting does not impact cookie or locale storage management.
    • storage:

      • Type: false | 'cookie' | 'localStorage' | 'sessionStorage' | CookiesAttributes | LocaleStorageAttributes | Array
      • Default: 'localStorage'
      • Description: Configuration for storing the locale in the client.
      • Examples:

        // Disable storagestorage: false// Simple storage typesstorage: 'cookie'storage: 'localStorage'storage: 'sessionStorage'// Cookie with custom attributesstorage: {  type: 'cookie',  name: 'custom-locale',  domain: '.example.com',  secure: true,  sameSite: 'strict'}// localStorage with custom keystorage: {  type: 'localStorage',  name: 'custom-locale'}// Multiple storage typesstorage: ['cookie', 'localStorage']
      • Note:

        • If false, the locale will not be stored by the middleware
        • Check GDPR compliance for cookies. See https://gdpr.eu/cookies/
        • Recommendation: Configure both localStorage and cookies for GDPR compliance
        • Disable cookie storage by default on the useLocale hook until user consent
    • headerName:

      • Type: string
      • Default: 'x-intlayer-locale'
      • Description: The name of the HTTP header used to determine the locale.
      • Example: 'x-custom-locale'
      • Note: This is useful for API-based locale determination.
    • basePath:

      • Type: string
      • Default: ''
      • Description: The base path for the application URLs.
      • Example: '/my-app'
      • Note:
        • If the application is hosted at https://example.com/my-app
        • The base path is '/my-app'
        • The URL will be https://example.com/my-app/en
        • If the base path is not set, the URL will be https://example.com/en

    When using cookie storage, you can configure additional cookie attributes:

    • name: Cookie name (default: 'INTLAYER_LOCALE')
    • domain: Cookie domain (default: undefined)
    • path: Cookie path (default: undefined)
    • secure: Require HTTPS (default: undefined)
    • httpOnly: HTTP-only flag (default: undefined)
    • sameSite: SameSite policy ('strict' | 'lax' | 'none')
    • expires: Expiration date or days (default: undefined)

    Locale Storage Attributes

    When using localStorage or sessionStorage:

    • type: Storage type ('localStorage' | 'sessionStorage')
    • name: Storage key name (default: 'INTLAYER_LOCALE')

    Configuration Examples

    Here are some common configuration examples for the new v7 routing structure:

    Basic Configuration (Default):

    // intlayer.config.tsexport default defineConfig({  internationalization: {    locales: ["en", "fr", "es"],    defaultLocale: "en",  },  routing: {    mode: "prefix-no-default",    storage: "localStorage",    headerName: "x-intlayer-locale",    basePath: "",  },});

    GDPR Compliant Configuration:

    // intlayer.config.tsexport default defineConfig({  internationalization: {    locales: ["en", "fr", "es"],    defaultLocale: "en",  },  routing: {    mode: "prefix-no-default",    storage: [      {        type: "localStorage",        name: "user-locale",      },      {        type: "cookie",        name: "user-locale",        secure: true,        sameSite: "strict",        httpOnly: false,      },    ],    headerName: "x-intlayer-locale",    basePath: "",  },});

    Search Parameters Mode:

    // intlayer.config.tsexport default defineConfig({  internationalization: {    locales: ["en", "fr", "es"],    defaultLocale: "en",  },  routing: {    mode: "search-params",    storage: "localStorage",    headerName: "x-intlayer-locale",    basePath: "",  },});

    No Prefix Mode with Custom Storage:

    // intlayer.config.tsexport default defineConfig({  internationalization: {    locales: ["en", "fr", "es"],    defaultLocale: "en",  },  routing: {    mode: "no-prefix",    storage: {      type: "sessionStorage",      name: "app-locale",    },    headerName: "x-custom-locale",    basePath: "/my-app",  },});

    Content Configuration

    Settings related to content handling within the application, including directory names, file extensions, and derived configurations.

    Properties

    • watch:

      • Type: boolean
      • Default: process.env.NODE_ENV === 'development'
      • Description: Indicates if Intlayer should watch for changes in the content declaration files in the app to rebuild the related dictionaries.
    • fileExtensions:

      • Type: string[]
      • Default: ['.content.ts', '.content.js', '.content.cjs', '.content.mjs', '.content.json', '.content.tsx', '.content.jsx']
      • Description: File extensions to look for when building dictionaries.
      • Example: ['.data.ts', '.data.js', '.data.json']
      • Note: Customizing file extensions can help avoid conflicts.
    • baseDir:

      • Type: string
      • Default: process.cwd()
      • Description: The base directory for the project.
      • Example: '/path/to/project'
      • Note: This is used to resolve all Intlayer-related directories.
    • contentDir:

      • Type: string[]
      • Default: ['.']
      • Example: ['src', '../../ui-library', require.resolve("@my-package/content")]
      • Description: The directory path where content is stored.
    • dictionariesDir:

      • Type: string
      • Default: '.intlayer/dictionaries'
      • Description: The directory path for storing intermediate or output results.
    • moduleAugmentationDir:

      • Type: string
      • Default: '.intlayer/types'
      • Description: Directory for module augmentation, allowing better IDE suggestions and type checking.
      • Example: 'intlayer-types'
      • Note: Be sure to include this in tsconfig.json.
    • unmergedDictionariesDir:

      • Type: string
      • Default: '.intlayer/unmerged_dictionary'
      • Description: The directory for storing unmerged dictionaries.
      • Example: 'translations'
    • dictionariesDir:

      • Type: string
      • Default: '.intlayer/dictionary'
      • Description: The directory for storing localization dictionaries.
      • Example: 'translations'
    • typesDir:

      • Type: string
      • Default: 'types'
      • Description: The directory for storing dictionary types.
      • Example: 'intlayer-types'
    • mainDir:

      • Type: string
      • Default: 'main'
      • Description: The directory where main application files are stored.
      • Example: 'intlayer-main'
    • excludedPath:

      • Type: string[]
      • Default: ['**/node_modules/**', '**/dist/**', '**/build/**', '**/.intlayer/**', '**/.next/**', '**/.nuxt/**', '**/.expo/**', '**/.vercel/**', '**/.turbo/**', '**/.tanstack/**']
      • Description: Directories excluded from content search.
      • Note: This setting is not yet used, but planned for future implementation.
    • formatCommand:

      • Type: string
      • Default: undefined
      • Description: The command to format the content. When intlayer write your .content files locally, this command will be used to format the content.
      • Example: 'npx prettier --write "{{file}}" --log-level silent' Using Prettier
      • Example: 'npx biome format "{{file}}" --write --log-level none' Using Biome
      • Example: 'npx eslint --fix "{{file}}" --quiet' Using ESLint
      • Note: Intlayer will replace the {{file}} with the path of the file to format.
      • Note: If not set, Intlayer will try to detect the format command automatically. By trying to resolve the following commands: prettier, biome, eslint.

    Dictionary Configuration

    Settings that control dictionary operations, including auto-fill behavior and content generation.

    This dictionary configuration serves two main purposes:

    1. Default Values: Define default values when creating content declaration files
    2. Fallback Behavior: Provide fallback values when specific fields are not defined, allowing you to define dictionary operation behavior globally

    For more information about content declaration files and how configuration values are applied, see the Content File Documentation.

    Properties

    • fill
    • description
    • locale
    • priority
    • live
    • title
    • tags
    • version

    Logger Configuration

    Settings that control the logger, including the prefix to use.

    Properties

    • mode:

      • Type: string
      • Default: default
      • Description: Indicates the mode of the logger.
      • Options: default, verbose, disabled
      • Example: default
      • Note: The mode of the logger. Verbose mode will log more information, but can be used for debugging purposes. Disabled mode will disable the logger.
    • prefix:

      • Type: string
      • Default: '[intlayer] '
      • Description: The prefix of the logger.
      • Example: '[my custom prefix] '
      • Note: The prefix of the logger.

    AI Configuration

    Settings that control the AI features of Intlayer, including the provider, model, and API key.

    This configuration is optional if you're registered on the Intlayer Dashboard using an access key. Intlayer will automatically manage the most efficient and cost-effective AI solution for your needs. Using the default options ensures better long-term maintainability as Intlayer continuously updates to use the most relevant models.

    If you prefer to use your own API key or specific model, you can define your custom AI configuration. This AI configuration will be used globally across your Intlayer environment. CLI commands will use these settings as defaults for the commands (e.g. fill), as well as the SDK, Visual Editor, and CMS. You can override these default values for specific use cases using command parameters.

    Intlayer supports multiple AI providers for enhanced flexibility and choice. Currently supported providers are:

    • OpenAI (default)
    • Anthropic Claude
    • Mistral AI
    • DeepSeek
    • Google Gemini
    • Meta Llama

    Properties

    • provider:

      • Type: string
      • Default: 'openai'
      • Description: The provider to use for the AI features of Intlayer.
      • Options: 'openai', 'anthropic', 'mistral', 'deepseek', 'gemini'
      • Example: 'anthropic'
      • Note: Different providers may require different API keys and have different pricing models.
    • model:

      • Type: string
      • Default: None
      • Description: The model to use for the AI features of Intlayer.
      • Example: 'gpt-4o-2024-11-20'
      • Note: The specific model to use varies by provider.
    • temperature:

      • Type: number
      • Default: None
      • Description: The temperature controls the randomness of the AI's responses.
      • Example: 0.1
      • Note: A higher temperature will make the AI more creative and less predictable.
    • apiKey:

      • Type: string
      • Default: None
      • Description: Your API key for the selected provider.
      • Example: process.env.OPENAI_API_KEY
      • Note: Important: API keys should be kept secret and not shared publicly. Please ensure to keep them in a secure location, such as environment variables.
    • applicationContext:

      • Type: string
      • Default: None
      • Description: Provides additional context about your application to the AI model, helping it generate more accurate and contextually appropriate translations. This can include information about your app's domain, target audience, tone, or specific terminology.

    Build Configuration

    Settings that control how Intlayer optimizes and builds your application's internationalization.

    Build options apply to the @intlayer/babel and @intlayer/swc plugins.

    In development mode, Intlayer uses static imports for dictionaries to simplify the development experience.
    When optimized, Intlayer will replace dictionary calls to optimize chunking, so the final bundle only imports dictionaries that are actually used.

    Properties

    • optimize:

      • Type: boolean
      • Default: process.env.NODE_ENV === 'production'
      • Description: Controls whether the build should be optimized.
      • Example: true
      • Note: When enabled, Intlayer will replace all calls of dictionaries to optimize chunking. That way the final bundle will import only the dictionaries that are used. All imports will stay as static import to avoid async processing when loading the dictionaries.
      • Note: Intlayer will replace all calls of useIntlayer with the defined mode by the importMode option and getIntlayer with getDictionary.
      • Note: This option relies on the @intlayer/babel and @intlayer/swc plugins.
      • Note: Ensure all keys are declared statically in the useIntlayer calls. e.g. useIntlayer('navbar').
    • importMode:
      • Type: 'static' | 'dynamic' | 'live'
      • Default: 'static'
      • Description: Controls how dictionaries are imported.
      • Example: 'dynamic'
      • Note: Available modes:
        • "static": Dictionaries are imported statically. Replaces useIntlayer with useDictionary.
        • "dynamic": Dictionaries are imported dynamically using Suspense. Replaces useIntlayer with useDictionaryDynamic.
        • "live": Dictionaries are fetched dynamically using the live sync API. Replaces useIntlayer with useDictionaryDynamic.
      • Note: Dynamic imports rely on Suspense and may slightly impact rendering performance.
      • Note: If disabled all locales will be loaded at once, even if they are not used.
      • Note: This option relies on the @intlayer/babel and @intlayer/swc plugins.
      • Note: Ensure all keys are declared statically in the useIntlayer calls. e.g. useIntlayer('navbar').
      • Note: This option will be ignored if optimize is disabled.
      • Note: If set to "live", only the dictionaries that are including remote content, and set as "live" flags will be transformed as live mode. Others will be imported dynamically as "dynamic" mode to optimize the number of fetch queries, and load performance.
      • Note: Live mode will use the live sync API to fetch the dictionaries. If the API call fails, the dictionaries will be imported dynamically as "dynamic" mode.
      • Note: This option will not impact the getIntlayer, getDictionary, useDictionary, useDictionaryAsync and useDictionaryDynamic functions.
    • outputFormat:

      • Type: 'esm' | 'cjs'
      • Default: 'esm'
      • Description: Controls the output format of the dictionaries.
      • Example: 'cjs'
      • Note: The output format of the dictionaries.
    • traversePattern:

      • Type: string[]
      • Default: ['**/*.{js,ts,mjs,cjs,jsx,tsx,mjx,cjx}', '!**/node_modules/**']
      • Description: Patterns that define which files should be traversed during optimization.
        • Example: ['src/**/*.{ts,tsx}', '../ui-library/**/*.{ts,tsx}', '!**/node_modules/**']
      • Note: Use this to limit optimization to relevant code files and improve build performance.
      • Note: This option will be ignored if optimize is disabled.
      • Note: Use glob pattern.
    Terima notifikasi tentang rilis Intlayer yang akan datang