Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/fzn0x/yoi18n
⚡ Straightforward & less effort React i18n library. (Under 1kb gminzipped)
https://github.com/fzn0x/yoi18n
i18n internationalization lightweight localization multi-language react react-i18n react-library translations typescript
Last synced: 3 months ago
JSON representation
⚡ Straightforward & less effort React i18n library. (Under 1kb gminzipped)
- Host: GitHub
- URL: https://github.com/fzn0x/yoi18n
- Owner: fzn0x
- License: mit
- Created: 2024-07-21T07:40:18.000Z (6 months ago)
- Default Branch: main
- Last Pushed: 2024-07-23T04:32:51.000Z (6 months ago)
- Last Synced: 2024-10-12T02:51:20.358Z (4 months ago)
- Topics: i18n, internationalization, lightweight, localization, multi-language, react, react-i18n, react-library, translations, typescript
- Language: TypeScript
- Homepage:
- Size: 313 KB
- Stars: 4
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# yoi18n
> [!WARNING]
> This package is still a work in progress.
[![GitHub Workflow Status](https://img.shields.io/github/actions/workflow/status/fzn0x/yoi18n/ci.yml?branch=main)](https://github.com/fzn0x/yoi18n/actions)
[![GitHub](https://img.shields.io/github/license/fzn0x/yoi18n)](https://github.com/fzn0x/yoi18n/blob/main/LICENSE)
[![npm](https://img.shields.io/npm/v/yoi18n)](https://www.npmjs.com/package/yoi18n)
[![npm](https://img.shields.io/npm/dm/yoi18n)](https://www.npmjs.com/package/yoi18n)
[![JSR](https://jsr.io/badges/@fzn0x/yoi18n)](https://jsr.io/@fzn0x/yoi18n)
[![Bundle Size](https://img.shields.io/bundlephobia/min/yoi18n)](https://bundlephobia.com/result?p=yoi18n)
[![Bundle Size](https://img.shields.io/bundlephobia/minzip/yoi18n)](https://bundlephobia.com/result?p=yoi18n)
[![GitHub commit activity](https://img.shields.io/github/commit-activity/m/fzn0x/yoi18n)](https://github.com/fzn0x/yoi18n/pulse)
[![GitHub last commit](https://img.shields.io/github/last-commit/fzn0x/yoi18n)](https://github.com/fzn0x/yoi18n/commits/main)
⚡Straightforward & less effort React i18n library.
## Get to Know
- [Installation](#installation)
- [Usage](#usage)
- [JavaScript](#javascript)
- [TypeScript](#typescript)
- [React](#react)
- [License](#license)## Installation
```bash
bun install yoi18n
npm install yoi18n
yarn add yoi18n
pnpm install yoi18n
```## Usage
Creates `lang.json` and `lang-admin.json` files:
**`lang.json` :**
```json
{
"en": {
"hello": "hello world"
},
"de": {
"hello": "Guten Morgen"
},
"id": {
"hello": "Hallo bang"
}
}
```**`lang-admin.json` :**
```json
{
"en": {
"hello": "hello world from admin"
},
"de": {
"hello": "Guten Morgen from admin"
},
"id": {
"hello": "Hallo bang from admin"
}
}
```### JavaScript
```js
// lang.js
const i18n = require('yoi18n')const t = i18n.init({
namespace: {
default: {
// user pages
load: `/lang.json`,
defaultLang: 'en',
},
admin: {
// admin pages
load: `/lang-admin.json`,
defaultLang: 'en',
},
},
detection: {
order: ['cookie', 'path', 'query'], // use defaultLang if not found
defaultLang: 'en',
},
})console.log(t('hello')) // "hello" from default namespace
console.log(t('admin.hello')) // "hello" from admin namespace,// You can export for reusability
// module.exports = t;
```### TypeScript
```js
// lang.ts
import i18n from 'yoi18n'const t = i18n.init({
namespace: {
default: {
// user pages
load: `/lang.json`,
defaultLang: 'en',
},
admin: {
// admin pages
load: `/lang-admin.json`,
defaultLang: 'en',
},
},
detection: {
order: ['cookie', 'path', 'query'], // use defaultLang if not found
defaultLang: 'en',
},
})console.log(t('hello')) // "hello" from default namespace
console.log(t('admin.hello')) // "hello" from admin namespace,// You can export for reusability
// export default t;
```### React
```jsx
import i18n from 'yoi18n'const t = i18n.init({
namespace: {
default: {
// user pages
load: `/lang.json`,
defaultLang: 'en',
},
admin: {
// admin pages
load: `/lang-admin.json`,
defaultLang: 'en',
},
},
detection: {
order: ['cookie', 'path', 'query'], // use defaultLang if not found
defaultLang: 'en',
},
})// Creates a function LanguageSwitch to change defaultLang
export default function LanguageSwitch({ lang, ns }) {
// t.switch is to change the defaultLang
returnt.switch(lang, ns)}>Switch Language for {ns}
};
;
```## License
yoi18n is [MIT Licensed](./LICENSE) and Open Source Software by [@fzn0x](https://github.com/fzn0x)