--- createdAt: 2024-08-13 updatedAt: 2025-08-20 title: Formateadores description: Utilidades de formateo conscientes del locale basadas en Intl para números, porcentajes, moneda, fechas, tiempo relativo, unidades y notación compacta. Incluye un helper Intl en caché. keywords: - Formateadores - Intl - Número - Moneda - Porcentaje - Fecha - Tiempo Relativo - Unidades - Compacto - Lista - Internacionalización slugs: - doc - formatters history: - version: 5.8.0 date: 2025-08-20 changes: Añadidos formateadores para Vue - version: 5.8.0 date: 2025-08-18 changes: Añadida documentación de formateadores - version: 5.8.0 date: 2025-08-20 changes: Añadido formateadores de vue - version: 5.8.0 date: 2025-08-18 changes: Añadida documentación de formateadores - version: 5.8.0 date: 2025-08-20 changes: Añadida documentación del formateador de listas - version: 5.8.0 date: 2025-08-20 changes: Añadidas utilidades Intl adicionales (DisplayNames, Collator, PluralRules) - version: 5.8.0 date: 2025-08-20 changes: Añadidas utilidades de configuración regional (getLocaleName, getLocaleLang, getLocaleFromPath, etc.) - version: 5.8.0 date: 2025-08-20 changes: Añadidas utilidades para manejo de contenido (getContent, getTranslation, getIntlayer, etc.) --- # Formateadores de Intlayer ## Resumen Intlayer proporciona un conjunto de helpers ligeros construidos sobre las APIs nativas de `Intl`, además de un wrapper `Intl` en caché para evitar construir repetidamente formateadores pesados. Estas utilidades son completamente conscientes del locale y pueden usarse desde el paquete principal `intlayer`. ### Importar ```ts import { Intl, number, percentage, currency, date, relativeTime, units, compact, list, getLocaleName, getLocaleLang, getLocaleFromPath, getPathWithoutLocale, getLocalizedUrl, getHTMLTextDir, getContent, getTranslation, getIntlayer, getIntlayerAsync, } from "intlayer"; ``` Si usas React, también hay hooks disponibles; consulta `react-intlayer/format`. ## Intl en caché El `Intl` exportado es un wrapper ligero y en caché alrededor del `Intl` global. Memoiza instancias de `NumberFormat`, `DateTimeFormat`, `RelativeTimeFormat`, `ListFormat`, `DisplayNames`, `Collator` y `PluralRules`, lo que evita reconstruir repetidamente el mismo formateador. Debido a que la construcción de formateadores es relativamente costosa, esta caché mejora el rendimiento sin cambiar el comportamiento. El wrapper expone la misma API que el `Intl` nativo, por lo que el uso es idéntico. - La caché es por proceso y transparente para los llamadores. > Si `Intl.DisplayNames` no está disponible en el entorno, se imprime una única advertencia solo para desarrolladores (considera usar un polyfill). Ejemplos: ```ts import { Intl } from "intlayer"; // Formateo de números const numberFormat = new Intl.NumberFormat("en-GB", { style: "currency", currency: "GBP", }); numberFormat.format(1234.5); // "£1,234.50" // Nombres para idiomas, regiones, etc. const displayNames = new Intl.DisplayNames("fr", { type: "language" }); displayNames.of("en"); // "anglais" // Ordenación para clasificación const collator = new Intl.Collator("fr", { sensitivity: "base" }); collator.compare("é", "e"); // 0 (igual) // Reglas de pluralización const pluralRules = new Intl.PluralRules("fr"); pluralRules.select(1); // "one" pluralRules.select(2); // "other" ``` ## Utilidades adicionales de Intl Más allá de los ayudantes para formateadores, también puedes usar directamente el wrapper cacheado de Intl para otras funcionalidades de Intl: ### `Intl.DisplayNames` Para nombres localizados de idiomas, regiones, monedas y escrituras: ```ts import { Intl } from "intlayer"; const languageNames = new Intl.DisplayNames("en", { type: "language" }); languageNames.of("fr"); // "Francés" const regionNames = new Intl.DisplayNames("fr", { type: "region" }); regionNames.of("US"); // "Estados Unidos" ``` ### `Intl.Collator` Para la comparación y ordenación de cadenas conscientes del locale: ```ts import { Intl } from "intlayer"; const collator = new Intl.Collator("de", { sensitivity: "base", numeric: true, }); const words = ["äpfel", "zebra", "100", "20"]; words.sort(collator.compare); // ["20", "100", "äpfel", "zebra"] ``` ### `Intl.PluralRules` Para determinar las formas plurales en diferentes locales: ```ts import { Intl } from "intlayer"; const pluralRules = new Intl.PluralRules("ar"); pluralRules.select(0); // "zero" pluralRules.select(1); // "one" pluralRules.select(2); // "two" pluralRules.select(3); // "few" pluralRules.select(11); // "many" ``` ## Utilidades de Locale ### `getLocaleName(displayLocale, targetLocale?)` Obtiene el nombre localizado de un locale en otro locale: ```ts import { getLocaleName } from "intlayer"; getLocaleName("fr", "en"); // "French" getLocaleName("en", "fr"); // "anglais" getLocaleName("de", "es"); // "alemán" ``` - **displayLocale**: El locale para el cual obtener el nombre - **targetLocale**: El locale en el que se mostrará el nombre (por defecto es displayLocale) ### `getLocaleLang(locale?)` Extrae el código de idioma de una cadena de locale: ```ts import { getLocaleLang } from "intlayer"; getLocaleLang("en-US"); // "en" getLocaleLang("fr-CA"); // "fr" getLocaleLang("de"); // "de" ``` - **locale**: El locale del cual extraer el idioma (por defecto es el locale actual) ### `getLocaleFromPath(inputUrl)` Extrae el segmento de locale de una URL o ruta: ```ts import { getLocaleFromPath } from "intlayer"; getLocaleFromPath("/en/dashboard"); // "en" getLocaleFromPath("/fr/dashboard"); // "fr" getLocaleFromPath("/dashboard"); // "en" (locale predeterminado) getLocaleFromPath("https://example.com/es/about"); // "es" ``` - **inputUrl**: La cadena completa de URL o ruta a procesar - **returns**: El locale detectado o el locale predeterminado si no se encuentra ningún locale ### `getPathWithoutLocale(inputUrl, locales?)` Elimina el segmento de locale de una URL o ruta: ```ts import { getPathWithoutLocale } from "intlayer"; getPathWithoutLocale("/en/dashboard"); // "/dashboard" getPathWithoutLocale("/fr/dashboard"); // "/dashboard" getPathWithoutLocale("https://example.com/en/about"); // "https://example.com/about" ``` - **inputUrl**: La cadena completa de URL o ruta a procesar - **locales**: Matriz opcional de locales soportados (por defecto, los locales configurados) - **returns**: La URL sin el segmento de locale ### `getLocalizedUrl(url, currentLocale, locales?, defaultLocale?, prefixDefault?)` Genera una URL localizada para el locale actual: ```ts import { getLocalizedUrl } from "intlayer"; getLocalizedUrl("/about", "fr", ["en", "fr"], "en", false); // "/fr/about" getLocalizedUrl("/about", "en", ["en", "fr"], "en", false); // "/about" getLocalizedUrl("https://example.com/about", "fr", ["en", "fr"], "en", true); // "https://example.com/fr/about" ``` - **url**: La URL original para localizar - **currentLocale**: El locale actual - **locales**: Matriz opcional de locales soportados (por defecto, los locales configurados) - **defaultLocale**: Locale predeterminado opcional (por defecto, el locale predeterminado configurado) - **prefixDefault**: Indica si se debe prefijar el locale predeterminado (por defecto, el valor configurado) ### `getHTMLTextDir(locale?)` Devuelve la dirección del texto para un locale: ```ts import { getHTMLTextDir } from "intlayer"; getHTMLTextDir("en-US"); // "ltr" getHTMLTextDir("ar"); // "rtl" getHTMLTextDir("he"); // "rtl" ``` - **locale**: El locale para obtener la dirección del texto (por defecto, el locale actual) - **returns**: `"ltr"`, `"rtl"` o `"auto"` ## Utilidades para el Manejo de Contenido ### `getContent(node, nodeProps, locale?)` Transforma un nodo de contenido con todos los plugins disponibles (traducción, enumeración, inserción, etc.): ```ts import { getContent } from "intlayer"; const content = getContent( contentNode, { dictionaryKey: "common", dictionaryPath: "/path/to/dict" }, "fr" ); ``` - **node**: El nodo de contenido a transformar - **nodeProps**: Propiedades para el contexto de transformación - **locale**: Locale opcional (por defecto, el locale predeterminado configurado) ### `getTranslation(languageContent, locale?, fallback?)` Extrae contenido para un locale específico de un objeto de contenido multilingüe: ```ts import { getTranslation } from "intlayer"; const content = getTranslation( { en: "Hello", fr: "Bonjour", de: "Hallo", }, "fr", true ); // "Bonjour" ``` - **languageContent**: Objeto que mapea locales a contenido - **locale**: Locale objetivo (por defecto el locale predeterminado configurado) - **fallback**: Indica si se debe usar el locale predeterminado como respaldo (por defecto es true) ### `getIntlayer(dictionaryKey, locale?, plugins?)` Recupera y transforma contenido de un diccionario por clave: ```ts import { getIntlayer } from "intlayer"; const content = getIntlayer("common", "fr"); const nestedContent = getIntlayer("common", "fr", customPlugins); ``` - **dictionaryKey**: La clave del diccionario a recuperar - **locale**: Locale opcional (por defecto es el locale predeterminado configurado) - **plugins**: Array opcional de plugins personalizados para transformación ### `getIntlayerAsync(dictionaryKey, locale?, plugins?)` Recupera contenido de un diccionario remoto de forma asíncrona: ```ts import { getIntlayerAsync } from "intlayer"; const content = await getIntlayerAsync("common", "fr"); ``` - **dictionaryKey**: La clave del diccionario a recuperar - **locale**: Locale opcional (por defecto es el locale predeterminado configurado) - **plugins**: Array opcional de plugins personalizados para transformación ## Formateadores Todos los helpers a continuación son exportados desde `intlayer`. ### `number(value, options?)` Formatea un valor numérico utilizando agrupación y decimales sensibles al locale. - **value**: `number | string` - **options**: `Intl.NumberFormatOptions & { locale?: LocalesValues }` Ejemplos: ```ts import { number } from "intlayer"; number(123456.789); // "123,456.789" (en en-US) number("1000000", { locale: "fr" }); // "1 000 000" number(1234.5, { minimumFractionDigits: 2 }); // "1,234.50" ``` ### `percentage(value, options?)` Formatea un número como una cadena de porcentaje. Comportamiento: los valores mayores que 1 se interpretan como porcentajes enteros y se normalizan (por ejemplo, `25` → `25%`, `0.25` → `25%`). - **value**: `number | string` - **options**: `Intl.NumberFormatOptions & { locale?: LocalesValues }` Ejemplos: ```ts import { percentage } from "intlayer"; percentage(0.25); // "25%" percentage(25); // "25%" percentage(0.237, { minimumFractionDigits: 1 }); // "23.7%" ``` ### `currency(value, options?)` Formatea un valor como moneda localizada. Por defecto es `USD` con dos dígitos decimales. - **value**: `number | string` - **options**: `Intl.NumberFormatOptions & { locale?: LocalesValues }` - Campos comunes: `currency` (por ejemplo, `"EUR"`), `currencyDisplay` (`"symbol" | "code" | "name"`) Ejemplos: ```ts import { currency } from "intlayer"; currency(1234.5, { currency: "EUR" }); // "€1,234.50" currency("5000", { locale: "fr", currency: "CAD", currencyDisplay: "code" }); // "5 000,00 CAD" ``` ### `date(date, optionsOrPreset?)` Formatea un valor de fecha/hora con `Intl.DateTimeFormat`. - **date**: `Date | string | number` - **optionsOrPreset**: `Intl.DateTimeFormatOptions & { locale?: LocalesValues }` o uno de los preajustes: - Preajustes: `"short" | "long" | "dateOnly" | "timeOnly" | "full"` Ejemplos: ```ts import { date } from "intlayer"; date(new Date(), "short"); // p. ej., "08/02/25, 14:30" date("2025-08-02T14:30:00Z", { locale: "fr", month: "long", day: "numeric" }); // "2 août" ``` ### `relativeTime(from, to = new Date(), options?)` Formatea el tiempo relativo entre dos instantes con `Intl.RelativeTimeFormat`. - Pasa "now" como primer argumento y el objetivo como segundo para obtener una frase natural. - **from**: `Date | string | number` - **to**: `Date | string | number` (por defecto `new Date()`) - **options**: `{ locale?: LocalesValues; unit?: Intl.RelativeTimeFormatUnit; numeric?: Intl.RelativeTimeFormatNumeric; style?: Intl.RelativeTimeFormatStyle }` - El valor predeterminado de `unit` es `"second"`. Ejemplos: ```ts import { relativeTime } from "intlayer"; const now = new Date(); const in3Days = new Date(now.getTime() + 3 * 864e5); relativeTime(now, in3Days, { unit: "day" }); // "en 3 días" const twoHoursAgo = new Date(now.getTime() - 2 * 3600e3); relativeTime(now, twoHoursAgo, { unit: "hour", numeric: "auto" }); // "hace 2 horas" ``` ### `units(value, options?)` Formatea un valor numérico como una cadena de unidad localizada usando `Intl.NumberFormat` con `style: 'unit'`. - **value**: `number | string` - **options**: `Intl.NumberFormatOptions & { locale?: LocalesValues }` - Campos comunes: `unit` (por ejemplo, `"kilometer"`, `"byte"`), `unitDisplay` (`"short" | "narrow" | "long"`) - Valores predeterminados: `unit: 'day'`, `unitDisplay: 'short'`, `useGrouping: false` Ejemplos: ```ts import { units } from "intlayer"; units(5, { unit: "kilometer", unitDisplay: "long", locale: "en-GB" }); // "5 kilometers" units(1024, { unit: "byte", unitDisplay: "narrow" }); // "1,024B" (dependiente del locale) ``` ### `compact(value, options?)` Formatea un número usando notación compacta (por ejemplo, `1.2K`, `1M`). - **value**: `number | string` - **options**: `Intl.NumberFormatOptions & { locale?: LocalesValues }` (usa internamente `notation: 'compact'`) Ejemplos: ```ts import { compact } from "intlayer"; compact(1200); // "1.2K" compact("1000000", { locale: "fr", compactDisplay: "long" }); // "1 million" ``` ### `list(values, options?)` Formatea un arreglo de valores en una cadena de lista localizada usando `Intl.ListFormat`. - **values**: `(string | number)[]` - **options**: `Intl.ListFormatOptions & { locale?: LocalesValues }` - Campos comunes: `type` (`"conjunction" | "disjunction" | "unit"`), `style` (`"long" | "short" | "narrow"`) - Valores por defecto: `type: 'conjunction'`, `style: 'long'` Ejemplos: ```ts import { list } from "intlayer"; list(["apple", "banana", "orange"]); // "apple, banana, and orange" list(["red", "green", "blue"], { locale: "fr", type: "disjunction" }); // "rouge, vert ou bleu" list([1, 2, 3], { type: "unit" }); // "1, 2, 3" ``` ## Notas - Todos los ayudantes aceptan entradas de tipo `string`; internamente se convierten a números o fechas. - El locale por defecto es el configurado en `internationalization.defaultLocale` si no se proporciona. - Estas utilidades son envoltorios ligeros; para un formateo avanzado, pase las opciones estándar de `Intl`. ## Puntos de entrada y re-exportaciones (`@index.ts`) Los formateadores residen en el paquete core y se re-exportan desde paquetes de nivel superior para mantener las importaciones ergonómicas en diferentes entornos de ejecución: Ejemplos: ```ts // Código de la aplicación (recomendado) import { number, currency, date, relativeTime, units, compact, list, Intl, getLocaleName, getLocaleLang, getLocaleFromPath, getPathWithoutLocale, getLocalizedUrl, getHTMLTextDir, getContent, getTranslation, getIntlayer, getIntlayerAsync, } from "intlayer"; ``` ### React Componentes cliente: ```tsx import { useNumber, useCurrency, useDate, usePercentage, useCompact, useList, useRelativeTime, useUnit, } from "react-intlayer/format"; // o en aplicaciones Next.js import { useNumber, useCurrency, useDate, usePercentage, useCompact, useList, useRelativeTime, useUnit, } from "next-intlayer/client/format"; const MyComponent = () => { const number = useNumber(); const currency = useCurrency(); const date = useDate(); const percentage = usePercentage(); const compact = useCompact(); const list = useList(); const relativeTime = useRelativeTime(); const unit = useUnit(); return (
{number(123456.789)}
{currency(1234.5, { currency: "EUR" })}
{date(new Date(), "short")}
{percentage(0.25)}
{compact(1200)}
{list(["apple", "banana", "orange"])}
{relativeTime(new Date(), new Date() + 1000)}
{unit(123456.789, { unit: "kilometer" })}