Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/luckyforce/easylang
A lightweight JavaScript/TypeScript language library to easily scale and manage multilingual websites.
https://github.com/luckyforce/easylang
javascript javascript-library language multilingual-websites typescript typescript-library
Last synced: 10 days ago
JSON representation
A lightweight JavaScript/TypeScript language library to easily scale and manage multilingual websites.
- Host: GitHub
- URL: https://github.com/luckyforce/easylang
- Owner: LuckyForce
- License: gpl-3.0
- Created: 2022-04-12T19:22:53.000Z (over 2 years ago)
- Default Branch: main
- Last Pushed: 2022-04-12T22:21:29.000Z (over 2 years ago)
- Last Synced: 2023-10-09T10:49:43.863Z (about 1 year ago)
- Topics: javascript, javascript-library, language, multilingual-websites, typescript, typescript-library
- Language: JavaScript
- Homepage:
- Size: 24.4 KB
- Stars: 5
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# EasyLang
A lightweight JavaScript/TypeScript language library to easily scale and manage multilingual websites.## Setup
All you need is to copy the file EasyLang.js or EasyLang.ts to your project and import it.TypeScript:
```ts
//Import
import { EasyLang } from './EasyLang.ts';
//Create Instance
const lang = new EasyLang();
```
JavaScript:
```js
//Import
import { EasyLang } from './EasyLang.js';
//Create Instance
const lang = new EasyLang();
```To make EasyLang work, you need to provide a language file in form of JSON. You can edit the path to the file in the file EasyLang.js or EasyLang.ts by changing the path of the import. Change PATH_NAME to the path of your language file.
```js
import json from 'PATH_NAME' assert {type: 'json'};
```The language file has to be build like the following:
```json
{
"default": "en",
"HelloWorld": {
"en": "Hello World",
"de": "Hallo Welt",
"es": "Hola Mundo"
}
}
```
The "default" key is the default language. This language will be used if no language or translation is provided. If the language is not available, the default language will be used. If the default language is not available and the other language is not available, it will return null.Phrases can be defined in the following way:
```json
{
"HelloWorld": {
"en": "Hello World",
"de": "Hallo Welt",
"es": "Hola Mundo"
}
}
```
"HelloWorld" is the key of the phrase. The value is an object with the languages as keys and the translation as value. If the phrase is not defined in the language file, it will return null.## Usage
To now use EasyLang you just need to call the method get() with the key of the phrase and the language.Example with the following language file:
```json
{
"default": "en",
"HelloWorld": {
"en": "Hello World",
"de": "Hallo Welt",
"es": "Hola Mundo"
}
}
``````js
//Import
import { EasyLang } from './EasyLang.js';
//Create Instance
const lang = new EasyLang();
//Get Phrase
lang.get('HelloWorld', 'en'); // Hello World
lang.get('HelloWorld', 'de'); // Hallo Welt
lang.get('HelloWorld', 'es'); // Hola Mundo
lang.get('HelloWorld', 'fr'); // Hello World (default language)
lang.get('HelloWorld'); // Hello World (default language)
```