Lingo.dev + .yaml (Rails)

Lingo.dev CLI переводит YAML-файлы интернационализации Ruby on Rails, используя корневые ключи, основанные на локали, для стандартного рабочего процесса интернационализации Rails. CLI управляет всеми переводами Rails в централизованных файлах локалей, поддерживает вложенные ключи Rails для моделей/представлений/контроллеров, обеспечивает работу якорей и алиасов YAML между локалями, бесшовно интегрируется с хелперами Rails t() и строго следует лучшим практикам интернационализации Rails.

Быстрая настройка

Настройка для файлов локалей Rails:

{
  "locale": {
    "source": "en",
    "targets": ["es", "fr", "de"]
  },
  "buckets": {
    "yaml-root-key": {
      "include": ["config/locales/*.yml"]
    }
  }
}

Перевод файлов интернационализации Rails

npx lingo.dev@latest i18n

Управляет контентом, специфичным для локалей Rails, под корневыми ключами, сохраняя структуру YAML и конвенции интернационализации Rails.

Структура интернационализации Rails

Стандартная организация Rails


# config/locales/en.yml

en:
  hello: "Hello world"

  # Переводы моделей
  activerecord:
    models:
      user: "User"
      post: "Post"
    attributes:
      user:
        name: "Name"
        email: "Email Address"

  # Переводы представлений
  layouts:
    application:
      title: "My Rails App"

  # Специфично для контроллеров/действий
  users:
    index:
      title: "All Users"
      new_user: "New User"
    show:
      edit: "Edit User"
      delete: "Delete User"

es:
  hello: "Hola mundo"

  activerecord:
    models:
      user: "Usuario"
      post: "Publicación"
    attributes:
      user:
        name: "Nombre"
        email: "Dirección de Correo"

  layouts:
    application:
      title: "Mi Aplicación Rails"

  users:
    index:
      title: "Todos los Usuarios"
      new_user: "Nuevo Usuario"
    show:
      edit: "Editar Usuario"
      delete: "Eliminar Usuario"

Сообщения валидации Rails

en:
  activerecord:
    errors:
      messages:
        blank: "can't be blank"
        too_short: "is too short (minimum is %{count} characters)"
        too_long: "is too long (maximum is %{count} characters)"
        taken: "has already been taken"

es:
  activerecord:
    errors:
      messages:
        blank: "no puede estar en blanco"
        too_short: "es demasiado corto (mínimo %{count} caracteres)"
        too_long: "es demasiado largo (máximo %{count} caracteres)"
        taken: "ya está en uso"

Возможности интеграции с Rails

Совместимость с методами-хелперами

Работает без проблем с хелперами i18n в Rails:

  • t('users.index.title')
  • I18n.t('hello')
  • <%= t('.edit') %> (ленивый поиск)
  • User.model_name.human

Поддержка интерполяции

ru:
  welcome_message: "Добро пожаловать, %{name}!"
  items_count:
    zero: "Нет элементов"
    one: "Один элемент"
    other: "%{count} элементов"

es:
  welcome_message: "¡Bienvenido, %{name}!"
  items_count:
    zero: "Sin artículos"
    one: "Un artículo"
    other: "%{count} artículos"

Расширенная конфигурация

Несколько файлов локалей Rails

"yaml-root-key": {
  "include": [
    "config/locales/*.yml",
    "config/locales/**/*.yml"
  ]
}

Блокировка системных ключей Rails

"yaml-root-key": {
  "include": ["config/locales/*.yml"],
  "lockedKeys": ["number", "time", "date", "datetime"]
}