loading…
Search for a command to run...
loading…
Localization as code — push, pull, translate, and extract strings from code with AI. 7 MCP tools for type-safe i18n across 182 languages.
Localization as code — push, pull, translate, and extract strings from code with AI. 7 MCP tools for type-safe i18n across 182 languages.
Your app in every language. One command.

Localization as code. Push your translation keys, AI translates to 182 languages, pull type-safe TypeScript definitions. Built for developers, AI agents, and product teams.
Free forever · No credit card · i1n.ai
Traditional i18n means dozens of JSON files, zero type safety, hours of copy-pasting, and deploys that break at 2 AM. Existing tools charge $120+/mo and require browser-based workflows.
i1n is different:
i1n push --translate es,fr,ja and you're donei1n.d.ts with full IDE autocomplete# To use the CLI (global)
npm install -g i1n
# To use the SDK + types (in your app)
npm install i1n
# Local CLI usage (optional)
npm install -D i1n
Supports npm, pnpm, yarn, and bun.
# 1. Initialize (auth + auto-detect setup)
i1n init
# 2. Push your translation keys
i1n push
# 3. Pull translations + auto-generated TypeScript types
i1n pull
i1n initInteractive setup that prepares your workspace.
i1n.config.json (automatically ignored via .gitignore).i1n pushSyncs your local translations to i1n.
i1n pullDownloads translations and generates type-safe IDs.
i1n.d.ts for full IDE autocomplete.i1n limitsReal-time usage tracking.
i1n setup-aiTurns your IDE into a localization expert.
.mdc), Claude Code (CLAUDE.md), Windsurf, and more.i1n mcpMCP server for AI coding assistants.
Starts a Model Context Protocol server that lets Cursor, Claude Code, Windsurf, and other AI assistants execute i1n commands directly from your IDE.
# Add to Claude Code
claude mcp add i1n -- npx i1n mcp
# Or add to .mcp.json / cursor config
{
"mcpServers": {
"i1n": {
"command": "npx",
"args": ["i1n", "mcp"]
}
}
}
7 tools available:
| Tool | Description |
|---|---|
i1n_status |
Get project status, plan, limits, and active languages |
i1n_push |
Push local translation files with automatic diff detection |
i1n_pull |
Pull translations and generate type-safe TypeScript definitions |
i1n_translate |
Translate keys to specified languages using AI |
i1n_add_language |
Add new languages with optional auto-translation |
i1n_extract_and_translate |
Extract strings from code, push as keys, translate to all languages |
i1n_search |
Search existing translation keys by name or value |
The killer workflow — tell your AI agent "internationalize this component":
i1n_extract_and_translate with the extracted stringst('key') callsA 60-minute task in 30 seconds.
| Format | Frameworks | File Sample |
|---|---|---|
| Nested JSON | i18next, next-intl, vue-i18n | en/common.json |
| Flat JSON | React Native, Generic | locales/en.json |
| ARB | Flutter / Dart | app_en.arb |
| YAML | Ruby on Rails | en.yml |
| Android XML | Native Android | strings.xml |
| Apple Strings | iOS / macOS | Localizable.strings |
| TypeScript | Type-safe JSON | locales/en.ts |
The i1n package includes a runtime SDK for web and mobile JS/TS projects. You can use it in two ways:
Use the i1n native engine directly. No external dependencies needed.
import { init, t, setLocale } from "i1n";
// Load your translation resources
init({
locale: "en_us",
resources: {
en_us: {
auth: { login: "Login", title: "Welcome back, {user}" },
items_one: "One item",
items_other: "{count} items",
},
es_es: {
auth: { login: "Entrar", title: "Bienvenido de nuevo, {user}" },
items_one: "Un elemento",
items_other: "{count} elementos",
},
},
});
// Autocomplete and type-safety work out of the box after 'i1n pull'
t("auth.login"); // "Login"
// Support for default values (useful during development)
t("new.key", { defaultValue: "Coming soon..." }); // "Coming soon..."
// Variables & Plurals
t("auth.title", { user: "Fran" }); // "Welcome back, Fran"
t("items", { count: 5 }); // "5 items"
// Switch language at runtime
setLocale("es_es");
t("auth.login"); // "Entrar"
Key resolution works with both nested and flat structures automatically — use whatever format your project prefers.
Already using i18next, vue-i18n, or react-intl? Connect it to i1n with one line and get full autocompletion.
import i18next from "i18next";
import { registerI1n, t } from "i1n";
// Set up i18next as usual
await i18next.init({
lng: "en",
resources: {
/* ... */
},
});
// Connect to i1n — one line
registerI1n((key, params) => i18next.t(key, params));
// Now t() uses i18next under the hood, but with strict type checking
t("common.greeting", { name: "World" }); // Powered by i18next, typed by i1n
Works with any library:
registerI1n((key, params) => i18n.global.t(key, params))registerI1n((key, params) => intl.formatMessage({ id: key }, params))registerI1n((key) => myLookup(key))Define plural variants with _zero, _one, _other suffixes:
// In your translation files:
// "items_zero": "No items"
// "items_one": "One item"
// "items_other": "{count} items"
t("items", { count: 0 }); // "No items"
t("items", { count: 1 }); // "One item"
t("items", { count: 5 }); // "5 items"
Three syntaxes supported universally: {var}, {{var}}, %{var}
The SDK works in plain JS — you just don't get autocompletion:
import { init, t } from "i1n";
init({ locale: "en_us", resources: { en_us: { greeting: "Hello {name}" } } });
t("greeting", { name: "World" }); // "Hello World"
For a "plug and play" experience, use this minimalist provider pattern.
import { createContext, useContext, useState, useEffect } from "react";
import { init, t, getLocale, setLocale as sdkSetLocale } from "i1n";
// 1. Initialize with wordings
// (In a real app, you'd probably import these from your locales folder)
init({
locale: "en_us",
resources: {
/* ... */
},
});
const STORAGE_KEY = "i1n-locale";
const I1nContext = createContext({
locale: "en_us",
setLocale: (l: string) => {},
});
// 2. Persistent Provider
export function I1nProvider({ children, defaultLocale = "en_us" }) {
const [locale, setLocaleState] = useState(() => {
return localStorage.getItem(STORAGE_KEY) || defaultLocale;
});
// Keep SDK in sync
useEffect(() => {
sdkSetLocale(locale);
}, [locale]);
const setLocale = (newLocale: string) => {
localStorage.setItem(STORAGE_KEY, newLocale);
setLocaleState(newLocale);
};
return (
<I1nContext.Provider value={{ locale, setLocale }}>
{children}
</I1nContext.Provider>
);
}
// 3. Simple Hook
export const useI1n = () => ({ t, ...useContext(I1nContext) });
Usage:
const { t, setLocale } = useI1n();
return (
<div>
<h1>{t("auth.title", { user: "Fran" })}</h1>
<button onClick={() => setLocale("es_es")}>Español</button>
</div>
);
Flutter, Android, and iOS projects don't use the SDK. They use the translation files (.arb, .xml, .strings) generated by i1n pull with their native localization systems.
i1n init automatically adds sensitive config files to your .gitignore.The CLI generates a lightweight declaration file (i1n.d.ts) that automatically augments the i1n package with your project's specific keys.
i1n pull. The CLI generates locales/i1n.d.ts and automatically updates your tsconfig.json so your IDE finds them immediately.t from i1n and get full autocomplete + compile-time checking. No manual path mapping required.import { t } from "i1n";
// Full autocomplete & compile-time checking
t("auth.login.title");
// ERROR: Argument of type '"auth.login.titlse"' is not assignable...
t("auth.login.titlse");
| Plan | Price | Keys | Languages | AI translations/mo |
|---|---|---|---|---|
| Starter | $0 | 600 | 2 | 2,000 |
| Pro | $19/mo | 5,000 | 5 | 10,000 |
| Business | $49/mo | 15,000 | 12 | 20,000 |
| Enterprise | Custom | Custom | 182 | Custom |
CLI, SDK, and MCP server are free on every plan. No credit card required for Starter.
Pro lifetime from $99 — only for the first 200 users.
MIT — © 2026 i1n.ai
Добавь это в claude_desktop_config.json и перезапусти Claude Desktop.
{
"mcpServers": {
"i1n": {
"command": "npx",
"args": []
}
}
}