eslint-plugin-nima 0.0.2 → 0.0.4

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 (46) hide show
  1. package/dist/constants/boolean-prefixes.d.ts +1 -0
  2. package/dist/constants/boolean-prefixes.js +15 -0
  3. package/dist/constants/boolean-prefixes.js.map +1 -0
  4. package/dist/constants/consoles.d.ts +1 -0
  5. package/dist/constants/consoles.js +5 -0
  6. package/dist/constants/consoles.js.map +1 -0
  7. package/dist/constants/hooks.d.ts +2 -0
  8. package/dist/constants/hooks.js +29 -0
  9. package/dist/constants/hooks.js.map +1 -0
  10. package/dist/index.d.ts +93 -0
  11. package/dist/index.js +80 -0
  12. package/dist/index.js.map +1 -0
  13. package/dist/rules/boolean-naming-convention.d.ts +9 -0
  14. package/dist/rules/boolean-naming-convention.js +310 -0
  15. package/dist/rules/boolean-naming-convention.js.map +1 -0
  16. package/dist/rules/no-handler-suffix.d.ts +3 -0
  17. package/dist/rules/no-handler-suffix.js +85 -0
  18. package/dist/rules/no-handler-suffix.js.map +1 -0
  19. package/dist/rules/no-objects-in-deps.d.ts +3 -0
  20. package/dist/rules/no-objects-in-deps.js +80 -0
  21. package/dist/rules/no-objects-in-deps.js.map +1 -0
  22. package/dist/rules/no-optional-in-routes.d.ts +3 -0
  23. package/dist/rules/no-optional-in-routes.js +37 -0
  24. package/dist/rules/no-optional-in-routes.js.map +1 -0
  25. package/dist/rules/params-naming-convention.d.ts +8 -0
  26. package/dist/rules/params-naming-convention.js +95 -0
  27. package/dist/rules/params-naming-convention.js.map +1 -0
  28. package/dist/rules/prefer-arrow-functions.d.ts +10 -0
  29. package/dist/rules/prefer-arrow-functions.js +208 -0
  30. package/dist/rules/prefer-arrow-functions.js.map +1 -0
  31. package/dist/rules/prefer-react-fc.d.ts +6 -0
  32. package/dist/rules/prefer-react-fc.js +208 -0
  33. package/dist/rules/prefer-react-fc.js.map +1 -0
  34. package/dist/rules/prefer-react-with-hooks.d.ts +5 -0
  35. package/dist/rules/prefer-react-with-hooks.js +176 -0
  36. package/dist/rules/prefer-react-with-hooks.js.map +1 -0
  37. package/dist/rules/restrict-console-methods.d.ts +9 -0
  38. package/dist/rules/restrict-console-methods.js +75 -0
  39. package/dist/rules/restrict-console-methods.js.map +1 -0
  40. package/dist/utility/getFunctionName.d.ts +2 -0
  41. package/dist/utility/getFunctionName.js +36 -0
  42. package/dist/utility/getFunctionName.js.map +1 -0
  43. package/dist/utility/getType.d.ts +3 -0
  44. package/dist/utility/getType.js +24 -0
  45. package/dist/utility/getType.js.map +1 -0
  46. package/package.json +3 -3
