Socket
Socket
Sign inDemoInstall

babel-plugin-lingui-extract-messages

Package Overview
Dependencies
4
Maintainers
1
Versions
39
Alerts
File Explorer

Advanced tools

Install Socket

Detect and block malicious and high-risk dependencies

Install

babel-plugin-lingui-extract-messages


Version published
Maintainers
1
Install size
572 kB
Created

Readme

Source

babel-plugin-lingui-extract-messages

This plugin collects message ids from Trans components

Detail

babel-plugin-lingui-transform-react converts children of Trans component to ICU message format which serves as a message ID. The message IDs are used in message catalogue and translations are assigned to it.

For example following message:

<Trans>
  <Plural 
    value={count}
    one="There's one item matching filter"
    other="There're # items matching filter"
  />
  (see <a href="?all">all</a>).
</Trans>

is converted to ICU message format:

<Trans 
  id="{count, plural, one {There's one item matching filter} other {There're # items matching filter}} (see <0>all</0>)" 
  params={{ count: count }}
  components={[
    <a href="?all" />
  ]}
/>

And following message ID is extracted:

{
  "{count, plural, one {There's one item matching filter} other {There're # items matching filter}} (see <0>all</0>)": {
    "origin": [
      ["App.js", 3] 
    ] 
  }
}

Finall, all files under {localeDir}/_build needs to be merged into final message catalog. This message catalog can be translated into target languages and loaded back to app.

Metadata

Each item in generated file is in format [messageId: string]: metadata, where metadata contains following information:

  • origin - Array of filenames and line numbers from where the message is extracted
  • defaults - Default message if custom messageId is used (<Trans id="msg">Custom message ID</Trans> becomes <Trans id="msg" defaults="Custom message ID" />)

Installation

npm install --save-dev babel-plugin-lingui-extract-messages
# or
yarn add --dev babel-plugin-lingui-extract-messages

Usage

.babelrc

{
  "plugins": ["lingui-extract-messages"]
}

Via CLI

babel --plugins lingui-extract-messages script.js

Via Node API

require("babel-core").transform("code", {
  plugins: ["lingui-extract-messages"]
})

Options

localeDir

string, defaults to locale.

Directory with locales. Files are written to _build subdirectory, one json file per each processed file.

{
  "plugins": [
    ["lingui-extract-messages", {
      "localeDir": "./locale"
    }]
  ]
}

Keywords

FAQs

Last updated on 13 Apr 2017

Did you know?

Socket

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap

Packages

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc