Arrays de localización PHP

Traducción con IA para archivos de localización PHP con Lingo.dev CLI

¿Qué son los arrays de localización PHP?

Los archivos de localización PHP utilizan sintaxis de arrays PHP para almacenar cadenas de traducción. Se usan comúnmente en frameworks PHP como Laravel para gestionar aplicaciones multiidioma.

Por ejemplo:

<?php

return [
    'Hello, world!',
    'Welcome to MyApp',

    'welcome_message' => 'Welcome!',
    'error_text'      => 'Something went wrong',

    'navigation' => [
        'home'    => 'Home',
        'about'   => 'About',
        'contact' => 'Contact',
    ],
];

¿Qué es Lingo.dev CLI?

Lingo.dev CLI es una CLI gratuita y de código abierto para traducir aplicaciones y contenido con IA. Está diseñada para reemplazar el software tradicional de gestión de traducciones mientras se integra con pipelines existentes.

Para obtener más información, consulta Descripción general.

Acerca de esta guía

Esta guía explica cómo traducir archivos de localización PHP con Lingo.dev CLI.

Aprenderás a:

  • Crear un proyecto desde cero
  • Configurar un pipeline de traducción
  • Generar traducciones con IA

Requisitos previos

Para usar Lingo.dev CLI, asegúrate de tener instalado Node.js v18+:

❯ node -v
v22.17.0

Paso 1. Configurar un proyecto

En el directorio de tu proyecto, crea un archivo i18n.json:

{
  "$schema": "https://lingo.dev/schema/i18n.json",
  "version": "1.10",
  "locale": {
    "source": "en",
    "targets": ["es"]
  },
  "buckets": {}
}

Este archivo define el comportamiento del pipeline de traducción, incluyendo entre qué idiomas traducir y dónde existe el contenido localizable en el sistema de archivos.

Para obtener más información sobre las propiedades disponibles, consulta i18n.json.

Paso 2. Configurar el idioma de origen

El idioma de origen es el idioma y región original en el que se escribió tu contenido. Para configurar el idioma de origen, establece la propiedad locale.source en el archivo i18n.json:

{
  "$schema": "https://lingo.dev/schema/i18n.json",
  "version": "1.10",
  "locale": {
    "source": "en",
    "targets": ["es"]
  },
  "buckets": {}
}

El idioma de origen debe proporcionarse como una etiqueta de idioma BCP 47.

Para ver la lista completa de códigos de idioma que admite Lingo.dev CLI, consulta Códigos de idioma admitidos.

Paso 3. Configurar los idiomas de destino

Los idiomas de destino son los idiomas y regiones a los que deseas traducir tu contenido. Para configurar los idiomas de destino, establece la propiedad locale.targets en el archivo i18n.json:

{
  "$schema": "https://lingo.dev/schema/i18n.json",
  "version": "1.10",
  "locale": {
    "source": "en",
    "targets": ["es"]
  },
  "buckets": {}
}

Paso 4. Crear el contenido de origen

Si aún no lo has hecho, crea uno o más archivos de localización PHP que contengan el contenido a traducir. Estos archivos deben estar ubicados en una ruta que incluya el idioma de origen en algún lugar de la ruta (por ejemplo, como un nombre de directorio como en/ o como parte del nombre del archivo como messages.en.php).

