Mohammad Asif cf937194cb Removed un-waned things 1. 5 months atrás
..
.github cf937194cb Removed un-waned things 1. 5 months atrás
docs cf937194cb Removed un-waned things 1. 5 months atrás
lib cf937194cb Removed un-waned things 1. 5 months atrás
tests cf937194cb Removed un-waned things 1. 5 months atrás
CHANGELOG.md cf937194cb Removed un-waned things 1. 5 months atrás
LICENSE cf937194cb Removed un-waned things 1. 5 months atrás
README.md cf937194cb Removed un-waned things 1. 5 months atrás
commitlint.config.js cf937194cb Removed un-waned things 1. 5 months atrás
package.json cf937194cb Removed un-waned things 1. 5 months atrás
v5.md cf937194cb Removed un-waned things 1. 5 months atrás

README.md

eslint-plugin-i18next

ESLint plugin for i18n

For old versions below v6, plz refer this document

Installation

npm install eslint-plugin-i18next --save-dev

Usage

Add i18next to the plugins section of your .eslintrc configuration file.

{
  "plugins": ["i18next"]
}

Then configure the rules you want to use under the rules section.

{
  "rules": {
    "i18next/no-literal-string": 2
  }
}

or

{
  "extends": ["plugin:i18next/recommended"]
}

Rule no-literal-string

This rule aims to avoid developers to display literal string directly to users without translating them.

Note: Disable auto-fix because key in the call i18next.t(key) usually was not the same as the literal

Example of incorrect code:

/*eslint i18next/no-literal-string: "error"*/
<div>hello world</div>

Example of correct code:

/*eslint i18next/no-literal-string: "error"*/
<div>{i18next.t('HELLO_KEY')}</div>

More options can be found here

Breaking change

By default, it will only validate the plain text in JSX markup instead of all literal strings in previous versions. You can change it easily