eslint-plugin-nima 1.2.4 → 1.2.6
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +18 -18
- package/dist/constants/boolean-prefixes.js.map +1 -1
- package/dist/constants/consoles.js.map +1 -1
- package/dist/constants/hooks.js.map +1 -1
- package/dist/index.d.ts +25 -24
- package/dist/index.js +13 -57
- package/dist/index.js.map +1 -1
- package/dist/{models/boolean-naming-convention.model.d.ts → rules/boolean-naming-convention/config.d.ts} +11 -0
- package/dist/rules/boolean-naming-convention/config.js +70 -0
- package/dist/rules/boolean-naming-convention/config.js.map +1 -0
- package/dist/rules/boolean-naming-convention/create.d.ts +11 -0
- package/dist/rules/boolean-naming-convention/create.js +415 -0
- package/dist/rules/boolean-naming-convention/create.js.map +1 -0
- package/dist/rules/boolean-naming-convention/index.d.ts +2 -0
- package/dist/rules/boolean-naming-convention/index.js +22 -0
- package/dist/rules/boolean-naming-convention/index.js.map +1 -0
- package/dist/rules/{restrict-imports.d.ts → boolean-naming-convention/rule.d.ts} +2 -2
- package/dist/rules/boolean-naming-convention/rule.js +14 -0
- package/dist/rules/boolean-naming-convention/rule.js.map +1 -0
- package/dist/rules/index.d.ts +12 -0
- package/dist/rules/index.js +49 -0
- package/dist/rules/index.js.map +1 -0
- package/dist/rules/no-handler-suffix/config.d.ts +14 -0
- package/dist/rules/no-handler-suffix/config.js +23 -0
- package/dist/rules/no-handler-suffix/config.js.map +1 -0
- package/dist/rules/no-handler-suffix/create.d.ts +8 -0
- package/dist/rules/no-handler-suffix/create.js +71 -0
- package/dist/rules/no-handler-suffix/create.js.map +1 -0
- package/dist/rules/no-handler-suffix/index.d.ts +2 -0
- package/dist/rules/no-handler-suffix/index.js +22 -0
- package/dist/rules/no-handler-suffix/index.js.map +1 -0
- package/dist/rules/{no-handler-suffix.d.ts → no-handler-suffix/rule.d.ts} +2 -2
- package/dist/rules/no-handler-suffix/rule.js +14 -0
- package/dist/rules/no-handler-suffix/rule.js.map +1 -0
- package/dist/rules/no-objects-in-deps/config.d.ts +14 -0
- package/dist/rules/no-objects-in-deps/config.js +22 -0
- package/dist/rules/no-objects-in-deps/config.js.map +1 -0
- package/dist/rules/no-objects-in-deps/create.d.ts +6 -0
- package/dist/rules/no-objects-in-deps/create.js +124 -0
- package/dist/rules/no-objects-in-deps/create.js.map +1 -0
- package/dist/rules/no-objects-in-deps/index.d.ts +2 -0
- package/dist/rules/no-objects-in-deps/index.js +22 -0
- package/dist/rules/no-objects-in-deps/index.js.map +1 -0
- package/dist/rules/{no-objects-in-deps.d.ts → no-objects-in-deps/rule.d.ts} +2 -2
- package/dist/rules/no-objects-in-deps/rule.js +14 -0
- package/dist/rules/no-objects-in-deps/rule.js.map +1 -0
- package/dist/rules/params-naming-convention/config.d.ts +21 -0
- package/dist/rules/params-naming-convention/config.js +55 -0
- package/dist/rules/params-naming-convention/config.js.map +1 -0
- package/dist/rules/params-naming-convention/create.d.ts +6 -0
- package/dist/rules/params-naming-convention/create.js +49 -0
- package/dist/rules/params-naming-convention/create.js.map +1 -0
- package/dist/rules/params-naming-convention/index.d.ts +2 -0
- package/dist/rules/params-naming-convention/index.js +22 -0
- package/dist/rules/params-naming-convention/index.js.map +1 -0
- package/dist/rules/{prefer-react-fc.d.ts → params-naming-convention/rule.d.ts} +2 -2
- package/dist/rules/params-naming-convention/rule.js +14 -0
- package/dist/rules/params-naming-convention/rule.js.map +1 -0
- package/dist/{models/prefer-arrow-functions.model.d.ts → rules/prefer-arrow-functions/config.d.ts} +10 -0
- package/dist/rules/prefer-arrow-functions/config.js +67 -0
- package/dist/rules/prefer-arrow-functions/config.js.map +1 -0
- package/dist/rules/prefer-arrow-functions/create.d.ts +9 -0
- package/dist/rules/prefer-arrow-functions/create.js +150 -0
- package/dist/rules/prefer-arrow-functions/create.js.map +1 -0
- package/dist/rules/prefer-arrow-functions/index.d.ts +2 -0
- package/dist/rules/prefer-arrow-functions/index.js +22 -0
- package/dist/rules/prefer-arrow-functions/index.js.map +1 -0
- package/dist/rules/{restrict-function-usage.d.ts → prefer-arrow-functions/rule.d.ts} +2 -2
- package/dist/rules/prefer-arrow-functions/rule.js +14 -0
- package/dist/rules/prefer-arrow-functions/rule.js.map +1 -0
- package/dist/rules/prefer-export-under-component/config.d.ts +14 -0
- package/dist/rules/prefer-export-under-component/config.js +23 -0
- package/dist/rules/prefer-export-under-component/config.js.map +1 -0
- package/dist/rules/prefer-export-under-component/create.d.ts +8 -0
- package/dist/rules/prefer-export-under-component/create.js +99 -0
- package/dist/rules/prefer-export-under-component/create.js.map +1 -0
- package/dist/rules/prefer-export-under-component/index.d.ts +2 -0
- package/dist/rules/prefer-export-under-component/index.js +22 -0
- package/dist/rules/prefer-export-under-component/index.js.map +1 -0
- package/dist/rules/{prefer-react-with-hooks.d.ts → prefer-export-under-component/rule.d.ts} +2 -2
- package/dist/rules/prefer-export-under-component/rule.js +14 -0
- package/dist/rules/prefer-export-under-component/rule.js.map +1 -0
- package/dist/rules/prefer-react-fc/config.d.ts +19 -0
- package/dist/rules/prefer-react-fc/config.js +43 -0
- package/dist/rules/prefer-react-fc/config.js.map +1 -0
- package/dist/rules/prefer-react-fc/create.d.ts +8 -0
- package/dist/rules/prefer-react-fc/create.js +166 -0
- package/dist/rules/prefer-react-fc/create.js.map +1 -0
- package/dist/rules/prefer-react-fc/index.d.ts +2 -0
- package/dist/rules/prefer-react-fc/index.js +22 -0
- package/dist/rules/prefer-react-fc/index.js.map +1 -0
- package/dist/rules/{prefer-arrow-functions.d.ts → prefer-react-fc/rule.d.ts} +2 -2
- package/dist/rules/prefer-react-fc/rule.js +14 -0
- package/dist/rules/prefer-react-fc/rule.js.map +1 -0
- package/dist/rules/prefer-react-with-hooks/config.d.ts +15 -0
- package/dist/rules/prefer-react-with-hooks/config.js +25 -0
- package/dist/rules/prefer-react-with-hooks/config.js.map +1 -0
- package/dist/rules/prefer-react-with-hooks/create.d.ts +7 -0
- package/dist/rules/prefer-react-with-hooks/create.js +188 -0
- package/dist/rules/prefer-react-with-hooks/create.js.map +1 -0
- package/dist/rules/prefer-react-with-hooks/index.d.ts +2 -0
- package/dist/rules/prefer-react-with-hooks/index.js +22 -0
- package/dist/rules/prefer-react-with-hooks/index.js.map +1 -0
- package/dist/rules/{prefer-export-under-component.d.ts → prefer-react-with-hooks/rule.d.ts} +2 -2
- package/dist/rules/prefer-react-with-hooks/rule.js +14 -0
- package/dist/rules/prefer-react-with-hooks/rule.js.map +1 -0
- package/dist/rules/prefer-void-for-optional-param/config.d.ts +15 -0
- package/dist/rules/prefer-void-for-optional-param/config.js +25 -0
- package/dist/rules/prefer-void-for-optional-param/config.js.map +1 -0
- package/dist/rules/prefer-void-for-optional-param/create.d.ts +8 -0
- package/dist/rules/prefer-void-for-optional-param/create.js +188 -0
- package/dist/rules/prefer-void-for-optional-param/create.js.map +1 -0
- package/dist/rules/prefer-void-for-optional-param/index.d.ts +2 -0
- package/dist/rules/prefer-void-for-optional-param/index.js +22 -0
- package/dist/rules/prefer-void-for-optional-param/index.js.map +1 -0
- package/dist/rules/prefer-void-for-optional-param/rule.d.ts +5 -0
- package/dist/rules/prefer-void-for-optional-param/rule.js +14 -0
- package/dist/rules/prefer-void-for-optional-param/rule.js.map +1 -0
- package/dist/rules/restrict-console-methods/config.d.ts +18 -0
- package/dist/rules/restrict-console-methods/config.js +38 -0
- package/dist/rules/restrict-console-methods/config.js.map +1 -0
- package/dist/rules/restrict-console-methods/create.d.ts +6 -0
- package/dist/rules/restrict-console-methods/create.js +34 -0
- package/dist/rules/restrict-console-methods/create.js.map +1 -0
- package/dist/rules/restrict-console-methods/index.d.ts +2 -0
- package/dist/rules/restrict-console-methods/index.js +22 -0
- package/dist/rules/restrict-console-methods/index.js.map +1 -0
- package/dist/rules/restrict-console-methods/rule.d.ts +5 -0
- package/dist/rules/restrict-console-methods/rule.js +14 -0
- package/dist/rules/restrict-console-methods/rule.js.map +1 -0
- package/dist/rules/restrict-function-usage/config.d.ts +21 -0
- package/dist/rules/restrict-function-usage/config.js +62 -0
- package/dist/rules/restrict-function-usage/config.js.map +1 -0
- package/dist/rules/restrict-function-usage/create.d.ts +6 -0
- package/dist/rules/restrict-function-usage/create.js +76 -0
- package/dist/rules/restrict-function-usage/create.js.map +1 -0
- package/dist/rules/restrict-function-usage/index.d.ts +2 -0
- package/dist/rules/restrict-function-usage/index.js +22 -0
- package/dist/rules/restrict-function-usage/index.js.map +1 -0
- package/dist/rules/restrict-function-usage/rule.d.ts +5 -0
- package/dist/rules/restrict-function-usage/rule.js +14 -0
- package/dist/rules/restrict-function-usage/rule.js.map +1 -0
- package/dist/rules/restrict-imports/config.d.ts +22 -0
- package/dist/rules/restrict-imports/config.js +69 -0
- package/dist/rules/restrict-imports/config.js.map +1 -0
- package/dist/rules/restrict-imports/create.d.ts +6 -0
- package/dist/rules/restrict-imports/create.js +92 -0
- package/dist/rules/restrict-imports/create.js.map +1 -0
- package/dist/rules/restrict-imports/index.d.ts +2 -0
- package/dist/rules/restrict-imports/index.js +22 -0
- package/dist/rules/restrict-imports/index.js.map +1 -0
- package/dist/rules/restrict-imports/rule.d.ts +5 -0
- package/dist/rules/restrict-imports/rule.js +14 -0
- package/dist/rules/restrict-imports/rule.js.map +1 -0
- package/dist/utility/core.js.map +1 -1
- package/dist/utility/file-helpers.d.ts +6 -0
- package/dist/utility/file-helpers.js +32 -0
- package/dist/utility/file-helpers.js.map +1 -0
- package/dist/utility/function-helpers.d.ts +4 -4
- package/dist/utility/function-helpers.js +17 -15
- package/dist/utility/function-helpers.js.map +1 -1
- package/dist/utility/type-helpers.d.ts +4 -1
- package/dist/utility/type-helpers.js +6 -4
- package/dist/utility/type-helpers.js.map +1 -1
- package/package.json +75 -73
- package/dist/models/boolean-naming-convention.model.js +0 -11
- package/dist/models/boolean-naming-convention.model.js.map +0 -1
- package/dist/models/no-handler-suffix.model.d.ts +0 -4
- package/dist/models/no-handler-suffix.model.js +0 -8
- package/dist/models/no-handler-suffix.model.js.map +0 -1
- package/dist/models/no-objects-in-deps.model.d.ts +0 -4
- package/dist/models/no-objects-in-deps.model.js +0 -8
- package/dist/models/no-objects-in-deps.model.js.map +0 -1
- package/dist/models/params-naming-convention.model.d.ts +0 -11
- package/dist/models/params-naming-convention.model.js +0 -8
- package/dist/models/params-naming-convention.model.js.map +0 -1
- package/dist/models/prefer-arrow-functions.model.js +0 -10
- package/dist/models/prefer-arrow-functions.model.js.map +0 -1
- package/dist/models/prefer-export-under-component.model.d.ts +0 -4
- package/dist/models/prefer-export-under-component.model.js +0 -8
- package/dist/models/prefer-export-under-component.model.js.map +0 -1
- package/dist/models/prefer-react-fc.model.d.ts +0 -9
- package/dist/models/prefer-react-fc.model.js +0 -8
- package/dist/models/prefer-react-fc.model.js.map +0 -1
- package/dist/models/prefer-react-with-hooks.model.d.ts +0 -5
- package/dist/models/prefer-react-with-hooks.model.js +0 -9
- package/dist/models/prefer-react-with-hooks.model.js.map +0 -1
- package/dist/models/prefer-void-for-optional-param.model.d.ts +0 -5
- package/dist/models/prefer-void-for-optional-param.model.js +0 -9
- package/dist/models/prefer-void-for-optional-param.model.js.map +0 -1
- package/dist/models/restrict-console-methods.model.d.ts +0 -8
- package/dist/models/restrict-console-methods.model.js +0 -8
- package/dist/models/restrict-console-methods.model.js.map +0 -1
- package/dist/models/restrict-function-usage.model.d.ts +0 -11
- package/dist/models/restrict-function-usage.model.js +0 -8
- package/dist/models/restrict-function-usage.model.js.map +0 -1
- package/dist/models/restrict-imports.model.d.ts +0 -12
- package/dist/models/restrict-imports.model.js +0 -8
- package/dist/models/restrict-imports.model.js.map +0 -1
- package/dist/rules/boolean-naming-convention.d.ts +0 -5
- package/dist/rules/boolean-naming-convention.js +0 -379
- package/dist/rules/boolean-naming-convention.js.map +0 -1
- package/dist/rules/no-handler-suffix.js +0 -89
- package/dist/rules/no-handler-suffix.js.map +0 -1
- package/dist/rules/no-objects-in-deps.js +0 -90
- package/dist/rules/no-objects-in-deps.js.map +0 -1
- package/dist/rules/params-naming-convention.d.ts +0 -5
- package/dist/rules/params-naming-convention.js +0 -95
- package/dist/rules/params-naming-convention.js.map +0 -1
- package/dist/rules/prefer-arrow-functions.js +0 -208
- package/dist/rules/prefer-arrow-functions.js.map +0 -1
- package/dist/rules/prefer-export-under-component.js +0 -113
- package/dist/rules/prefer-export-under-component.js.map +0 -1
- package/dist/rules/prefer-react-fc.js +0 -204
- package/dist/rules/prefer-react-fc.js.map +0 -1
- package/dist/rules/prefer-react-with-hooks.js +0 -185
- package/dist/rules/prefer-react-with-hooks.js.map +0 -1
- package/dist/rules/prefer-void-for-optional-param.d.ts +0 -6
- package/dist/rules/prefer-void-for-optional-param.js +0 -188
- package/dist/rules/prefer-void-for-optional-param.js.map +0 -1
- package/dist/rules/restrict-console-methods.d.ts +0 -5
- package/dist/rules/restrict-console-methods.js +0 -66
- package/dist/rules/restrict-console-methods.js.map +0 -1
- package/dist/rules/restrict-function-usage.js +0 -121
- package/dist/rules/restrict-function-usage.js.map +0 -1
- package/dist/rules/restrict-imports.js +0 -135
- package/dist/rules/restrict-imports.js.map +0 -1
|
@@ -1,379 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.rule = exports.name = void 0;
|
|
4
|
-
const boolean_prefixes_1 = require("../constants/boolean-prefixes");
|
|
5
|
-
const boolean_naming_convention_model_1 = require("../models/boolean-naming-convention.model");
|
|
6
|
-
const utils_1 = require("@typescript-eslint/utils");
|
|
7
|
-
const core_1 = require("../utility/core");
|
|
8
|
-
const type_helpers_1 = require("../utility/type-helpers");
|
|
9
|
-
exports.name = "boolean-naming-convention";
|
|
10
|
-
exports.rule = (0, core_1.createRule)({
|
|
11
|
-
create: (context, [options]) => {
|
|
12
|
-
const { allowedPrefixes = boolean_prefixes_1.DEFAULT_PREFIXES, checkFunctions = true, checkParameters = true, checkProperties = true, checkVariables = true, } = options;
|
|
13
|
-
const services = context.sourceCode.parserServices;
|
|
14
|
-
const checker = services?.program?.getTypeChecker();
|
|
15
|
-
function hasValidBooleanPrefix(name) {
|
|
16
|
-
return allowedPrefixes?.some((prefix) => name.toLowerCase().startsWith(prefix.toLowerCase()));
|
|
17
|
-
}
|
|
18
|
-
function generateSuggestion(name) {
|
|
19
|
-
return "is" + name.charAt(0).toUpperCase() + name.slice(1);
|
|
20
|
-
}
|
|
21
|
-
function isBooleanType(node) {
|
|
22
|
-
try {
|
|
23
|
-
const type = (0, type_helpers_1.getType)(context, node);
|
|
24
|
-
return type === "boolean" || type === "true" || type === "false";
|
|
25
|
-
}
|
|
26
|
-
catch {
|
|
27
|
-
return false;
|
|
28
|
-
}
|
|
29
|
-
}
|
|
30
|
-
const isParamBoolean = (node) => {
|
|
31
|
-
const reported = new Set();
|
|
32
|
-
for (const param of node.params) {
|
|
33
|
-
if (param.type === utils_1.AST_NODE_TYPES.Identifier &&
|
|
34
|
-
param.typeAnnotation?.typeAnnotation.type ===
|
|
35
|
-
utils_1.AST_NODE_TYPES.TSBooleanKeyword) {
|
|
36
|
-
checkNameOnce(param.name, param, reported);
|
|
37
|
-
}
|
|
38
|
-
if (param.type === utils_1.AST_NODE_TYPES.Identifier &&
|
|
39
|
-
param.typeAnnotation?.typeAnnotation.type ===
|
|
40
|
-
utils_1.AST_NODE_TYPES.TSTypeLiteral) {
|
|
41
|
-
for (const member of param.typeAnnotation.typeAnnotation.members) {
|
|
42
|
-
if (member.type === utils_1.AST_NODE_TYPES.TSPropertySignature &&
|
|
43
|
-
member.typeAnnotation?.typeAnnotation.type ===
|
|
44
|
-
utils_1.AST_NODE_TYPES.TSBooleanKeyword &&
|
|
45
|
-
member.key.type === utils_1.AST_NODE_TYPES.Identifier) {
|
|
46
|
-
checkNameOnce(member.key.name, member, reported);
|
|
47
|
-
}
|
|
48
|
-
}
|
|
49
|
-
}
|
|
50
|
-
if (param.type === utils_1.AST_NODE_TYPES.ObjectPattern) {
|
|
51
|
-
checkObjectPattern(param, param.typeAnnotation?.typeAnnotation, reported);
|
|
52
|
-
}
|
|
53
|
-
}
|
|
54
|
-
};
|
|
55
|
-
function checkObjectPattern(pattern, typeAnnotation, reported) {
|
|
56
|
-
for (const prop of pattern.properties) {
|
|
57
|
-
if (prop.type === utils_1.AST_NODE_TYPES.Property) {
|
|
58
|
-
const propKey = prop.key;
|
|
59
|
-
const propValue = prop.value;
|
|
60
|
-
if (propKey.type === utils_1.AST_NODE_TYPES.Identifier &&
|
|
61
|
-
propValue.type === utils_1.AST_NODE_TYPES.Identifier) {
|
|
62
|
-
const hasDirectAnnotation = propValue.typeAnnotation?.typeAnnotation.type ===
|
|
63
|
-
utils_1.AST_NODE_TYPES.TSBooleanKeyword;
|
|
64
|
-
if (hasDirectAnnotation) {
|
|
65
|
-
checkNameOnce(propKey.name, propKey, reported);
|
|
66
|
-
}
|
|
67
|
-
else if (typeAnnotation?.type === utils_1.AST_NODE_TYPES.TSTypeLiteral) {
|
|
68
|
-
for (const member of typeAnnotation.members) {
|
|
69
|
-
if (member.type === utils_1.AST_NODE_TYPES.TSPropertySignature &&
|
|
70
|
-
member.key.type === utils_1.AST_NODE_TYPES.Identifier &&
|
|
71
|
-
member.key.name === propKey.name &&
|
|
72
|
-
member.typeAnnotation?.typeAnnotation.type ===
|
|
73
|
-
utils_1.AST_NODE_TYPES.TSBooleanKeyword) {
|
|
74
|
-
checkNameOnce(propKey.name, propKey, reported);
|
|
75
|
-
break;
|
|
76
|
-
}
|
|
77
|
-
}
|
|
78
|
-
}
|
|
79
|
-
}
|
|
80
|
-
else if (propKey.type === utils_1.AST_NODE_TYPES.Identifier &&
|
|
81
|
-
propValue.type === utils_1.AST_NODE_TYPES.ObjectPattern) {
|
|
82
|
-
if (typeAnnotation?.type === utils_1.AST_NODE_TYPES.TSTypeLiteral) {
|
|
83
|
-
for (const member of typeAnnotation.members) {
|
|
84
|
-
if (member.type === utils_1.AST_NODE_TYPES.TSPropertySignature &&
|
|
85
|
-
member.key.type === utils_1.AST_NODE_TYPES.Identifier &&
|
|
86
|
-
member.key.name === propKey.name) {
|
|
87
|
-
checkObjectPattern(propValue, member.typeAnnotation?.typeAnnotation, reported);
|
|
88
|
-
break;
|
|
89
|
-
}
|
|
90
|
-
}
|
|
91
|
-
}
|
|
92
|
-
}
|
|
93
|
-
}
|
|
94
|
-
}
|
|
95
|
-
}
|
|
96
|
-
function checkNameOnce(name, node, reported) {
|
|
97
|
-
const key = `${name}-${node.loc.start.line}`;
|
|
98
|
-
if (reported && reported.has(key)) {
|
|
99
|
-
return;
|
|
100
|
-
}
|
|
101
|
-
if (!hasValidBooleanPrefix(name)) {
|
|
102
|
-
reported?.add(key);
|
|
103
|
-
context.report({
|
|
104
|
-
data: { name, suggestion: generateSuggestion(name) },
|
|
105
|
-
messageId: boolean_naming_convention_model_1.Messages.BAD_PARAMETER_BOOLEAN_PREFIX,
|
|
106
|
-
node,
|
|
107
|
-
});
|
|
108
|
-
}
|
|
109
|
-
}
|
|
110
|
-
function functionReturnsBooleanType(node) {
|
|
111
|
-
try {
|
|
112
|
-
const tsNode = services?.esTreeNodeToTSNodeMap?.get(node);
|
|
113
|
-
if (!tsNode)
|
|
114
|
-
return false;
|
|
115
|
-
const signature = checker?.getSignatureFromDeclaration(tsNode);
|
|
116
|
-
if (signature && checker) {
|
|
117
|
-
const returnType = checker.getReturnTypeOfSignature(signature);
|
|
118
|
-
const returnTypeString = checker.typeToString(returnType);
|
|
119
|
-
return (returnTypeString === "boolean" ||
|
|
120
|
-
returnTypeString === "true" ||
|
|
121
|
-
returnTypeString === "false");
|
|
122
|
-
}
|
|
123
|
-
return false;
|
|
124
|
-
}
|
|
125
|
-
catch {
|
|
126
|
-
return false;
|
|
127
|
-
}
|
|
128
|
-
}
|
|
129
|
-
return {
|
|
130
|
-
ArrowFunctionExpression(node) {
|
|
131
|
-
if (checkParameters) {
|
|
132
|
-
isParamBoolean(node);
|
|
133
|
-
}
|
|
134
|
-
},
|
|
135
|
-
FunctionDeclaration: (node) => {
|
|
136
|
-
if (!checkFunctions)
|
|
137
|
-
return;
|
|
138
|
-
if (node.id && functionReturnsBooleanType(node)) {
|
|
139
|
-
const name = node.id.name;
|
|
140
|
-
if (!hasValidBooleanPrefix(name)) {
|
|
141
|
-
context.report({
|
|
142
|
-
data: {
|
|
143
|
-
name,
|
|
144
|
-
suggestion: generateSuggestion(name),
|
|
145
|
-
},
|
|
146
|
-
messageId: boolean_naming_convention_model_1.Messages.BAD_FUNCTION_BOOLEAN_PREFIX,
|
|
147
|
-
node: node.id,
|
|
148
|
-
});
|
|
149
|
-
}
|
|
150
|
-
}
|
|
151
|
-
if (checkParameters) {
|
|
152
|
-
isParamBoolean(node);
|
|
153
|
-
}
|
|
154
|
-
},
|
|
155
|
-
FunctionExpression(node) {
|
|
156
|
-
if (checkParameters) {
|
|
157
|
-
isParamBoolean(node);
|
|
158
|
-
}
|
|
159
|
-
},
|
|
160
|
-
ObjectExpression: (node) => {
|
|
161
|
-
if (!checkProperties)
|
|
162
|
-
return;
|
|
163
|
-
for (const prop of node.properties) {
|
|
164
|
-
if (prop.type === utils_1.AST_NODE_TYPES.Property &&
|
|
165
|
-
prop.key.type === utils_1.AST_NODE_TYPES.Identifier &&
|
|
166
|
-
!prop.computed &&
|
|
167
|
-
prop.value) {
|
|
168
|
-
if (isBooleanType(prop.value) ||
|
|
169
|
-
((prop.value.type === utils_1.AST_NODE_TYPES.FunctionExpression ||
|
|
170
|
-
prop.value.type === utils_1.AST_NODE_TYPES.ArrowFunctionExpression) &&
|
|
171
|
-
functionReturnsBooleanType(prop.value))) {
|
|
172
|
-
const name = prop.key.name;
|
|
173
|
-
if (!hasValidBooleanPrefix(name)) {
|
|
174
|
-
context.report({
|
|
175
|
-
data: {
|
|
176
|
-
name,
|
|
177
|
-
suggestion: generateSuggestion(name),
|
|
178
|
-
},
|
|
179
|
-
messageId: boolean_naming_convention_model_1.Messages.BAD_PROPERTY_BOOLEAN_PREFIX,
|
|
180
|
-
node: prop.key,
|
|
181
|
-
});
|
|
182
|
-
}
|
|
183
|
-
}
|
|
184
|
-
}
|
|
185
|
-
}
|
|
186
|
-
},
|
|
187
|
-
Property: (node) => {
|
|
188
|
-
if (node.parent?.type === utils_1.AST_NODE_TYPES.ObjectPattern) {
|
|
189
|
-
let current = node.parent;
|
|
190
|
-
while (current) {
|
|
191
|
-
if (current.type === utils_1.AST_NODE_TYPES.ArrowFunctionExpression ||
|
|
192
|
-
current.type === utils_1.AST_NODE_TYPES.FunctionExpression ||
|
|
193
|
-
current.type === utils_1.AST_NODE_TYPES.FunctionDeclaration) {
|
|
194
|
-
return;
|
|
195
|
-
}
|
|
196
|
-
current = current.parent;
|
|
197
|
-
}
|
|
198
|
-
}
|
|
199
|
-
if (!checkParameters)
|
|
200
|
-
return;
|
|
201
|
-
if (node.key.type === utils_1.AST_NODE_TYPES.Identifier &&
|
|
202
|
-
node.value.type === utils_1.AST_NODE_TYPES.Identifier &&
|
|
203
|
-
node.parent?.type === utils_1.AST_NODE_TYPES.ObjectPattern) {
|
|
204
|
-
let current = node.parent;
|
|
205
|
-
while (current && current.type !== utils_1.AST_NODE_TYPES.Identifier) {
|
|
206
|
-
current = current.parent;
|
|
207
|
-
}
|
|
208
|
-
let param = node.parent;
|
|
209
|
-
while (param && param.parent) {
|
|
210
|
-
if (param.parent.type === utils_1.AST_NODE_TYPES.ArrowFunctionExpression ||
|
|
211
|
-
param.parent.type === utils_1.AST_NODE_TYPES.FunctionExpression ||
|
|
212
|
-
param.parent.type === utils_1.AST_NODE_TYPES.FunctionDeclaration) {
|
|
213
|
-
break;
|
|
214
|
-
}
|
|
215
|
-
param = param.parent;
|
|
216
|
-
}
|
|
217
|
-
if (param && "typeAnnotation" in param && param.typeAnnotation) {
|
|
218
|
-
const typeAnnotation = param.typeAnnotation;
|
|
219
|
-
if (typeAnnotation.typeAnnotation.type ===
|
|
220
|
-
utils_1.AST_NODE_TYPES.TSTypeLiteral) {
|
|
221
|
-
const typeLiteral = typeAnnotation.typeAnnotation;
|
|
222
|
-
const propertyType = typeLiteral.members.find((member) => {
|
|
223
|
-
if (member.type === utils_1.AST_NODE_TYPES.TSPropertySignature &&
|
|
224
|
-
member.key?.type === utils_1.AST_NODE_TYPES.Identifier &&
|
|
225
|
-
member.key.name ===
|
|
226
|
-
node.key.name) {
|
|
227
|
-
return (member.typeAnnotation?.typeAnnotation.type ===
|
|
228
|
-
utils_1.AST_NODE_TYPES.TSBooleanKeyword);
|
|
229
|
-
}
|
|
230
|
-
return false;
|
|
231
|
-
});
|
|
232
|
-
if (propertyType) {
|
|
233
|
-
const name = node.value.name;
|
|
234
|
-
if (!hasValidBooleanPrefix(name)) {
|
|
235
|
-
context.report({
|
|
236
|
-
data: {
|
|
237
|
-
name,
|
|
238
|
-
suggestion: generateSuggestion(name),
|
|
239
|
-
},
|
|
240
|
-
messageId: boolean_naming_convention_model_1.Messages.BAD_PARAMETER_BOOLEAN_PREFIX,
|
|
241
|
-
node: node.value,
|
|
242
|
-
});
|
|
243
|
-
}
|
|
244
|
-
}
|
|
245
|
-
}
|
|
246
|
-
}
|
|
247
|
-
}
|
|
248
|
-
},
|
|
249
|
-
VariableDeclarator: (node) => {
|
|
250
|
-
if (node.id.type === "ObjectPattern") {
|
|
251
|
-
if (!checkParameters)
|
|
252
|
-
return;
|
|
253
|
-
if (node.id.type === utils_1.AST_NODE_TYPES.ObjectPattern && node.init) {
|
|
254
|
-
node.id.properties.forEach((prop) => {
|
|
255
|
-
if (prop.type === utils_1.AST_NODE_TYPES.Property &&
|
|
256
|
-
prop.key.type === utils_1.AST_NODE_TYPES.Identifier &&
|
|
257
|
-
prop.value.type === utils_1.AST_NODE_TYPES.Identifier) {
|
|
258
|
-
const valueName = prop.value.name;
|
|
259
|
-
try {
|
|
260
|
-
const tsNode = services?.esTreeNodeToTSNodeMap?.get(prop.value);
|
|
261
|
-
if (tsNode && checker) {
|
|
262
|
-
const type = checker.getTypeAtLocation(tsNode);
|
|
263
|
-
const typeString = checker.typeToString(type);
|
|
264
|
-
if (typeString === "boolean" ||
|
|
265
|
-
typeString === "true" ||
|
|
266
|
-
typeString === "false") {
|
|
267
|
-
if (!hasValidBooleanPrefix(valueName)) {
|
|
268
|
-
context.report({
|
|
269
|
-
data: {
|
|
270
|
-
name: valueName,
|
|
271
|
-
suggestion: generateSuggestion(valueName),
|
|
272
|
-
},
|
|
273
|
-
messageId: boolean_naming_convention_model_1.Messages.BAD_VARIABLE_BOOLEAN_PREFIX,
|
|
274
|
-
node: prop.value,
|
|
275
|
-
});
|
|
276
|
-
}
|
|
277
|
-
}
|
|
278
|
-
}
|
|
279
|
-
}
|
|
280
|
-
catch { }
|
|
281
|
-
}
|
|
282
|
-
});
|
|
283
|
-
}
|
|
284
|
-
}
|
|
285
|
-
if (!checkVariables)
|
|
286
|
-
return;
|
|
287
|
-
if (node.id.type === utils_1.AST_NODE_TYPES.Identifier) {
|
|
288
|
-
if (node.id.typeAnnotation?.typeAnnotation.type ===
|
|
289
|
-
utils_1.AST_NODE_TYPES.TSBooleanKeyword) {
|
|
290
|
-
const name = node.id.name;
|
|
291
|
-
if (!hasValidBooleanPrefix(name)) {
|
|
292
|
-
context.report({
|
|
293
|
-
data: {
|
|
294
|
-
name,
|
|
295
|
-
suggestion: generateSuggestion(name),
|
|
296
|
-
},
|
|
297
|
-
messageId: boolean_naming_convention_model_1.Messages.BAD_VARIABLE_BOOLEAN_PREFIX,
|
|
298
|
-
node: node.id,
|
|
299
|
-
});
|
|
300
|
-
}
|
|
301
|
-
return;
|
|
302
|
-
}
|
|
303
|
-
if (node.init) {
|
|
304
|
-
if ((node.init.type === utils_1.AST_NODE_TYPES.ArrowFunctionExpression ||
|
|
305
|
-
node.init.type === utils_1.AST_NODE_TYPES.FunctionExpression) &&
|
|
306
|
-
functionReturnsBooleanType(node.init)) {
|
|
307
|
-
const name = node.id.name;
|
|
308
|
-
if (!hasValidBooleanPrefix(name)) {
|
|
309
|
-
context.report({
|
|
310
|
-
data: {
|
|
311
|
-
name,
|
|
312
|
-
suggestion: generateSuggestion(name),
|
|
313
|
-
},
|
|
314
|
-
messageId: boolean_naming_convention_model_1.Messages.BAD_FUNCTION_BOOLEAN_PREFIX,
|
|
315
|
-
node: node.id,
|
|
316
|
-
});
|
|
317
|
-
}
|
|
318
|
-
}
|
|
319
|
-
else if (isBooleanType(node.init)) {
|
|
320
|
-
const name = node.id.name;
|
|
321
|
-
if (!hasValidBooleanPrefix(name)) {
|
|
322
|
-
context.report({
|
|
323
|
-
data: {
|
|
324
|
-
name,
|
|
325
|
-
suggestion: generateSuggestion(name),
|
|
326
|
-
},
|
|
327
|
-
messageId: boolean_naming_convention_model_1.Messages.BAD_VARIABLE_BOOLEAN_PREFIX,
|
|
328
|
-
node: node.id,
|
|
329
|
-
});
|
|
330
|
-
}
|
|
331
|
-
}
|
|
332
|
-
}
|
|
333
|
-
}
|
|
334
|
-
},
|
|
335
|
-
};
|
|
336
|
-
},
|
|
337
|
-
defaultOptions: [
|
|
338
|
-
{
|
|
339
|
-
allowedPrefixes: boolean_prefixes_1.DEFAULT_PREFIXES,
|
|
340
|
-
checkFunctions: true,
|
|
341
|
-
checkParameters: true,
|
|
342
|
-
checkProperties: true,
|
|
343
|
-
checkVariables: true,
|
|
344
|
-
},
|
|
345
|
-
],
|
|
346
|
-
meta: {
|
|
347
|
-
docs: {
|
|
348
|
-
description: "Enforces boolean variables to use appropriate prefixes (is, has, can, should, etc.)",
|
|
349
|
-
recommended: false,
|
|
350
|
-
url: "https://github.com/NIMA-Enterprises/eslint-plugin-nima/blob/main/documentation/rules/boolean-naming-convention.md",
|
|
351
|
-
},
|
|
352
|
-
messages: {
|
|
353
|
-
[boolean_naming_convention_model_1.Messages.BAD_FUNCTION_BOOLEAN_PREFIX]: "NIMA: Function '{{name}}' returns a boolean, use a prefix like {{suggestion}}",
|
|
354
|
-
[boolean_naming_convention_model_1.Messages.BAD_PARAMETER_BOOLEAN_PREFIX]: "NIMA: Boolean parameter '{{name}}' should use a prefix like {{suggestion}}",
|
|
355
|
-
[boolean_naming_convention_model_1.Messages.BAD_PROPERTY_BOOLEAN_PREFIX]: "NIMA: Boolean property '{{name}}' should use a prefix like {{suggestion}}",
|
|
356
|
-
[boolean_naming_convention_model_1.Messages.BAD_VARIABLE_BOOLEAN_PREFIX]: "NIMA: Boolean variable '{{name}}' should use a prefix like {{suggestion}}",
|
|
357
|
-
},
|
|
358
|
-
schema: [
|
|
359
|
-
{
|
|
360
|
-
additionalProperties: false,
|
|
361
|
-
properties: {
|
|
362
|
-
allowedPrefixes: {
|
|
363
|
-
default: boolean_prefixes_1.DEFAULT_PREFIXES,
|
|
364
|
-
items: { type: "string" },
|
|
365
|
-
type: "array",
|
|
366
|
-
},
|
|
367
|
-
checkFunctions: { default: true, type: "boolean" },
|
|
368
|
-
checkParameters: { default: true, type: "boolean" },
|
|
369
|
-
checkProperties: { default: true, type: "boolean" },
|
|
370
|
-
checkVariables: { default: true, type: "boolean" },
|
|
371
|
-
},
|
|
372
|
-
type: "object",
|
|
373
|
-
},
|
|
374
|
-
],
|
|
375
|
-
type: "suggestion",
|
|
376
|
-
},
|
|
377
|
-
name: exports.name,
|
|
378
|
-
});
|
|
379
|
-
//# sourceMappingURL=boolean-naming-convention.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"boolean-naming-convention.js","sourceRoot":"","sources":["../../src/rules/boolean-naming-convention.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,89 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.rule = exports.name = void 0;
|
|
4
|
-
const no_handler_suffix_model_1 = require("../models/no-handler-suffix.model");
|
|
5
|
-
const utils_1 = require("@typescript-eslint/utils");
|
|
6
|
-
const core_1 = require("../utility/core");
|
|
7
|
-
exports.name = "no-handler-suffix";
|
|
8
|
-
exports.rule = (0, core_1.createRule)({
|
|
9
|
-
create: (context) => {
|
|
10
|
-
function generateUniqueName(base, scope) {
|
|
11
|
-
let candidate = base;
|
|
12
|
-
let index = 2;
|
|
13
|
-
const existingNames = new Set(scope.variables.map((v) => v.name));
|
|
14
|
-
while (existingNames.has(candidate)) {
|
|
15
|
-
candidate = `${base}${index++}`;
|
|
16
|
-
}
|
|
17
|
-
return candidate;
|
|
18
|
-
}
|
|
19
|
-
function checkName(node, name) {
|
|
20
|
-
if (name?.toLowerCase().endsWith("handler")) {
|
|
21
|
-
const base = name.slice(0, -7);
|
|
22
|
-
const stripped = base.length === 0 ? "" : base[0].toUpperCase() + base.slice(1);
|
|
23
|
-
const suggestedBase = `handle${stripped}`;
|
|
24
|
-
const sourceCode = context.sourceCode;
|
|
25
|
-
const scope = sourceCode.getScope(node);
|
|
26
|
-
const uniqueName = generateUniqueName(suggestedBase, scope);
|
|
27
|
-
const variable = scope.set.get(name);
|
|
28
|
-
context.report({
|
|
29
|
-
data: {
|
|
30
|
-
fnWithGoodName: uniqueName,
|
|
31
|
-
},
|
|
32
|
-
fix(fixer) {
|
|
33
|
-
const fixes = [fixer.replaceText(node, uniqueName)];
|
|
34
|
-
if (variable) {
|
|
35
|
-
for (const ref of variable.references) {
|
|
36
|
-
if (ref.identifier !== node) {
|
|
37
|
-
fixes.push(fixer.replaceText(ref.identifier, uniqueName));
|
|
38
|
-
}
|
|
39
|
-
}
|
|
40
|
-
}
|
|
41
|
-
return fixes;
|
|
42
|
-
},
|
|
43
|
-
messageId: no_handler_suffix_model_1.Messages.BAD_HANDLER_NAME,
|
|
44
|
-
node,
|
|
45
|
-
});
|
|
46
|
-
}
|
|
47
|
-
}
|
|
48
|
-
return {
|
|
49
|
-
ArrowFunctionExpression(node) {
|
|
50
|
-
const parent = node.parent;
|
|
51
|
-
if (parent?.type === utils_1.AST_NODE_TYPES.VariableDeclarator &&
|
|
52
|
-
parent.id.type === utils_1.AST_NODE_TYPES.Identifier) {
|
|
53
|
-
checkName(parent.id, parent.id.name);
|
|
54
|
-
}
|
|
55
|
-
},
|
|
56
|
-
FunctionDeclaration(node) {
|
|
57
|
-
if (node.id) {
|
|
58
|
-
checkName(node.id, node.id?.name);
|
|
59
|
-
}
|
|
60
|
-
},
|
|
61
|
-
FunctionExpression(node) {
|
|
62
|
-
const parent = node.parent;
|
|
63
|
-
if (node.id) {
|
|
64
|
-
checkName(node.id, node.id.name);
|
|
65
|
-
}
|
|
66
|
-
if (parent?.type === utils_1.AST_NODE_TYPES.VariableDeclarator &&
|
|
67
|
-
parent.id.type === utils_1.AST_NODE_TYPES.Identifier) {
|
|
68
|
-
checkName(parent.id, parent.id.name);
|
|
69
|
-
}
|
|
70
|
-
},
|
|
71
|
-
};
|
|
72
|
-
},
|
|
73
|
-
defaultOptions: [],
|
|
74
|
-
meta: {
|
|
75
|
-
docs: {
|
|
76
|
-
description: "Suggests to use handleFn instead of fnHandler",
|
|
77
|
-
recommended: true,
|
|
78
|
-
url: "https://github.com/NIMA-Enterprises/eslint-plugin-nima/blob/main/documentation/rules/no-handler-suffix.md",
|
|
79
|
-
},
|
|
80
|
-
fixable: "code",
|
|
81
|
-
messages: {
|
|
82
|
-
[no_handler_suffix_model_1.Messages.BAD_HANDLER_NAME]: "NIMA: You shouldn't use the handler suffix, use the handle prefix instead ({{ fnWithGoodName }})",
|
|
83
|
-
},
|
|
84
|
-
schema: [],
|
|
85
|
-
type: "problem",
|
|
86
|
-
},
|
|
87
|
-
name: exports.name,
|
|
88
|
-
});
|
|
89
|
-
//# sourceMappingURL=no-handler-suffix.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"no-handler-suffix.js","sourceRoot":"","sources":["../../src/rules/no-handler-suffix.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,90 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.rule = exports.name = void 0;
|
|
4
|
-
const hooks_1 = require("../constants/hooks");
|
|
5
|
-
const no_objects_in_deps_model_1 = require("../models/no-objects-in-deps.model");
|
|
6
|
-
const utils_1 = require("@typescript-eslint/utils");
|
|
7
|
-
const core_1 = require("../utility/core");
|
|
8
|
-
exports.name = "no-objects-in-deps";
|
|
9
|
-
exports.rule = (0, core_1.createRule)({
|
|
10
|
-
create: (context) => {
|
|
11
|
-
function getCalleeName(node) {
|
|
12
|
-
const callee = node.callee;
|
|
13
|
-
if (callee.type === utils_1.AST_NODE_TYPES.Identifier) {
|
|
14
|
-
return callee.name;
|
|
15
|
-
}
|
|
16
|
-
if (callee.type === utils_1.AST_NODE_TYPES.MemberExpression) {
|
|
17
|
-
if (!callee.computed &&
|
|
18
|
-
callee.property.type === utils_1.AST_NODE_TYPES.Identifier) {
|
|
19
|
-
return callee.property.name;
|
|
20
|
-
}
|
|
21
|
-
if (callee.computed &&
|
|
22
|
-
callee.property.type === utils_1.AST_NODE_TYPES.Literal) {
|
|
23
|
-
return String(callee.property.value);
|
|
24
|
-
}
|
|
25
|
-
}
|
|
26
|
-
return null;
|
|
27
|
-
}
|
|
28
|
-
const checkDep = (element, node) => {
|
|
29
|
-
const invalidExpression = element.type === utils_1.AST_NODE_TYPES.ObjectExpression ||
|
|
30
|
-
element.type === utils_1.AST_NODE_TYPES.ArrayExpression ||
|
|
31
|
-
element.type === utils_1.AST_NODE_TYPES.NewExpression;
|
|
32
|
-
if (invalidExpression) {
|
|
33
|
-
context.report({
|
|
34
|
-
data: {
|
|
35
|
-
object: context.sourceCode.getText(element),
|
|
36
|
-
},
|
|
37
|
-
messageId: no_objects_in_deps_model_1.Messages.NO_OBJECTS_IN_DEPENDENCIES,
|
|
38
|
-
node: element,
|
|
39
|
-
});
|
|
40
|
-
}
|
|
41
|
-
else if (element.type === utils_1.AST_NODE_TYPES.Identifier) {
|
|
42
|
-
const scope = context.sourceCode.getScope(node);
|
|
43
|
-
const variable = scope.variables.find((v) => v.name === element.name);
|
|
44
|
-
if (variable) {
|
|
45
|
-
for (const def of variable.defs) {
|
|
46
|
-
if (def.type === "Variable" && def.node.init) {
|
|
47
|
-
context.report({
|
|
48
|
-
data: {
|
|
49
|
-
object: context.sourceCode.getText(element),
|
|
50
|
-
},
|
|
51
|
-
messageId: no_objects_in_deps_model_1.Messages.NO_OBJECTS_IN_DEPENDENCIES,
|
|
52
|
-
node: element,
|
|
53
|
-
});
|
|
54
|
-
}
|
|
55
|
-
}
|
|
56
|
-
}
|
|
57
|
-
}
|
|
58
|
-
};
|
|
59
|
-
return {
|
|
60
|
-
CallExpression(node) {
|
|
61
|
-
const calleeName = getCalleeName(node);
|
|
62
|
-
if (!calleeName || !hooks_1.HOOKS_WITH_DEPS.has(calleeName))
|
|
63
|
-
return;
|
|
64
|
-
const deps = node.arguments[1];
|
|
65
|
-
if (deps?.type === utils_1.AST_NODE_TYPES.ArrayExpression) {
|
|
66
|
-
for (const element of deps.elements) {
|
|
67
|
-
if (!element)
|
|
68
|
-
continue;
|
|
69
|
-
checkDep(element, node);
|
|
70
|
-
}
|
|
71
|
-
}
|
|
72
|
-
},
|
|
73
|
-
};
|
|
74
|
-
},
|
|
75
|
-
defaultOptions: [],
|
|
76
|
-
meta: {
|
|
77
|
-
docs: {
|
|
78
|
-
description: "Suggests to not use objects in dependency arrays",
|
|
79
|
-
recommended: false,
|
|
80
|
-
url: "https://github.com/NIMA-Enterprises/eslint-plugin-nima/blob/main/documentation/rules/no-objects-in-deps.md",
|
|
81
|
-
},
|
|
82
|
-
messages: {
|
|
83
|
-
[no_objects_in_deps_model_1.Messages.NO_OBJECTS_IN_DEPENDENCIES]: "NIMA: Objects inside of dependency arrays aren't allowed. Try doing JSON.stringify({{ object }}).",
|
|
84
|
-
},
|
|
85
|
-
schema: [],
|
|
86
|
-
type: "suggestion",
|
|
87
|
-
},
|
|
88
|
-
name: exports.name,
|
|
89
|
-
});
|
|
90
|
-
//# sourceMappingURL=no-objects-in-deps.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"no-objects-in-deps.js","sourceRoot":"","sources":["../../src/rules/no-objects-in-deps.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,5 +0,0 @@
|
|
|
1
|
-
import { Messages, type Options } from "../models/params-naming-convention.model";
|
|
2
|
-
export declare const name = "params-naming-convention";
|
|
3
|
-
export declare const rule: import("@typescript-eslint/utils/ts-eslint").RuleModule<Messages, Options, {
|
|
4
|
-
recommended: boolean;
|
|
5
|
-
}, import("@typescript-eslint/utils/ts-eslint").RuleListener>;
|