Paso 5. Crear un bucket

  1. En el archivo i18n.json, añade un objeto "php" al objeto buckets:

    {
      "$schema": "https://lingo.dev/schema/i18n.json",
      "version": "1.10",
      "locale": {
        "source": "en",
        "targets": ["es"]
      },
      "buckets": {
        "php": {}
      }
    }
    
  2. En el objeto "php", define un array de uno o más patrones include:

    {
      "$schema": "https://lingo.dev/schema/i18n.json",
      "version": "1.10",
      "locale": {
        "source": "en",
        "targets": ["es"]
      },
      "buckets": {
        "php": {
          "include": ["./[locale]/example.php"]
        }
      }
    }
    

    Estos patrones definen qué archivos traducir.

    Los patrones en sí:

    • deben contener [locale] como marcador de posición para el idioma configurado
    • pueden apuntar a rutas de archivos (por ejemplo, "[locale]/messages.php")
    • pueden usar asteriscos como marcadores de posición comodín (por ejemplo, "[locale]/*.php")

    No se admiten patrones glob recursivos (por ejemplo, **/*.php).

Paso 6. Configurar un LLM

Lingo.dev CLI utiliza modelos de lenguaje de gran tamaño (LLM) para traducir contenido con IA. Para usar uno de estos modelos, necesitas una clave API de un proveedor compatible.

Para empezar lo más rápido posible, recomendamos usar Lingo.dev Engine, nuestra propia plataforma alojada que ofrece 10 000 tokens de uso gratuito mensual:

  1. Regístrate para obtener una cuenta de Lingo.dev.

  2. Ejecuta el siguiente comando:

    npx lingo.dev@latest login
    

    Esto abrirá tu navegador predeterminado y te pedirá que te autentiques.

  3. Sigue las instrucciones.

Paso 7. Generar las traducciones

En el directorio que contiene el archivo i18n.json, ejecuta el siguiente comando:

npx lingo.dev@latest run

Este comando:

  1. Lee el archivo i18n.json.
  2. Encuentra los archivos que necesitan ser traducidos.
  3. Extrae el contenido traducible de los archivos.
  4. Utiliza el LLM configurado para traducir el contenido extraído.
  5. Escribe el contenido traducido de vuelta en el sistema de archivos.

La primera vez que se generan las traducciones, se crea un archivo i18n.lock. Este archivo realiza un seguimiento del contenido que ha sido traducido, evitando retraducciones innecesarias en ejecuciones posteriores.

Ejemplo

en/example.php

<?php

return [
    'Hello, world!',
    'Welcome to MyApp',

    "It's \"simple\" with a backslash \\ and newline\nAll text here",

    'welcome_message' => 'Welcome!',
    'error_text'      => 'Something went wrong',

    'navigation' => [
        'home'    => 'Home',
        'about'   => 'About',
        'contact' => 'Contact',
    ],

    'forms' => [
        'login' => [
            'username_label' => 'Username',
            'password_label' => 'Password',
            'submit_button'  => 'Sign In',
        ],
    ],

    'mixed_content' => [
        'title'        => 'Settings',
        'count'        => 42,
        'enabled'      => true,
        'nothing_here' => null,
        'description'  => 'App settings and preferences',
    ],
];

es/example.php

<?php

return [
    '¡Hola, mundo!',
    'Bienvenido a MyApp',

    "Es \"simple\" con una barra invertida \\ y salto de línea\nTodo el texto aquí",

    'welcome_message' => '¡Bienvenido!',
    'error_text'      => 'Algo salió mal',

    'navigation' => [
        'home'    => 'Inicio',
        'about'   => 'Acerca de',
        'contact' => 'Contacto',
    ],

    'forms' => [
        'login' => [
            'username_label' => 'Nombre de usuario',
            'password_label' => 'Contraseña',
            'submit_button'  => 'Iniciar sesión',
        ],
    ],

    'mixed_content' => [
        'title'        => 'Configuración',
        'count'        => 42,
        'enabled'      => true,
        'nothing_here' => null,
        'description'  => 'Configuración y preferencias de la aplicación',
    ],
];

i18n.json

{
  "version": "1.10",
  "locale": {
    "source": "en",
    "targets": ["es"]
  },
  "buckets": {
    "php": {
      "include": ["./[locale]/example.php"]
    }
  },
  "$schema": "https://lingo.dev/schema/i18n.json"
}

i18n.lock

version: 1
checksums:
  0ee8d6907f60fa2cc288cc0503ecbba1:
    "0": 0468579ef2fbc83c9d520c2f2f1c5059
    "1": d1c3a9f35e377554a4ccaa467ca26614
    "2": 769caedbdc5246bb9fee615739534bbd
    3/welcome_message: 8778dc41547a2778d0f9482da989fc00
    4/error_text: a3cd2f01c073f1f5ff436d4b132d39cf
    5/navigation/home: 104a3db3b671c04e167eafbe21e57881
    5/navigation/about: 944521eeeed2511833d2299931273c71
    5/navigation/contact: 9afa39bc47019ee6dec6c74b6273967c
    6/forms/login/username_label: 2ee65bc2dd2f12cf2672f95b2a054bf8
    6/forms/login/password_label: 223a61cf906ab9c40d22612c588dff48
    6/forms/login/submit_button: ec7b8f314fe9bc6591006707484ede61
    7/mixed_content/title: 8df6777277469c1fd88cc18dde2f1cc3
    7/mixed_content/description: 063afcd2ea84a82a1acc8f5c9fd8e42f