ESLINT-PLUGIN-OKTA
This package contains Okta's custom ESlint rules.
Table of Contents
Configuration
This plugin provides a sharable configuration that can be extended in any UI project.
To use this preset, add the following to your configuration file:
module.exports = {
extends: [
'plugin:@okta/okta/recommended',
'plugin:@okta/okta/courage-app',
],
}
Extending an existing config with this sharable configuration will result in all *.properties
and *.js
files in your project to be checked. To apply rules specifically to *.js
files, utilize the overrides
entry to separate these rules:
module.exports = {
extends: [
'plugin:@okta/okta/recommended',
],
overrides: [
{
files: ['*.js'],
rules: [
'max-len': ['error', { code: 120 }],
]
},
]
}
Rules
Processors
Processors | Description |
---|
properties | Parse properties files as JavaScript |
Writing a new rule
Custom rules follow the standard ESLint guidelines - check out their Working with Rules page for a good primer. When writing rules, you'll often need to find the right Selector to match the nodes you want to test against - a useful tool for finding these is the AST Explorer.
Once you've got the basics down, create these 3 files. When coming up with a rule name, follow the Rule Naming Conventions, and check out ESLint's list of rules for examples of good rule names.
-
lib/rules/${your-rule}.js
This is the rule definition. If it's possible, add a fix function to the rule.
-
lib/rules/${your-rule}.test.js
This is the test file. We use ESLint's RuleTester, which makes this extra easy.
-
docs/rules/${your-rule}.md
This is the documentation for your rule. Check out the existing docs, or brows through ESLint's own rule docs for good examples of what you should write.
As you're writing your rule, you can run the tests with yarn:
yarn test