-
Notifications
You must be signed in to change notification settings - Fork 0
/
index.js
116 lines (103 loc) · 2.81 KB
/
index.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
import js from "@eslint/js";
import prettier from "eslint-config-prettier";
import importPlugin from "eslint-plugin-import";
import jsdoc from "eslint-plugin-jsdoc";
import markdown from "eslint-plugin-markdown";
import globals from "globals";
import neostandard, { plugins } from "neostandard";
export default [
{
plugins: {
import: importPlugin,
jsdoc,
markdown,
},
},
...neostandard({ noStyle: true }),
prettier,
...markdown.configs.recommended,
{
ignores: [
"**/.cache/**",
"**/dist/**",
"**/vendor/**",
// Lint dot files
"!.*",
"node_modules",
"node_modules/.*",
// Prevent CHANGELOG history changes
"CHANGELOG.md",
],
},
{
...js.configs.recommended,
...importPlugin.flatConfigs.recommended,
...jsdoc.configs["flat/recommended"],
...plugins.n.configs["flat/recommended"],
...plugins.promise.configs["flat/recommended"],
files: [
"**/*.{cjs,js,mjs}",
// Check markdown `*.md` contains valid code blocks
// https://github.com/eslint/eslint-plugin-markdown#advanced-configuration
"**/*.md/*.{cjs,js,mjs}",
],
languageOptions: {
globals: {
...globals.browser,
},
parserOptions: {
ecmaVersion: "latest",
},
},
rules: {
// Check import or require statements are A-Z ordered
"import/order": [
"error",
{
alphabetize: { order: "asc" },
"newlines-between": "always",
},
],
// Check for valid formatting
"jsdoc/check-line-alignment": [
"warn",
"never",
{
wrapIndent: " ",
},
],
// JSDoc blocks can use `@preserve` to prevent removal
"jsdoc/check-tag-names": [
"warn",
{
definedTags: ["preserve"],
},
],
// JSDoc blocks are optional by default
"jsdoc/require-jsdoc": "off",
// JSDoc @param required in (optional) blocks but
// @param description is not necessary by default
"jsdoc/require-param-description": "off",
"jsdoc/require-param": "error",
// Require hyphens before param description
// Aligns with TSDoc style: https://tsdoc.org/pages/tags/param/
"jsdoc/require-hyphen-before-param-description": "warn",
// Maintain new line after description
"jsdoc/tag-lines": [
"warn",
"never",
{
startLines: 1,
},
],
// Automatically use template strings
"no-useless-concat": "error",
"prefer-template": "error",
// Avoid continue and else blocks after return statements in if statements
"no-continue": "error",
"no-else-return": "error",
// Avoid hard to read multi assign statements
"no-multi-assign": "error",
},
},
];