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.
Files changed (227) hide show
  1. package/README.md +18 -18
  2. package/dist/constants/boolean-prefixes.js.map +1 -1
  3. package/dist/constants/consoles.js.map +1 -1
  4. package/dist/constants/hooks.js.map +1 -1
  5. package/dist/index.d.ts +25 -24
  6. package/dist/index.js +13 -57
  7. package/dist/index.js.map +1 -1
  8. package/dist/{models/boolean-naming-convention.model.d.ts → rules/boolean-naming-convention/config.d.ts} +11 -0
  9. package/dist/rules/boolean-naming-convention/config.js +70 -0
  10. package/dist/rules/boolean-naming-convention/config.js.map +1 -0
  11. package/dist/rules/boolean-naming-convention/create.d.ts +11 -0
  12. package/dist/rules/boolean-naming-convention/create.js +415 -0
  13. package/dist/rules/boolean-naming-convention/create.js.map +1 -0
  14. package/dist/rules/boolean-naming-convention/index.d.ts +2 -0
  15. package/dist/rules/boolean-naming-convention/index.js +22 -0
  16. package/dist/rules/boolean-naming-convention/index.js.map +1 -0
  17. package/dist/rules/{restrict-imports.d.ts → boolean-naming-convention/rule.d.ts} +2 -2
  18. package/dist/rules/boolean-naming-convention/rule.js +14 -0
  19. package/dist/rules/boolean-naming-convention/rule.js.map +1 -0
  20. package/dist/rules/index.d.ts +12 -0
  21. package/dist/rules/index.js +49 -0
  22. package/dist/rules/index.js.map +1 -0
  23. package/dist/rules/no-handler-suffix/config.d.ts +14 -0
  24. package/dist/rules/no-handler-suffix/config.js +23 -0
  25. package/dist/rules/no-handler-suffix/config.js.map +1 -0
  26. package/dist/rules/no-handler-suffix/create.d.ts +8 -0
  27. package/dist/rules/no-handler-suffix/create.js +71 -0
  28. package/dist/rules/no-handler-suffix/create.js.map +1 -0
  29. package/dist/rules/no-handler-suffix/index.d.ts +2 -0
  30. package/dist/rules/no-handler-suffix/index.js +22 -0
  31. package/dist/rules/no-handler-suffix/index.js.map +1 -0
  32. package/dist/rules/{no-handler-suffix.d.ts → no-handler-suffix/rule.d.ts} +2 -2
  33. package/dist/rules/no-handler-suffix/rule.js +14 -0
  34. package/dist/rules/no-handler-suffix/rule.js.map +1 -0
  35. package/dist/rules/no-objects-in-deps/config.d.ts +14 -0
  36. package/dist/rules/no-objects-in-deps/config.js +22 -0
  37. package/dist/rules/no-objects-in-deps/config.js.map +1 -0
  38. package/dist/rules/no-objects-in-deps/create.d.ts +6 -0
  39. package/dist/rules/no-objects-in-deps/create.js +124 -0
  40. package/dist/rules/no-objects-in-deps/create.js.map +1 -0
  41. package/dist/rules/no-objects-in-deps/index.d.ts +2 -0
  42. package/dist/rules/no-objects-in-deps/index.js +22 -0
  43. package/dist/rules/no-objects-in-deps/index.js.map +1 -0
  44. package/dist/rules/{no-objects-in-deps.d.ts → no-objects-in-deps/rule.d.ts} +2 -2
  45. package/dist/rules/no-objects-in-deps/rule.js +14 -0
  46. package/dist/rules/no-objects-in-deps/rule.js.map +1 -0
  47. package/dist/rules/params-naming-convention/config.d.ts +21 -0
  48. package/dist/rules/params-naming-convention/config.js +55 -0
  49. package/dist/rules/params-naming-convention/config.js.map +1 -0
  50. package/dist/rules/params-naming-convention/create.d.ts +6 -0
  51. package/dist/rules/params-naming-convention/create.js +49 -0
  52. package/dist/rules/params-naming-convention/create.js.map +1 -0
  53. package/dist/rules/params-naming-convention/index.d.ts +2 -0
  54. package/dist/rules/params-naming-convention/index.js +22 -0
  55. package/dist/rules/params-naming-convention/index.js.map +1 -0
  56. package/dist/rules/{prefer-react-fc.d.ts → params-naming-convention/rule.d.ts} +2 -2
  57. package/dist/rules/params-naming-convention/rule.js +14 -0
  58. package/dist/rules/params-naming-convention/rule.js.map +1 -0
  59. package/dist/{models/prefer-arrow-functions.model.d.ts → rules/prefer-arrow-functions/config.d.ts} +10 -0
  60. package/dist/rules/prefer-arrow-functions/config.js +67 -0
  61. package/dist/rules/prefer-arrow-functions/config.js.map +1 -0
  62. package/dist/rules/prefer-arrow-functions/create.d.ts +9 -0
  63. package/dist/rules/prefer-arrow-functions/create.js +150 -0
  64. package/dist/rules/prefer-arrow-functions/create.js.map +1 -0
  65. package/dist/rules/prefer-arrow-functions/index.d.ts +2 -0
  66. package/dist/rules/prefer-arrow-functions/index.js +22 -0
  67. package/dist/rules/prefer-arrow-functions/index.js.map +1 -0
  68. package/dist/rules/{restrict-function-usage.d.ts → prefer-arrow-functions/rule.d.ts} +2 -2
  69. package/dist/rules/prefer-arrow-functions/rule.js +14 -0
  70. package/dist/rules/prefer-arrow-functions/rule.js.map +1 -0
  71. package/dist/rules/prefer-export-under-component/config.d.ts +14 -0
  72. package/dist/rules/prefer-export-under-component/config.js +23 -0
  73. package/dist/rules/prefer-export-under-component/config.js.map +1 -0
  74. package/dist/rules/prefer-export-under-component/create.d.ts +8 -0
  75. package/dist/rules/prefer-export-under-component/create.js +99 -0
  76. package/dist/rules/prefer-export-under-component/create.js.map +1 -0
  77. package/dist/rules/prefer-export-under-component/index.d.ts +2 -0
  78. package/dist/rules/prefer-export-under-component/index.js +22 -0
  79. package/dist/rules/prefer-export-under-component/index.js.map +1 -0
  80. package/dist/rules/{prefer-react-with-hooks.d.ts → prefer-export-under-component/rule.d.ts} +2 -2
  81. package/dist/rules/prefer-export-under-component/rule.js +14 -0
  82. package/dist/rules/prefer-export-under-component/rule.js.map +1 -0
  83. package/dist/rules/prefer-react-fc/config.d.ts +19 -0
  84. package/dist/rules/prefer-react-fc/config.js +43 -0
  85. package/dist/rules/prefer-react-fc/config.js.map +1 -0
  86. package/dist/rules/prefer-react-fc/create.d.ts +8 -0
  87. package/dist/rules/prefer-react-fc/create.js +166 -0
  88. package/dist/rules/prefer-react-fc/create.js.map +1 -0
  89. package/dist/rules/prefer-react-fc/index.d.ts +2 -0
  90. package/dist/rules/prefer-react-fc/index.js +22 -0
  91. package/dist/rules/prefer-react-fc/index.js.map +1 -0
  92. package/dist/rules/{prefer-arrow-functions.d.ts → prefer-react-fc/rule.d.ts} +2 -2
  93. package/dist/rules/prefer-react-fc/rule.js +14 -0
  94. package/dist/rules/prefer-react-fc/rule.js.map +1 -0
  95. package/dist/rules/prefer-react-with-hooks/config.d.ts +15 -0
  96. package/dist/rules/prefer-react-with-hooks/config.js +25 -0
  97. package/dist/rules/prefer-react-with-hooks/config.js.map +1 -0
  98. package/dist/rules/prefer-react-with-hooks/create.d.ts +7 -0
  99. package/dist/rules/prefer-react-with-hooks/create.js +188 -0
  100. package/dist/rules/prefer-react-with-hooks/create.js.map +1 -0
  101. package/dist/rules/prefer-react-with-hooks/index.d.ts +2 -0
  102. package/dist/rules/prefer-react-with-hooks/index.js +22 -0
  103. package/dist/rules/prefer-react-with-hooks/index.js.map +1 -0
  104. package/dist/rules/{prefer-export-under-component.d.ts → prefer-react-with-hooks/rule.d.ts} +2 -2
  105. package/dist/rules/prefer-react-with-hooks/rule.js +14 -0
  106. package/dist/rules/prefer-react-with-hooks/rule.js.map +1 -0
  107. package/dist/rules/prefer-void-for-optional-param/config.d.ts +15 -0
  108. package/dist/rules/prefer-void-for-optional-param/config.js +25 -0
  109. package/dist/rules/prefer-void-for-optional-param/config.js.map +1 -0
  110. package/dist/rules/prefer-void-for-optional-param/create.d.ts +8 -0
  111. package/dist/rules/prefer-void-for-optional-param/create.js +188 -0
  112. package/dist/rules/prefer-void-for-optional-param/create.js.map +1 -0
  113. package/dist/rules/prefer-void-for-optional-param/index.d.ts +2 -0
  114. package/dist/rules/prefer-void-for-optional-param/index.js +22 -0
  115. package/dist/rules/prefer-void-for-optional-param/index.js.map +1 -0
  116. package/dist/rules/prefer-void-for-optional-param/rule.d.ts +5 -0
  117. package/dist/rules/prefer-void-for-optional-param/rule.js +14 -0
  118. package/dist/rules/prefer-void-for-optional-param/rule.js.map +1 -0
  119. package/dist/rules/restrict-console-methods/config.d.ts +18 -0
  120. package/dist/rules/restrict-console-methods/config.js +38 -0
  121. package/dist/rules/restrict-console-methods/config.js.map +1 -0
  122. package/dist/rules/restrict-console-methods/create.d.ts +6 -0
  123. package/dist/rules/restrict-console-methods/create.js +34 -0
  124. package/dist/rules/restrict-console-methods/create.js.map +1 -0
  125. package/dist/rules/restrict-console-methods/index.d.ts +2 -0
  126. package/dist/rules/restrict-console-methods/index.js +22 -0
  127. package/dist/rules/restrict-console-methods/index.js.map +1 -0
  128. package/dist/rules/restrict-console-methods/rule.d.ts +5 -0
  129. package/dist/rules/restrict-console-methods/rule.js +14 -0
  130. package/dist/rules/restrict-console-methods/rule.js.map +1 -0
  131. package/dist/rules/restrict-function-usage/config.d.ts +21 -0
  132. package/dist/rules/restrict-function-usage/config.js +62 -0
  133. package/dist/rules/restrict-function-usage/config.js.map +1 -0
  134. package/dist/rules/restrict-function-usage/create.d.ts +6 -0
  135. package/dist/rules/restrict-function-usage/create.js +76 -0
  136. package/dist/rules/restrict-function-usage/create.js.map +1 -0
  137. package/dist/rules/restrict-function-usage/index.d.ts +2 -0
  138. package/dist/rules/restrict-function-usage/index.js +22 -0
  139. package/dist/rules/restrict-function-usage/index.js.map +1 -0
  140. package/dist/rules/restrict-function-usage/rule.d.ts +5 -0
  141. package/dist/rules/restrict-function-usage/rule.js +14 -0
  142. package/dist/rules/restrict-function-usage/rule.js.map +1 -0
  143. package/dist/rules/restrict-imports/config.d.ts +22 -0
  144. package/dist/rules/restrict-imports/config.js +69 -0
  145. package/dist/rules/restrict-imports/config.js.map +1 -0
  146. package/dist/rules/restrict-imports/create.d.ts +6 -0
  147. package/dist/rules/restrict-imports/create.js +92 -0
  148. package/dist/rules/restrict-imports/create.js.map +1 -0
  149. package/dist/rules/restrict-imports/index.d.ts +2 -0
  150. package/dist/rules/restrict-imports/index.js +22 -0
  151. package/dist/rules/restrict-imports/index.js.map +1 -0
  152. package/dist/rules/restrict-imports/rule.d.ts +5 -0
  153. package/dist/rules/restrict-imports/rule.js +14 -0
  154. package/dist/rules/restrict-imports/rule.js.map +1 -0
  155. package/dist/utility/core.js.map +1 -1
  156. package/dist/utility/file-helpers.d.ts +6 -0
  157. package/dist/utility/file-helpers.js +32 -0
  158. package/dist/utility/file-helpers.js.map +1 -0
  159. package/dist/utility/function-helpers.d.ts +4 -4
  160. package/dist/utility/function-helpers.js +17 -15
  161. package/dist/utility/function-helpers.js.map +1 -1
  162. package/dist/utility/type-helpers.d.ts +4 -1
  163. package/dist/utility/type-helpers.js +6 -4
  164. package/dist/utility/type-helpers.js.map +1 -1
  165. package/package.json +75 -73
  166. package/dist/models/boolean-naming-convention.model.js +0 -11
  167. package/dist/models/boolean-naming-convention.model.js.map +0 -1
  168. package/dist/models/no-handler-suffix.model.d.ts +0 -4
  169. package/dist/models/no-handler-suffix.model.js +0 -8
  170. package/dist/models/no-handler-suffix.model.js.map +0 -1
  171. package/dist/models/no-objects-in-deps.model.d.ts +0 -4
  172. package/dist/models/no-objects-in-deps.model.js +0 -8
  173. package/dist/models/no-objects-in-deps.model.js.map +0 -1
  174. package/dist/models/params-naming-convention.model.d.ts +0 -11
  175. package/dist/models/params-naming-convention.model.js +0 -8
  176. package/dist/models/params-naming-convention.model.js.map +0 -1
  177. package/dist/models/prefer-arrow-functions.model.js +0 -10
  178. package/dist/models/prefer-arrow-functions.model.js.map +0 -1
  179. package/dist/models/prefer-export-under-component.model.d.ts +0 -4
  180. package/dist/models/prefer-export-under-component.model.js +0 -8
  181. package/dist/models/prefer-export-under-component.model.js.map +0 -1
  182. package/dist/models/prefer-react-fc.model.d.ts +0 -9
  183. package/dist/models/prefer-react-fc.model.js +0 -8
  184. package/dist/models/prefer-react-fc.model.js.map +0 -1
  185. package/dist/models/prefer-react-with-hooks.model.d.ts +0 -5
  186. package/dist/models/prefer-react-with-hooks.model.js +0 -9
  187. package/dist/models/prefer-react-with-hooks.model.js.map +0 -1
  188. package/dist/models/prefer-void-for-optional-param.model.d.ts +0 -5
  189. package/dist/models/prefer-void-for-optional-param.model.js +0 -9
  190. package/dist/models/prefer-void-for-optional-param.model.js.map +0 -1
  191. package/dist/models/restrict-console-methods.model.d.ts +0 -8
  192. package/dist/models/restrict-console-methods.model.js +0 -8
  193. package/dist/models/restrict-console-methods.model.js.map +0 -1
  194. package/dist/models/restrict-function-usage.model.d.ts +0 -11
  195. package/dist/models/restrict-function-usage.model.js +0 -8
  196. package/dist/models/restrict-function-usage.model.js.map +0 -1
  197. package/dist/models/restrict-imports.model.d.ts +0 -12
  198. package/dist/models/restrict-imports.model.js +0 -8
  199. package/dist/models/restrict-imports.model.js.map +0 -1
  200. package/dist/rules/boolean-naming-convention.d.ts +0 -5
  201. package/dist/rules/boolean-naming-convention.js +0 -379
  202. package/dist/rules/boolean-naming-convention.js.map +0 -1
  203. package/dist/rules/no-handler-suffix.js +0 -89
  204. package/dist/rules/no-handler-suffix.js.map +0 -1
  205. package/dist/rules/no-objects-in-deps.js +0 -90
  206. package/dist/rules/no-objects-in-deps.js.map +0 -1
  207. package/dist/rules/params-naming-convention.d.ts +0 -5
  208. package/dist/rules/params-naming-convention.js +0 -95
  209. package/dist/rules/params-naming-convention.js.map +0 -1
  210. package/dist/rules/prefer-arrow-functions.js +0 -208
  211. package/dist/rules/prefer-arrow-functions.js.map +0 -1
  212. package/dist/rules/prefer-export-under-component.js +0 -113
  213. package/dist/rules/prefer-export-under-component.js.map +0 -1
  214. package/dist/rules/prefer-react-fc.js +0 -204
  215. package/dist/rules/prefer-react-fc.js.map +0 -1
  216. package/dist/rules/prefer-react-with-hooks.js +0 -185
  217. package/dist/rules/prefer-react-with-hooks.js.map +0 -1
  218. package/dist/rules/prefer-void-for-optional-param.d.ts +0 -6
  219. package/dist/rules/prefer-void-for-optional-param.js +0 -188
  220. package/dist/rules/prefer-void-for-optional-param.js.map +0 -1
  221. package/dist/rules/restrict-console-methods.d.ts +0 -5
  222. package/dist/rules/restrict-console-methods.js +0 -66
  223. package/dist/rules/restrict-console-methods.js.map +0 -1
  224. package/dist/rules/restrict-function-usage.js +0 -121
  225. package/dist/rules/restrict-function-usage.js.map +0 -1
  226. package/dist/rules/restrict-imports.js +0 -135
  227. 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>;