extract-react-intl-messages
This package will generate json or yaml files from a glob. It will generate one file per locale, with the ids of each message defined by the defineMessages function of react-intl. The value of each of these keys will be an empty string, except for your defaultLocale which will be populated with the defaultMessage.
Install
This project has a peer dependency on babel-core
.
To use this with Babel 6, run
$ npm install --save-dev extract-react-intl-messages babel-core
To use this with Babel 7, run
$ npm install --save-dev extract-react-intl-messages babel-core@bridge @babel/core
Usage
app/components/App/messages.js
Run Script
$ extract-messages -l=en,ja -o app/translations -d en --flat false 'app/**/!(*.test).js'
Output
app/translations/en.json
app/translations/ja.json
Recommend
Use with babel-plugin-react-intl-auto: i18n for the component age. Auto management react-intl ID.
CLI
create-react-app user
create .babelrc
like this.
Run with NODE_ENV=development
.
$ NODE_ENV=development extract-messages ...
API
extractReactIntlMessages(locales, input, buildDir, [options])
locales
Type: Array<string>
Example: ['en', 'ja']
input
Type: Array<string>
Target files.
glob.
buildDir
Type: string
Export directory.
options
defaultLocale
Type: string
Default: en
format
Type: json
| yaml
Default: json
Set extension to output.
flat
Type: boolean
Default: true
If format is yaml
, set to false
.
Be careful if false
.
See this issue.