@@ -0,0 +1,85 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.rule = exports.name = void 0;
4
+ const utils_1 = require("@typescript-eslint/utils");
5
+ exports.name = "no-handler-suffix";
6
+ exports.rule = utils_1.ESLintUtils.RuleCreator.withoutDocs({
7
+ create: (context) => {
8
+ function generateUniqueName(base, scope) {
9
+ let candidate = base;
10
+ let index = 2;
11
+ const existingNames = new Set(scope.variables.map((v) => v.name));
12
+ while (existingNames.has(candidate)) {
13
+ candidate = `${base}${index++}`;
14
+ }
15
+ return candidate;
16
+ }
17
+ function checkName(node, name) {
18
+ if (name === null || name === void 0 ? void 0 : name.toLowerCase().endsWith("handler")) {
19
+ const base = name.slice(0, -7);
20
+ const stripped = base.length === 0 ? "" : base[0].toUpperCase() + base.slice(1);
21
+ const suggestedBase = `handle${stripped}`;
22
+ const sourceCode = context.sourceCode;
23
+ const scope = sourceCode.getScope(node);
24
+ const uniqueName = generateUniqueName(suggestedBase, scope);
25
+ const variable = scope.set.get(name);
26
+ context.report({
27
+ data: {
28
+ fnWithGoodName: uniqueName,
29
+ },
30
+ fix(fixer) {
31
+ const fixes = [fixer.replaceText(node, uniqueName)];
32
+ if (variable) {
33
+ for (const ref of variable.references) {
34
+ if (ref.identifier !== node) {
35
+ fixes.push(fixer.replaceText(ref.identifier, uniqueName));
36
+ }
37
+ }
38
+ }
39
+ return fixes;
40
+ },
41
+ messageId: "badHandleName",
42
+ node,
43
+ });
44
+ }
45
+ }
46
+ return {
47
+ ArrowFunctionExpression(node) {
48
+ const parent = node.parent;
49
+ if ((parent === null || parent === void 0 ? void 0 : parent.type) === "VariableDeclarator" &&
50
+ parent.id.type === "Identifier") {
51
+ checkName(parent.id, parent.id.name);
52
+ }
53
+ },
54
+ FunctionDeclaration(node) {
55
+ var _a;
56
+ if (node.id) {
57
+ checkName(node.id, (_a = node.id) === null || _a === void 0 ? void 0 : _a.name);
58
+ }
59
+ },
60
+ FunctionExpression(node) {
61
+ const parent = node.parent;
62
+ if (node.id) {
63
+ checkName(node.id, node.id.name);
64
+ }
65
+ if ((parent === null || parent === void 0 ? void 0 : parent.type) === "VariableDeclarator" &&
66
+ parent.id.type === "Identifier") {
67
+ checkName(parent.id, parent.id.name);
68
+ }
69
+ },
70
+ };
71
+ },
72
+ defaultOptions: [],
73
+ meta: {
74
+ docs: {
75
+ description: "Suggests to use handleFn instead of fnHandler",
76
+ },
77
+ fixable: "code",
78
+ messages: {
79
+ badHandleName: "NIMA: You shouldn't use the handler suffix, use the handle prefix instead ({{ fnWithGoodName }})",
80
+ },
81
+ schema: [],
82
+ type: "suggestion",
83
+ },
84
+ });
85
+ //# sourceMappingURL=no-handler-suffix.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"no-handler-suffix.js","sourceRoot":"","sources":["../../src/rules/no-handler-suffix.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,3 @@
1
+ import { ESLintUtils } from "@typescript-eslint/utils";
2
+ export declare const name = "no-objects-in-deps";
3
+ export declare const rule: ESLintUtils.RuleModule<"noObjects", [], unknown, ESLintUtils.RuleListener>;
@@ -0,0 +1,80 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.rule = exports.name = void 0;
4
+ const utils_1 = require("@typescript-eslint/utils");
5
+ const hooks_js_1 = require("../constants/hooks.js");
6
+ exports.name = "no-objects-in-deps";
7
+ exports.rule = utils_1.ESLintUtils.RuleCreator.withoutDocs({
8
+ create: (context) => {
9
+ function getCalleeName(node) {
10
+ const callee = node.callee;
11
+ if (callee.type === "Identifier") {
12
+ return callee.name;
13
+ }
14
+ if (callee.type === "MemberExpression") {
15
+ if (!callee.computed && callee.property.type === "Identifier") {
16
+ return callee.property.name;
17
+ }
18
+ if (callee.computed && callee.property.type === "Literal") {
19
+ return String(callee.property.value);
20
+ }
21
+ }
22
+ return null;
23
+ }
24
+ const checkDep = (element, node) => {
25
+ const invalidExpression = element.type === "ObjectExpression" ||
26
+ element.type === "ArrayExpression" ||
27
+ element.type === "NewExpression";
28
+ if (invalidExpression) {
29
+ context.report({
30
+ messageId: "noObjects",
31
+ node: element,
32
+ });
33
+ }
34
+ else if (element.type === "Identifier") {
35
+ const scope = context.sourceCode.getScope(node);
36
+ const variable = scope.variables.find((v) => v.name === element.name);
37
+ if (variable) {
38
+ for (const def of variable.defs) {
39
+ if (def.type === "Variable" && def.node.init) {
40
+ context.report({
41
+ data: {
42
+ object: context.sourceCode.getText(element),
43
+ },
44
+ messageId: "noObjects",
45
+ node: element,
46
+ });
47
+ }
48
+ }
49
+ }
50
+ }
51
+ };
52
+ return {
53
+ CallExpression(node) {
54
+ const calleeName = getCalleeName(node);
55
+ if (!calleeName || !hooks_js_1.HOOKS_WITH_DEPS.has(calleeName))
56
+ return;
57
+ const deps = node.arguments[1];
58
+ if ((deps === null || deps === void 0 ? void 0 : deps.type) === "ArrayExpression") {
59
+ for (const element of deps.elements) {
60
+ if (!element)
61
+ continue;
62
+ checkDep(element, node);
63
+ }
64
+ }
65
+ },
66
+ };
67
+ },
68
+ defaultOptions: [],
69
+ meta: {
70
+ docs: {
71
+ description: "Suggests to not use objects in dependency arrays",
72
+ },
73
+ messages: {
74
+ noObjects: "NIMA: Objects inside of dependency arrays aren't allowed. Try doing JSON.stringify({{ object }}).",
75
+ },
76
+ schema: [],
77
+ type: "suggestion",
78
+ },
79
+ });
80
+ //# sourceMappingURL=no-objects-in-deps.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"no-objects-in-deps.js","sourceRoot":"","sources":["../../src/rules/no-objects-in-deps.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,3 @@
1
+ import { ESLintUtils } from "@typescript-eslint/utils";
2
+ export declare const name = "no-optional-in-routes";
3
+ export declare const rule: ESLintUtils.RuleModule<"noOptional", [], unknown, ESLintUtils.RuleListener>;
@@ -0,0 +1,37 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.rule = exports.name = void 0;
4
+ const utils_1 = require("@typescript-eslint/utils");
5
+ exports.name = "no-optional-in-routes";
6
+ exports.rule = utils_1.ESLintUtils.RuleCreator.withoutDocs({
7
+ create(context) {
8
+ const filename = context.filename;
9
+ if (!filename.includes("/routes/")) {
10
+ return;
11
+ }
12
+ return {
13
+ CallExpression(node) {
14
+ if (node.callee.type === "MemberExpression" &&
15
+ node.callee.property.type === "Identifier" &&
16
+ node.callee.property.name === "optional") {
17
+ context.report({
18
+ messageId: "noOptional",
19
+ node: node.callee.property,
20
+ });
21
+ }
22
+ },
23
+ };
24
+ },
25
+ defaultOptions: [],
26
+ meta: {
27
+ docs: {
28
+ description: "Disallow use of .optional() in routes folder",
29
+ },
30
+ messages: {
31
+ noOptional: "Do not use .optional() inside the routes folder.",
32
+ },
33
+ schema: [],
34
+ type: "problem",
35
+ },
36
+ });
37
+ //# sourceMappingURL=no-optional-in-routes.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"no-optional-in-routes.js","sourceRoot":"","sources":["../../src/rules/no-optional-in-routes.ts"],"names":[],"mappings":";;;AAAA,oDAAiE;AAEpD,QAAA,IAAI,GAAG,uBAAuB,CAAC;AAE/B,QAAA,IAAI,GAAG,mBAAW,CAAC,WAAW,CAAC,WAAW,CAAC;IACtD,MAAM,CAAC,OAAO;QACZ,MAAM,QAAQ,GAAG,OAAO,CAAC,QAAQ,CAAC;QAElC,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,UAAU,CAAC,EAAE,CAAC;YACnC,OAAO;QACT,CAAC;QAED,OAAO;YACL,cAAc,CAAC,IAA6B;gBAC1C,IACE,IAAI,CAAC,MAAM,CAAC,IAAI,KAAK,kBAAkB;oBACvC,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,IAAI,KAAK,YAAY;oBAC1C,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,IAAI,KAAK,UAAU,EACxC,CAAC;oBACD,OAAO,CAAC,MAAM,CAAC;wBACb,SAAS,EAAE,YAAY;wBACvB,IAAI,EAAE,IAAI,CAAC,MAAM,CAAC,QAAQ;qBAC3B,CAAC,CAAC;gBACL,CAAC;YACH,CAAC;SACF,CAAC;IACJ,CAAC;IACD,cAAc,EAAE,EAAE;IAClB,IAAI,EAAE;QACJ,IAAI,EAAE;YACJ,WAAW,EAAE,8CAA8C;SAC5D;QACD,QAAQ,EAAE;YACR,UAAU,EAAE,kDAAkD;SAC/D;QACD,MAAM,EAAE,EAAE;QACV,IAAI,EAAE,SAAS;KAChB;CACF,CAAC,CAAC"}
@@ -0,0 +1,8 @@
1
+ import { ESLintUtils } from "@typescript-eslint/utils";
2
+ export declare const name = "params-naming-convention";
3
+ export declare const rule: ESLintUtils.RuleModule<"useObjectParams", [{
4
+ allowedParameters: number;
5
+ ignore: string[];
6
+ ignoreFunctions: string[];
7
+ ignorePrefixes: string[];
8
+ }], unknown, ESLintUtils.RuleListener>;
@@ -0,0 +1,95 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.rule = exports.name = void 0;
4
+ const utils_1 = require("@typescript-eslint/utils");
5
+ const getFunctionName_1 = require("../utility/getFunctionName");
6
+ exports.name = "params-naming-convention";
7
+ exports.rule = utils_1.ESLintUtils.RuleCreator.withoutDocs({
8
+ create: (context, options) => {
9
+ const ignore = options[0].ignore;
10
+ const ignorePrefixes = options[0].ignorePrefixes;
11
+ const allowedParameters = options[0].allowedParameters;
12
+ const ignoreFunctions = options[0].ignoreFunctions;
13
+ function checkParams(node) {
14
+ if (node.params.length <= allowedParameters) {
15
+ return;
16
+ }
17
+ const fnName = (0, getFunctionName_1.getFunctionName)(node);
18
+ if (fnName && (ignoreFunctions === null || ignoreFunctions === void 0 ? void 0 : ignoreFunctions.includes(fnName))) {
19
+ return;
20
+ }
21
+ if (node.params.length > 1 &&
22
+ node.params[1].type === utils_1.AST_NODE_TYPES.Identifier &&
23
+ node.params[1].name === "index") {
24
+ return;
25
+ }
26
+ if (node.params[0] &&
27
+ node.params[0].type === utils_1.AST_NODE_TYPES.ObjectPattern)
28
+ return;
29
+ const paramNames = node.params
30
+ .map((p) => {
31
+ if (p.type === utils_1.AST_NODE_TYPES.Identifier)
32
+ return p.name;
33
+ return null;
34
+ })
35
+ .filter((name) => !!name)
36
+ .filter((name) => !ignore.includes(name) &&
37
+ !(ignorePrefixes === null || ignorePrefixes === void 0 ? void 0 : ignorePrefixes.some((prefix) => name.startsWith(prefix))));
38
+ if (paramNames.length > 0) {
39
+ context.report({
40
+ data: {
41
+ count: paramNames.length.toString(),
42
+ params: paramNames.join(", "),
43
+ },
44
+ messageId: "useObjectParams",
45
+ node,
46
+ });
47
+ }
48
+ }
49
+ return {
50
+ "FunctionDeclaration, FunctionExpression, ArrowFunctionExpression": checkParams,
51
+ };
52
+ },
53
+ defaultOptions: [
54
+ {
55
+ allowedParameters: 1,
56
+ ignore: ["e"],
57
+ ignoreFunctions: ["reduce"],
58
+ ignorePrefixes: ["$"],
59
+ },
60
+ ],
61
+ meta: {
62
+ docs: {
63
+ description: "Enforce using a single object parameter for all functions",
64
+ },
65
+ messages: {
66
+ useObjectParams: "NIMA: Function has {{count}} parameter(s). Use a single object parameter instead: {{params}}",
67
+ },
68
+ schema: [
69
+ {
70
+ additionalProperties: false,
71
+ properties: {
72
+ allowedParameters: {
73
+ default: 1,
74
+ type: "number",
75
+ },
76
+ ignore: {
77
+ items: { type: "string" },
78
+ type: "array",
79
+ },
80
+ ignoreFunctions: {
81
+ items: { type: "string" },
82
+ type: "array",
83
+ },
84
+ ignorePrefixes: {
85
+ items: { type: "string" },
86
+ type: "array",
87
+ },
88
+ },
89
+ type: "object",
90
+ },
91
+ ],
92
+ type: "problem",
93
+ },
94
+ });
95
+ //# sourceMappingURL=params-naming-convention.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"params-naming-convention.js","sourceRoot":"","sources":["../../src/rules/params-naming-convention.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,10 @@
1
+ import { ESLintUtils } from "@typescript-eslint/utils";
2
+ export declare const name = "prefer-arrow-functions";
3
+ export declare const rule: ESLintUtils.RuleModule<"preferArrowFunction" | "preferArrowFunctionExpression" | "preferArrowMethod", [{
4
+ allowAsync: boolean;
5
+ allowConstructors: boolean;
6
+ allowFunctionDeclarations: boolean;
7
+ allowFunctionExpressions: boolean;
8
+ allowGenerators: boolean;
9
+ allowMethodDefinitions: boolean;
10
+ }], unknown, ESLintUtils.RuleListener>;
@@ -0,0 +1,208 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.rule = exports.name = void 0;
4
+ const utils_1 = require("@typescript-eslint/utils");
5
+ exports.name = "prefer-arrow-functions";
6
+ exports.rule = utils_1.ESLintUtils.RuleCreator.withoutDocs({
7
+ create: (context, options) => {
8
+ const allowConstructors = options[0].allowConstructors;
9
+ const allowAsync = options[0].allowAsync;
10
+ const allowFunctionDeclarations = options[0].allowFunctionDeclarations;
11
+ const allowFunctionExpressions = options[0].allowFunctionExpressions;
12
+ const allowGenerators = options[0].allowGenerators;
13
+ const allowMethodDefinitions = options[0].allowMethodDefinitions;
14
+ const shouldSkipFunction = (node) => {
15
+ var _a;
16
+ if (allowConstructors &&
17
+ ((_a = node.parent) === null || _a === void 0 ? void 0 : _a.type) === utils_1.AST_NODE_TYPES.MethodDefinition &&
18
+ node.parent.kind === "constructor") {
19
+ return true;
20
+ }
21
+ if (allowGenerators && "generator" in node && node.generator) {
22
+ return true;
23
+ }
24
+ if (!allowAsync && "async" in node && node.async) {
25
+ return false;
26
+ }
27
+ if (node.type === utils_1.AST_NODE_TYPES.TSEmptyBodyFunctionExpression) {
28
+ return true;
29
+ }
30
+ return false;
31
+ };
32
+ const generateArrowFunction = (node) => {
33
+ const sourceCode = context.getSourceCode();
34
+ const asyncKeyword = node.async ? "async " : "";
35
+ const params = node.params.length === 0
36
+ ? "()"
37
+ : node.params.length === 1 &&
38
+ node.params[0].type === utils_1.AST_NODE_TYPES.Identifier &&
39
+ !node.params[0].typeAnnotation
40
+ ? sourceCode.getText(node.params[0])
41
+ : `(${node.params.map((p) => sourceCode.getText(p)).join(", ")})`;
42
+ const returnType = node.returnType
43
+ ? `: ${sourceCode.getText(node.returnType.typeAnnotation)}`
44
+ : "";
45
+ const body = node.body ? sourceCode.getText(node.body) : "";
46
+ return `${asyncKeyword}${params}${returnType} => ${body}`;
47
+ };
48
+ return {
49
+ FunctionDeclaration: (node) => {
50
+ if (allowFunctionDeclarations || shouldSkipFunction(node)) {
51
+ return;
52
+ }
53
+ context.report({
54
+ fix: (fixer) => {
55
+ var _a, _b;
56
+ if (!node.id)
57
+ return null;
58
+ const functionName = node.id.name;
59
+ const arrowFunction = generateArrowFunction(node);
60
+ let replacement;
61
+ if (((_a = node.parent) === null || _a === void 0 ? void 0 : _a.type) === utils_1.AST_NODE_TYPES.ExportDefaultDeclaration) {
62
+ const constDeclaration = `const ${functionName} = ${arrowFunction}`;
63
+ const exportDeclaration = `export default ${functionName}`;
64
+ replacement = `${constDeclaration};\n${exportDeclaration}`;
65
+ return fixer.replaceText(node.parent, replacement);
66
+ }
67
+ else if (((_b = node.parent) === null || _b === void 0 ? void 0 : _b.type) === utils_1.AST_NODE_TYPES.ExportNamedDeclaration) {
68
+ replacement = `export const ${functionName} = ${arrowFunction}`;
69
+ return fixer.replaceText(node.parent, replacement);
70
+ }
71
+ else {
72
+ replacement = `const ${functionName} = ${arrowFunction}`;
73
+ return fixer.replaceText(node, replacement);
74
+ }
75
+ },
76
+ messageId: "preferArrowFunction",
77
+ node: node.id || node,
78
+ });
79
+ },
80
+ FunctionExpression: (node) => {
81
+ var _a, _b;
82
+ if (allowFunctionExpressions || shouldSkipFunction(node)) {
83
+ return;
84
+ }
85
+ if (((_a = node.parent) === null || _a === void 0 ? void 0 : _a.type) === utils_1.AST_NODE_TYPES.MethodDefinition ||
86
+ ((_b = node.parent) === null || _b === void 0 ? void 0 : _b.type) === utils_1.AST_NODE_TYPES.Property) {
87
+ if (!allowMethodDefinitions) {
88
+ return;
89
+ }
90
+ return;
91
+ }
92
+ context.report({
93
+ fix: (fixer) => {
94
+ const arrowFunction = generateArrowFunction(node);
95
+ return fixer.replaceText(node, arrowFunction);
96
+ },
97
+ messageId: "preferArrowFunctionExpression",
98
+ node,
99
+ });
100
+ },
101
+ MethodDefinition: (node) => {
102
+ if (allowMethodDefinitions ||
103
+ node.kind === "constructor" ||
104
+ node.kind === "get" ||
105
+ node.kind === "set") {
106
+ return;
107
+ }
108
+ if (node.value.type === utils_1.AST_NODE_TYPES.FunctionExpression &&
109
+ !shouldSkipFunction(node.value)) {
110
+ context.report({
111
+ fix: (fixer) => {
112
+ const sourceCode = context.getSourceCode();
113
+ const key = sourceCode.getText(node.key);
114
+ const arrowFunction = generateArrowFunction(node.value);
115
+ const static_ = node.static ? "static " : "";
116
+ const replacement = `${static_}${key} = ${arrowFunction}`;
117
+ return fixer.replaceText(node, replacement);
118
+ },
119
+ messageId: "preferArrowMethod",
120
+ node: node.key,
121
+ });
122
+ }
123
+ },
124
+ Property: (node) => {
125
+ if (allowMethodDefinitions) {
126
+ return;
127
+ }
128
+ if (node.method &&
129
+ node.value.type === utils_1.AST_NODE_TYPES.FunctionExpression &&
130
+ !shouldSkipFunction(node.value)) {
131
+ const fn = node.value;
132
+ context.report({
133
+ fix: (fixer) => {
134
+ const sourceCode = context.getSourceCode();
135
+ const key = sourceCode.getText(node.key);
136
+ const arrowFunction = generateArrowFunction(fn);
137
+ const replacement = `${key}: ${arrowFunction}`;
138
+ return fixer.replaceText(node, replacement);
139
+ },
140
+ messageId: "preferArrowMethod",
141
+ node: node.key,
142
+ });
143
+ }
144
+ },
145
+ };
146
+ },
147
+ defaultOptions: [
148
+ {
149
+ allowAsync: true,
150
+ allowConstructors: true,
151
+ allowFunctionDeclarations: false,
152
+ allowFunctionExpressions: false,
153
+ allowGenerators: true,
154
+ allowMethodDefinitions: false,
155
+ },
156
+ ],
157
+ meta: {
158
+ docs: {
159
+ description: "Prefer arrow functions over function declarations and expressions",
160
+ },
161
+ fixable: "code",
162
+ messages: {
163
+ preferArrowFunction: "NIMA: Prefer arrow functions over function declarations.",
164
+ preferArrowFunctionExpression: "NIMA: Prefer arrow functions over function expressions.",
165
+ preferArrowMethod: "NIMA: Prefer arrow functions over method definitions.",
166
+ },
167
+ schema: [
168
+ {
169
+ additionalProperties: false,
170
+ properties: {
171
+ allowAsync: {
172
+ default: true,
173
+ description: "Allow async functions (they can still be arrow functions)",
174
+ type: "boolean",
175
+ },
176
+ allowConstructors: {
177
+ default: true,
178
+ description: "Allow constructor functions",
179
+ type: "boolean",
180
+ },
181
+ allowFunctionDeclarations: {
182
+ default: false,
183
+ description: "Allow function declarations (function name() {})",
184
+ type: "boolean",
185
+ },
186
+ allowFunctionExpressions: {
187
+ default: false,
188
+ description: "Allow function expressions (const name = function() {})",
189
+ type: "boolean",
190
+ },
191
+ allowGenerators: {
192
+ default: true,
193
+ description: "Allow generator functions",
194
+ type: "boolean",
195
+ },
196
+ allowMethodDefinitions: {
197
+ default: false,
198
+ description: "Allow method definitions in classes and objects",
199
+ type: "boolean",
200
+ },
201
+ },
202
+ type: "object",
203
+ },
204
+ ],
205
+ type: "suggestion",
206
+ },
207
+ });
208
+ //# sourceMappingURL=prefer-arrow-functions.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"prefer-arrow-functions.js","sourceRoot":"","sources":["../../src/rules/prefer-arrow-functions.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,6 @@
1
+ import { ESLintUtils } from "@typescript-eslint/utils";
2
+ export declare const name = "prefer-react-fc";
3
+ export declare const rule: ESLintUtils.RuleModule<"requireReactFC", [{
4
+ allowArrowFunctions: boolean;
5
+ allowFunctionDeclarations: boolean;
6
+ }], unknown, ESLintUtils.RuleListener>;