Security News
Fluent Assertions Faces Backlash After Abandoning Open Source Licensing
Fluent Assertions is facing backlash after dropping the Apache license for a commercial model, leaving users blindsided and questioning contributor rights.
A very tiny library to translate your application based on its DOM with ease.
A tiny, modular, dependency-free library to translate your web application on demand using the DOM as reference.
npm install linguistic
Or you can use a script from the build/
folder.
Note: linguistic.js is compatible with CommonJS, AMD or window invokation.
linguistic is designed based on modularity thinking. It is unobtrusive and let you decide what convention you want to follow.
That being said, its flow is basically divided in four fragments, which are:
Maybe you're scared, huh? But don't be — it's easier than you think. See the following example:
var linguistic = require ('linguistic');
var pt = {
'h1': 'Olá, mundo!',
'h3': 'Como você está?'
};
var en = {
'h1': 'Hello, world!',
'h3': 'How do you do?'
};
var dictionaries = {
'pt-BR': pt,
'en-US': en
};
linguistic.handle(dictionaries).translate();
Looking deeper:
pt
is a dictionary
for portuguese language (JavaScript object);en
is a dictionary
for english language (JavaScript object);dictionaries
is a dictionary
of languages (JavaScript object);This will work based on a HTML like this:
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Linguisticjs Markup Demonstration</title>
</head>
<body>
<h1>Bonjour le monde !</h1>
<h3>Comment ça va ?</h3>
</body>
</html>
pt-BR
or en-US
?Under the hood, it uses navigator.language
as its first criteria. In other words, it is primarily based on client's browser language. If you want to apply your own logic to handle the language that linguistic.js must to consider, feel free to do it through .interpret()
method, such as:
linguistic
.interpret('pt-BR')
.handle(dictionaries)
.translate();
Of course, the example above is flat and probably you won't apply it — but you can, for instance, make something sharper depending of your need, like extracting the locale from URL. Learn more further.
Having this markup as example:
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Linguisticjs Markup Demonstration</title>
</head>
<body>
<h1>Bonjour le <span class="target"></span> !</h1>
<h3>Comment ça va ?</h3>
</body>
</html>
We can do:
var linguistic = require ('linguistic');
var names = [];
function getRandom (matrix) {
return matrix[Math.floor(Math.random() * matrix.length)];
};
var en = {
'h1 span.target': function () {
names = ['world', 'ninja'];
return 'Hello, ' + getRandom(names) + '!';
},
'h3': 'How do you do?'
};
var pt = {
'h1 span.target': function () {
names = ['mundo', 'ninja'];
return 'Olá, ' + getRandom(names) + '!';
},
'h3': 'Como você está?'
};
var dictionaries = {
'en-US': en,
'pt-BR': pt
};
linguistic.handle(dictionaries).translate();
You see? It's possible to use any element you want to get its string translated, also you are not limited to use only strings in the values of your dictionaries — functions are here to make all the logic you need and/or want.
There are two ways to work with pluralisations. The easy way:
var en = {
'.followers': [
5,
'No followers',
'One follower',
'%s followers'
]
};
Yes, simple as that: an array with four spaces!
Or, if you want to implement your own logic:
var en = {
'.followers': function () {
var value = 5;
if (value === 0) {
return 'Nobody likes you. No followers.';
};
if (value === 1) {
return 'One follower';
};
if (value > 1) {
return value + ' followers';
};
if (value === 5) {
return '5ive followers';
};
}
};
void
Applies a dictionary against the language the client is requesting.
linguistic.translate();
Wether the element doesn't exist in your markup, linguistic will leave it untouchable. In other words, with its default value.
Note: translate
method depends of a handled dictionary. See the next topic.
void
It handles a compatible dictionary based on the client's language — which can be pre-defined through .interpret()
or assuming the default criteria, that is navigator.language
property.
linguistic.handle(dictionaries);
string
Get the language linguistic is assuming to use.
linguistic.clientLanguage;
void
Handle the language client is using.
linguistic.handleLanguage();
void
It creates a usefulDictionary
that is the one to be currently used based on your client's need.
linguistic.setUsefulDictionary(dictionary);
object
It is the property storing the dictionary in use. Basically, this is the chosen one to be applied into your client's interface based on his language.
linguistic.usefulDictionary;
string
It retrieves a specific translation based on a specified parameter.
linguistic.getTranslation('h1');
string
It will check for the very first value of its parameter (which is supposed to be an array) using isSingular()
or isPlural()
methods to determine wether string it should to return: [1] for emptiness; [2] for singular; [3] for plural.
var matrix = [
5,
'No followers',
'1 follower',
'%s followers'
];
linguistic.parsePluralisation(matrix); // returns '5 followers'
Note: %s
is the same thing (value) of the first ([0]
) position of your matrix. Only available to use in the fourth ([3]
) position.
boolean
Check wether a number is or isn't singular. 1
is singular and 0
returns false
.
linguistic.isSingular(1); // returns true
boolean
Check wether a number is or isn't plural. > 1
is plural and everything else returns false
.
linguistic.isPlural(3); // returns true
Making a decoupled application is a goal that lots of developers has nowadays. Linguistic.js has born with an optimistic purpose: make the way you translate your application more modular and decoupled — keeping in the front-end what belongs to it.
As you can see, it is minimalistic and very easy to inject into your architecture, no matter if you are using Backbone, Ember, Angular or Vanilla JavaScript — you can go seamlessly.
Translating what your client sees isn't responsibility of the back end. Hence, everything people sees in a web application belongs to elements: <h1>
s, <p>
s, <div>
s, etc. So, why can't we use the DOM in our favor?
You can distribute your translations via an API, consume them via JavaScript and finally inject them into dictionaries to be rendered painlessly — all the hardwork belongs to linguistic and nobody else. Please, keep your focus on creating your HTML and translations — all other efforts are linguistic's!
If you want to improve linguistic in any way, please read our CONTRIBUTING.md document.
To make the tests, we are using Facebook's Jest. To proceed, please clone:
git clone git@github.com:chiefGui/linguistic.js.git && cd linguistic.js
Then
npm install && npm test
And you're good to go! :-)
MIT © 2015
FAQs
A very tiny library to translate your application based on its DOM with ease.
The npm package linguistic receives a total of 4 weekly downloads. As such, linguistic popularity was classified as not popular.
We found that linguistic demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 1 open source maintainer collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
Fluent Assertions is facing backlash after dropping the Apache license for a commercial model, leaving users blindsided and questioning contributor rights.
Research
Security News
Socket researchers uncover the risks of a malicious Python package targeting Discord developers.
Security News
The UK is proposing a bold ban on ransomware payments by public entities to disrupt cybercrime, protect critical services, and lead global cybersecurity efforts.