ESLint plugin with rules for moment.js to ensure consistent and error-free code when working with dates and times.
- Prevents usage of moment's default constructor function and other literals for moment variable declarations except
moment
. - Enhances code quality by enforcing best practices when working with moment.js.
Before using eslint-plugin-moment
, make sure you have ESLint installed:
$ npm install eslint --save-dev
Now, install eslint-plugin-moment
:
$ npm install eslint-plugin-moment --save-dev
Add moment
to the plugins section of your .eslintrc
configuration file. You can omit the eslint-plugin-
prefix:
{
"plugins": [
"moment"
]
}
Then configure the rules you want to use under the rules section.
{
"rules": {
"moment/moment-parse-options": 2
}
}
- moment-parse-options
Prevents use default moment constructor function and variable declaration with any other literal except moment
Examples of incorrect code for this rule:
const literal = require("moment");
import literal from 'moment';
import * as literal from 'moment';
moment();
moment("19/09/2020");
Examples of correct code for this rule:
const moment = require("moment");
import moment from 'moment';
import * as moment from 'moment';
// UTC
moment.utc();
moment.utc("19/09/2020");
// TimeZone
moment.tz();
moment.tz("19/09/2020", "Europe/Kiev");
We welcome contributions! If you find a bug or have a suggestion, please open an issue or create a pull request.
This project is licensed under the MIT License - see the LICENSE.md file for details.