UNPKG

3.5 kBJavaScriptView Raw
1"use strict";
2var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3 if (k2 === undefined) k2 = k;
4 Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });
5}) : (function(o, m, k, k2) {
6 if (k2 === undefined) k2 = k;
7 o[k2] = m[k];
8}));
9var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
10 Object.defineProperty(o, "default", { enumerable: true, value: v });
11}) : function(o, v) {
12 o["default"] = v;
13});
14var __importStar = (this && this.__importStar) || function (mod) {
15 if (mod && mod.__esModule) return mod;
16 var result = {};
17 if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
18 __setModuleDefault(result, mod);
19 return result;
20};
21Object.defineProperty(exports, "__esModule", { value: true });
22const util = __importStar(require("../util"));
23exports.default = util.createRule({
24 name: 'prefer-enum-initializers',
25 meta: {
26 type: 'suggestion',
27 docs: {
28 description: 'Prefer initializing each enums member value',
29 recommended: false,
30 suggestion: true,
31 },
32 hasSuggestions: true,
33 messages: {
34 defineInitializer: "The value of the member '{{ name }}' should be explicitly defined.",
35 defineInitializerSuggestion: 'Can be fixed to {{ name }} = {{ suggested }}',
36 },
37 schema: [],
38 },
39 defaultOptions: [],
40 create(context) {
41 const sourceCode = context.getSourceCode();
42 function TSEnumDeclaration(node) {
43 const { members } = node;
44 members.forEach((member, index) => {
45 if (member.initializer == null) {
46 const name = sourceCode.getText(member);
47 context.report({
48 node: member,
49 messageId: 'defineInitializer',
50 data: {
51 name,
52 },
53 suggest: [
54 {
55 messageId: 'defineInitializerSuggestion',
56 data: { name, suggested: index },
57 fix: (fixer) => {
58 return fixer.replaceText(member, `${name} = ${index}`);
59 },
60 },
61 {
62 messageId: 'defineInitializerSuggestion',
63 data: { name, suggested: index + 1 },
64 fix: (fixer) => {
65 return fixer.replaceText(member, `${name} = ${index + 1}`);
66 },
67 },
68 {
69 messageId: 'defineInitializerSuggestion',
70 data: { name, suggested: `'${name}'` },
71 fix: (fixer) => {
72 return fixer.replaceText(member, `${name} = '${name}'`);
73 },
74 },
75 ],
76 });
77 }
78 });
79 }
80 return {
81 TSEnumDeclaration,
82 };
83 },
84});
85//# sourceMappingURL=prefer-enum-initializers.js.map
\No newline at end of file