@vocab/react
Advanced tools
Comparing version 0.0.5 to 0.0.6
# @vocab/react | ||
## 0.0.6 | ||
### Patch Changes | ||
- [`26b52f4`](https://github.com/seek-oss/vocab/commit/26b52f4878ded440841e08c858bdc9e685500c2a) [#16](https://github.com/seek-oss/vocab/pull/16) Thanks [@jahredhope](https://github.com/jahredhope)! - Enable debugging with DEBUG environment variable | ||
- Updated dependencies [[`08de30d`](https://github.com/seek-oss/vocab/commit/08de30d338c2a5ebdcf14da7c736dddf22e7ca9e)]: | ||
- @vocab/types@0.0.4 | ||
## 0.0.5 | ||
@@ -4,0 +13,0 @@ |
@@ -11,7 +11,2 @@ 'use strict'; | ||
const trace = (...params) => { | ||
// eslint-disable-next-line no-console | ||
console.log(...params); | ||
}; | ||
const TranslationsContext = /*#__PURE__*/React__default['default'].createContext(undefined); | ||
@@ -52,3 +47,2 @@ const TranslationsProvider = ({ | ||
trace('useTranslation', 'returning not ready'); | ||
return { | ||
@@ -64,3 +58,2 @@ t: () => ' ', | ||
if (!((_translationsObject = translationsObject) === null || _translationsObject === void 0 ? void 0 : _translationsObject[key])) { | ||
trace('useTranslation', 't', 'Missing value', key); | ||
return null; | ||
@@ -67,0 +60,0 @@ } |
@@ -11,7 +11,2 @@ 'use strict'; | ||
const trace = (...params) => { | ||
// eslint-disable-next-line no-console | ||
console.log(...params); | ||
}; | ||
const TranslationsContext = /*#__PURE__*/React__default['default'].createContext(undefined); | ||
@@ -52,3 +47,2 @@ const TranslationsProvider = ({ | ||
trace('useTranslation', 'returning not ready'); | ||
return { | ||
@@ -64,3 +58,2 @@ t: () => ' ', | ||
if (!((_translationsObject = translationsObject) === null || _translationsObject === void 0 ? void 0 : _translationsObject[key])) { | ||
trace('useTranslation', 't', 'Missing value', key); | ||
return null; | ||
@@ -67,0 +60,0 @@ } |
import React, { useContext, useReducer } from 'react'; | ||
const trace = (...params) => { | ||
// eslint-disable-next-line no-console | ||
console.log(...params); | ||
}; | ||
const TranslationsContext = /*#__PURE__*/React.createContext(undefined); | ||
@@ -43,3 +38,2 @@ const TranslationsProvider = ({ | ||
trace('useTranslation', 'returning not ready'); | ||
return { | ||
@@ -55,3 +49,2 @@ t: () => ' ', | ||
if (!((_translationsObject = translationsObject) === null || _translationsObject === void 0 ? void 0 : _translationsObject[key])) { | ||
trace('useTranslation', 't', 'Missing value', key); | ||
return null; | ||
@@ -58,0 +51,0 @@ } |
{ | ||
"name": "@vocab/react", | ||
"version": "0.0.5", | ||
"version": "0.0.6", | ||
"main": "dist/vocab-react.cjs.js", | ||
@@ -12,3 +12,3 @@ "module": "dist/vocab-react.esm.js", | ||
"dependencies": { | ||
"@vocab/types": "^0.0.3", | ||
"@vocab/types": "^0.0.4", | ||
"intl-messageformat": "^9.3.18" | ||
@@ -15,0 +15,0 @@ }, |
175
README.md
# Vocab | ||
Vocab is a strongly-typed internationalisation framework for React | ||
Vocab is a strongly typed internationalisation framework for React. | ||
## Getting started | ||
### Step 1: Install Dependencies | ||
Vocab is a monorepo with different packages you can install depending on your usage, the below list will get you started using the cli, React and webpack integrations. | ||
```bash | ||
$ npm i --save @vocab/cli @vocab/react @vocab/webpack | ||
``` | ||
### Step 2: Setup Webpack plugin | ||
Before starting to write code you'll need to setup webpack to understand how to use `translation.json` files. | ||
This is done using the **VocabWebpackPlugin**. | ||
**webpack.config.js** | ||
```js | ||
const VocabWebpackPlugin = require('@vocab/webpack').default; | ||
module.exports = { | ||
..., | ||
plugins: [new VocabWebpackPlugin({})] | ||
} | ||
``` | ||
### Step 3: Configure Vocab | ||
You can configure Vocab directly when calling the API or via a `vocab.config.js` file. | ||
In this example we've configured two languages, English and French, where our initial `translation.json` files will use English. | ||
**vocab.config.js** | ||
```js | ||
module.exports = { | ||
devLanguage: 'en', | ||
languages: [{ name: 'en' }, { name: 'fr' }] | ||
}; | ||
``` | ||
### Step 3: Set the language using the React Provider | ||
Vocab doesn't tell you how to select or change your language. You just need to tell Vocab what language to use. | ||
**Note:** Using methods discussed later we'll make sure the first language is loaded on page load. However, after this changing languages may then lead to a period of no translations as Vocab downloads the new language's translations. | ||
**src/App.tsx** | ||
```tsx | ||
import { TranslationsProvider } from '@vocab/react'; | ||
function App({ children }) { | ||
return ( | ||
<TranslationsProvider language={language}> | ||
{children} | ||
</TranslationsProvider> | ||
); | ||
} | ||
``` | ||
### Step 4: Create initial values and use them | ||
A translation file is a JSON file consisting of a flat structure of keys, each with a message and an optional description. | ||
**./translations.json** | ||
```json | ||
{ | ||
"my key": { | ||
"message": "Hello from Vocab", | ||
"description": "An optional description to help when translating" | ||
} | ||
} | ||
``` | ||
You can then import these translations into your React components. Translations can be used by calling the `t` function returned by `useTranslation`. | ||
**./MyComponent.tsx** | ||
```tsx | ||
import { useTranslation } from '@vocab/react'; | ||
import translations from './translations.json'; | ||
function MyComponent({ children }) { | ||
const { t } = useTranslation(translations); | ||
return <div>{t('my key')}</div>; | ||
} | ||
``` | ||
### Step 5: Create translations | ||
So far your app will run, but you're missing any translations other than the initial language. The below file can be created manually; however, you can also integrate with a remote translation platform to push and pull translations automatically. | ||
**./\_\_translations\_\_/translations.fr-FR.json** | ||
```json | ||
{ | ||
"my key": { | ||
"message": "Bonjour de Vocab", | ||
"decription": "An optional description to help when translating" | ||
} | ||
} | ||
``` | ||
### Step 6: Optimize for fast page loading | ||
Using the above method without optimizing what chunks webpack uses you may find the page needing to do an extra round trip to load languages on a page. | ||
This is where `getChunkName` can be used to retrieve the Webpack chunk used for a specific language. | ||
For example here is a Server Render function that would add the current language chunk to [Loadable component's ChunkExtractor](https://loadable-components.com/docs/api-loadable-server/#chunkextractor). | ||
**src/render.tsx** | ||
```tsx | ||
import { getChunkName } from '@vocab/webpack/chunk-name'; | ||
// ... | ||
const chunkName = getChunkName(language); | ||
const extractor = new ChunkExtractor(); | ||
extractor.addChunk(chunkName); | ||
``` | ||
## Configuration | ||
Configuration can either be passed into the Node API directly or be gathered from the nearest _vocab.config.js_ file. | ||
**vocab.config.js** | ||
```js | ||
module.exports = { | ||
devLanguage: 'en', | ||
languages: [ | ||
{ name: 'en' }, | ||
{ name: 'en-AU', extends: 'en' }, | ||
{ name: 'en-US', extends: 'en' }, | ||
{ name: 'fr-FR' } | ||
] | ||
}; | ||
``` | ||
## Generate Types | ||
Vocab generates custom `translation.json.d.ts` files that give your React components strongly typed translations to work with. | ||
To generate these types run: | ||
```bash | ||
$ vocab generate-types | ||
``` | ||
## External translation tooling | ||
Vocab can be used to syncronize your translations with translations from a remote translation platform. | ||
| Platform | Environment Variables | | ||
| -------------------------------------------- | ----------------------------------- | | ||
| [Phrase](https://developers.phrase.com/api/) | PHRASE_PROJECT_ID, PHRASE_API_TOKEN | | ||
```bash | ||
$ vocab push --branch my-branch | ||
$ vocab pull --branch my-branch | ||
``` | ||
### License | ||
MIT. |
Sorry, the diff of this file is not supported yet
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
16132
177
270
+ Added@vocab/types@0.0.4(transitive)
- Removed@vocab/types@0.0.3(transitive)
Updated@vocab/types@^0.0.4