JSPM

  • Created
  • Published
  • Downloads 353024
  • Score
    100M100P100Q214011F
  • License MIT

PluralFormat and SelectFormat Message and i18n Tool - A JavaScript Implemenation of the ICU standards.

Package Exports

  • messageformat

This package does not declare an exports field, so the exports above have been automatically detected and optimized by JSPM instead. If any package subpath is missing, it is recommended to post an issue to the original package (messageformat) to support the "exports" field. If that is not possible, create a JSPM override to customize the exports field for this package.

Readme

This library provides a formatter and other tools for Unicode MessageFormat 2.0 (MF2), the new standard for localization developed by the MessageFormat Working Group.

This includes a formatter that can be used as a polyfill for the proposed [ECMA-402 Intl.MessageFormat] formatter.

The API provided by this library is current as of the LDML 47 (March 2025) Final version of the MF2 specification.

npm install --save messageformat
import { MessageFormat } from 'messageformat';

const msg = 'Today is {$today :datetime dateStyle=medium}';
const mf = new MessageFormat('en', msg);

mf.format({ today: new Date('2022-02-02') });
// 'Today is Feb 2, 2022'

The library also provides a number of other tools and utilities for MF2, such as:

  • MF2 data model conversion tools

    import { parseMessage, stringifyMessage } from 'messageformat';
  • MF2 data model validation and transformation tools

    import { validate, visit } from 'messageformat';
  • Concreate Syntax Tree (CST) tools for MF2

    import { parseCST, messageFromCST, stringifyCST } from 'messageformat/cst';
  • Utilities for building custom function handlers for MF2

    import {
      DraftFunctions,
      asPositiveInteger,
      asString
    } from 'messageformat/functions';

In addition to supporting MF2 syntax, compilers and formatting function runtimes are also provided for ICU MessageFormat and Fluent messages:

For more information on the types and functions provided by this package, see the documentation site.

[!IMPORTANT] The v4 release of the messageformat package has an entirely different API compared to its earlier major releases, which were built on top of ICU MessageFormat, aka "MF1". For that, please see @messageformat/core instead.