9f9214abe5
This PR updates the docs and examples for `create-next-app` to include pnpm usage. The following script was used to update every example README: ```js const fs = require('fs') const examples = fs.readdirSync('./examples') for (let example of examples) { const filename = `./examples/${example}/README.md` const markdown = fs.readFileSync(filename, 'utf8') const regex = new RegExp(`^yarn create next-app --example (.*)$`, 'gm') const output = markdown.replace(regex, (yarn, group) => { const pnpm = `pnpm create next-app -- --example ${group}` return `${yarn}\n# or\n${pnpm}` }) fs.writeFileSync(filename, output) } ``` |
||
---|---|---|
.. | ||
components | ||
locale | ||
pages | ||
.babelrc | ||
.gitignore | ||
lingui.config.js | ||
next.config.js | ||
package.json | ||
README.md |
With Lingui example
This example shows a way to use lingui.js with next.js.
It adds a webpack loader for the messages to avoid having to manually compile while developing as well as adds the compile step to the next build
script for production builds.
The example also uses a Higher order Component which can be added to all pages which will be translated and that checks for a ?lang
query string switch the language. Next.js will dynamically load in the messages for the locale when navigating using a Next.js <Link />
component.
Deploy your own
Deploy the example using Vercel or preview live with StackBlitz
How to use
Execute create-next-app
with npm or Yarn to bootstrap the example:
npx create-next-app --example with-lingui with-lingui-app
# or
yarn create next-app --example with-lingui with-lingui-app
# or
pnpm create next-app -- --example with-lingui with-lingui-app
Deploy it to the cloud with Vercel (Documentation).
How to add more translated strings
To add new strings use the react component <Trans />
and then run yarn export
to export the messages into locale/{language}/messages.po
.
How to add another language
To add another language simply run yarn add-locale <locale ...>
and it will create a new locale in the locale/messages/
directory.