@fenge/eslint-config 0.5.0 → 0.5.2
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/CHANGELOG.md +22 -0
- package/README.md +5 -2
- package/dist/config/javascript.d.ts +40 -134
- package/dist/config/javascript.d.ts.map +1 -1
- package/dist/config/js/base.d.ts +40 -134
- package/dist/config/js/base.d.ts.map +1 -1
- package/dist/config/js/base.js +11 -3
- package/dist/config/ts/base.d.ts +41 -134
- package/dist/config/ts/base.d.ts.map +1 -1
- package/dist/config/ts/base.js +2 -1
- package/dist/config/typescript.d.ts +41 -134
- package/dist/config/typescript.d.ts.map +1 -1
- package/package.json +6 -6
- package/src/config/js/base.ts +10 -2
- package/src/config/ts/base.ts +1 -0
package/dist/config/ts/base.js
CHANGED
|
@@ -75,6 +75,7 @@ export function getTsBase() {
|
|
|
75
75
|
"@typescript-eslint/adjacent-overload-signatures": "error",
|
|
76
76
|
// "@typescript-eslint/array-type": ["error", 'array-simple'], // The default option is 'array'. Not very sure if we need to change the option. So disabled it.
|
|
77
77
|
"@typescript-eslint/await-thenable": "error",
|
|
78
|
+
"@typescript-eslint/class-literal-property-style": "error",
|
|
78
79
|
"@typescript-eslint/consistent-generic-constructors": "error",
|
|
79
80
|
"@typescript-eslint/consistent-indexed-object-style": "error",
|
|
80
81
|
"@typescript-eslint/consistent-type-assertions": [
|
|
@@ -203,4 +204,4 @@ export function getTsBase() {
|
|
|
203
204
|
},
|
|
204
205
|
};
|
|
205
206
|
}
|
|
206
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"base.js","sourceRoot":"","sources":["../../../src/config/ts/base.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,aAAa,MAAM,yBAAyB,CAAC;AACzD,OAAO,QAAQ,MAAM,2BAA2B,CAAC;AACjD,OAAO,EAAE,SAAS,EAAE,MAAM,eAAe,CAAC;AAE1C,MAAM,UAAU,SAAS;IACvB,MAAM,MAAM,GAAG,SAAS,EAAE,CAAC;IAE3B,MAAM,mBAAmB,GAAG,GAAG,EAAE;QAC/B,mCAAmC;QACnC,iDAAiD;QACjD,MAAM,gBAAgB,GAAG;YACvB,wBAAwB,EAAE,2CAA2C;YACrE,mBAAmB,EAAE,sCAAsC;YAC3D,oBAAoB,EAAE,uCAAuC;YAC7D,cAAc,EAAE,iCAAiC;YACjD,mBAAmB,EAAE,sCAAsC;YAC3D,YAAY,EAAE,+BAA+B;YAC7C,sBAAsB,EAAE,yCAAyC;YACjE,uBAAuB,EAAE,0CAA0C;YACnE,mBAAmB,EAAE,sCAAsC;YAC3D,iBAAiB,EAAE,oCAAoC;YACvD,iBAAiB,EAAE,oCAAoC;YACvD,cAAc,EAAE,iCAAiC;YACjD,sGAAsG;YACtG,kBAAkB,EAAE,qCAAqC;YACzD,cAAc,EAAE,iCAAiC;YACjD,uBAAuB,EAAE,0CAA0C;YACnE,WAAW,EAAE,8BAA8B;YAC3C,uBAAuB,EAAE,0CAA0C;YACnE,gBAAgB,EAAE,mCAAmC;YACrD,sBAAsB,EAAE,yCAAyC;YACjE,wBAAwB,EAAE,2CAA2C;YACrE,kBAAkB,EAAE,qCAAqC;YACzD,sBAAsB,EAAE,yCAAyC;YACjE,8BAA8B,EAC5B,iDAAiD;YACnD,eAAe,EAAE,kCAAkC;YACnD,iBAAiB,EAAE,iCAAiC,EAAE,sCAAsC;SACpF,CAAC;QAmBX,MAAM,oBAAoB,GAAG,CAC3B,GAAW,EAC2B,EAAE,CAAC,GAAG,IAAI,gBAAgB,CAAC;QACnE,OAAO,MAAM,CAAC,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,MAAM,CACxC,CAAC,MAAM,EAAE,CAAC,SAAS,EAAE,WAAW,CAAC,EAAE,EAAE,CACnC,oBAAoB,CAAC,SAAS,CAAC;YAC7B,CAAC,CAAC;gBACE,GAAG,MAAM;gBACT,CAAC,SAAS,CAAC,EAAE,KAAK;gBAClB,CAAC,gBAAgB,CAAC,SAAS,CAAC,CAAC,EAAE,WAAW;aAC3C;YACH,CAAC,CAAC,MAAM,EACZ,EAAY,CACb,CAAC;IACJ,CAAC,CAAC;IAEF,OAAO;QACL,GAAG,MAAM;QACT,IAAI,EAAE,kBAAkB;QACxB,KAAK,EAAE,CAAC,uBAAuB,CAAC;QAChC,eAAe,EAAE;YACf,GAAG,MAAM,CAAC,eAAe;YACzB,MAAM,EAAE,QAAQ,EAAE,sLAAsL;YACxM,aAAa,EAAE;gBACb,GAAG,MAAM,CAAC,eAAe,CAAC,aAAa;gBACvC,uIAAuI;gBACvI,wIAAwI;gBACxI,cAAc,EAAE,IAAI;aACrB;SACF;QACD,OAAO,EAAE;YACP,GAAG,MAAM,CAAC,OAAO;YACjB,WAAW,EAAE,aAAa;SAC3B;QACD,KAAK,EAAE;YACL,GAAG,MAAM,CAAC,KAAK;YACf,GAAG,mBAAmB,EAAE;YAExB,QAAQ;YACR,8BAA8B,EAAE,OAAO;YACvC,yBAAyB,EAAE,OAAO;YAClC,uBAAuB,EAAE,OAAO;YAChC,gCAAgC,EAAE,OAAO;YACzC,iCAAiC,EAAE,OAAO;YAC1C,kCAAkC,EAAE,OAAO;YAC3C,aAAa;YACb,iDAAiD,EAAE,OAAO;YAC1D,+JAA+J;YAC/J,mCAAmC,EAAE,OAAO;YAC5C,oDAAoD,EAAE,OAAO;YAC7D,oDAAoD,EAAE,OAAO;YAC7D,+CAA+C,EAAE;gBAC/C,OAAO;gBACP;oBACE,cAAc,EAAE,IAAI;oBACpB,2BAA2B,EAAE,oBAAoB;iBAClD;aACF;YACD,gDAAgD,EAAE,CAAC,OAAO,EAAE,WAAW,CAAC,EAAE,mCAAmC;YAC7G,4CAA4C,EAAE,OAAO;YACrD,wDAAwD;YACxD,iCAAiC,EAAE,CAAC,OAAO,EAAE,EAAE,aAAa,EAAE,IAAI,EAAE,CAAC;YACrE,2CAA2C,EAAE,OAAO;YACpD,sCAAsC,EAAE;gBACtC,OAAO;gBACP;oBACE,QAAQ,EAAE,UAAU;oBACpB,MAAM,EAAE,CAAC,WAAW,EAAE,YAAY,CAAC;iBACpC;gBACD;oBACE,QAAQ,EAAE,UAAU;oBACpB,KAAK,EAAE,CAAC,UAAU,CAAC;oBACnB,MAAM,EAAE,CAAC,WAAW,EAAE,YAAY,CAAC,EAAE,6BAA6B;iBACnE;gBACD;oBACE,QAAQ,EAAE,OAAO;oBACjB,MAAM,EAAE,CAAC,YAAY,CAAC;iBACvB;gBACD;oBACE,QAAQ,EAAE,WAAW;oBACrB,MAAM,EAAE,CAAC,YAAY,CAAC;iBACvB;gBACD;oBACE,QAAQ,EAAE,WAAW;oBACrB,MAAM,EAAE,CAAC,YAAY,CAAC;iBACvB;gBACD;oBACE,QAAQ,EAAE,eAAe;oBACzB,MAAM,EAAE,CAAC,YAAY,EAAE,YAAY,CAAC;iBACrC;aACF;YACD,oCAAoC,EAAE,OAAO;YAC7C,sCAAsC,EAAE;gBACtC,OAAO;gBACP,EAAE,gBAAgB,EAAE,EAAE,EAAE;aACzB;YACD,oDAAoD,EAAE,OAAO;YAC7D,kCAAkC,EAAE,OAAO;YAC3C,6CAA6C,EAAE,OAAO;YACtD,mDAAmD,EAAE,OAAO;YAC5D,yCAAyC,EAAE,OAAO;YAClD,gDAAgD,EAAE,OAAO;YACzD,8IAA8I;YAC9I,yCAAyC,EAAE;gBACzC,OAAO;gBACP;oBACE,UAAU,EAAE,KAAK;iBAClB;aACF;YACD,oCAAoC,EAAE,OAAO;YAC7C,gDAAgD,EAAE,OAAO;YACzD,wCAAwC,EAAE,OAAO;YACjD,yCAAyC,EAAE,OAAO;YAClD,mCAAmC,EAAE,OAAO;YAC5C,wCAAwC,EAAE,OAAO;YACjD,mCAAmC,EAAE,OAAO;YAC5C,iCAAiC,EAAE,OAAO,EAAE,kGAAkG;YAC9I,4DAA4D,EAAE,OAAO;YACrE,wDAAwD,EAAE,OAAO;YACjE,0CAA0C,EAAE,OAAO;YACnD,mDAAmD,EAAE,OAAO;YAC5D,uCAAuC,EAAE,OAAO;YAChD,uIAAuI;YACvI,6CAA6C,EAAE,OAAO;YACtD,iEAAiE,EAC/D,OAAO;YACT,uDAAuD,EAAE,OAAO,EAAE,yBAAyB;YAC3F,kDAAkD,EAAE,OAAO;YAC3D,kDAAkD,EAAE,OAAO;YAC3D,mDAAmD,EAAE,OAAO;YAC5D,kDAAkD,EAAE,OAAO;YAC3D,8CAA8C,EAAE,OAAO;YACvD,4CAA4C,EAAE,OAAO;YACrD,qCAAqC,EAAE,OAAO,EAAE,yGAAyG;YACzJ,0CAA0C,EAAE,OAAO;YACnD,4CAA4C,EAAE,OAAO;YACrD,sDAAsD,EAAE,OAAO;YAC/D,oCAAoC,EAAE,OAAO;YAC7C,yCAAyC,EAAE,OAAO;YAClD,+CAA+C,EAAE,OAAO;YACxD,6CAA6C,EAAE,OAAO;YACtD,0CAA0C,EAAE,OAAO;YACnD,oCAAoC,EAAE,OAAO;YAC7C,4CAA4C,EAAE,OAAO;YACrD,2CAA2C,EAAE;gBAC3C,OAAO;gBACP;oBACE,mBAAmB;oBACnB,YAAY,EAAE,KAAK;oBACnB,YAAY,EAAE,KAAK;oBACnB,oBAAoB,EAAE,KAAK;oBAC3B,WAAW,EAAE,KAAK;oBAClB,uBAAuB,EAAE,KAAK;iBAC/B;aACF;YACD,kDAAkD,EAAE;gBAClD,OAAO;gBACP;oBACE,KAAK,EAAE,EAAE;oBACT,mBAAmB;oBACnB,YAAY,EAAE,KAAK;oBACnB,UAAU,EAAE,KAAK;oBACjB,YAAY,EAAE,KAAK;oBACnB,WAAW,EAAE,KAAK;oBAClB,WAAW,EAAE,KAAK;iBACnB;aACF;YACD,gDAAgD,EAAE,OAAO;YACzD,iCAAiC,EAAE,CAAC,OAAO,EAAE,QAAQ,CAAC;YACtD,gDAAgD,EAAE;gBAChD,OAAO;gBACP,EAAE,yBAAyB,EAAE,IAAI,EAAE;aACpC;YACD,mCAAmC,EAAE,OAAO;YAC5C,uCAAuC,EAAE,OAAO;SACjD;KACO,CAAC;AACb,CAAC","sourcesContent":["import * as fengeTsPlugin from \"@fenge/eslint-plugin-ts\";\nimport tsParser from \"@typescript-eslint/parser\";\nimport { getJsBase } from \"../js/base.js\";\n\nexport function getTsBase() {\n  const jsBase = getJsBase();\n\n  const getTsExtensionRules = () => {\n    // Key is js rule, value is ts rule\n    // https://typescript-eslint.io/rules/?=extension\n    const extensionRuleMap = {\n      \"class-methods-use-this\": \"@typescript-eslint/class-methods-use-this\",\n      \"consistent-return\": \"@typescript-eslint/consistent-return\",\n      \"default-param-last\": \"@typescript-eslint/default-param-last\",\n      \"dot-notation\": \"@typescript-eslint/dot-notation\",\n      \"init-declarations\": \"@typescript-eslint/init-declarations\",\n      \"max-params\": \"@typescript-eslint/max-params\",\n      \"no-array-constructor\": \"@typescript-eslint/no-array-constructor\",\n      \"no-dupe-class-members\": \"@typescript-eslint/no-dupe-class-members\",\n      \"no-empty-function\": \"@typescript-eslint/no-empty-function\",\n      \"no-implied-eval\": \"@typescript-eslint/no-implied-eval\",\n      \"no-invalid-this\": \"@typescript-eslint/no-invalid-this\",\n      \"no-loop-func\": \"@typescript-eslint/no-loop-func\",\n      // \"no-loss-of-precision\": \"@typescript-eslint/no-loss-of-precision\", // This rule has been deprecated\n      \"no-magic-numbers\": \"@typescript-eslint/no-magic-numbers\",\n      \"no-redeclare\": \"@typescript-eslint/no-redeclare\",\n      \"no-restricted-imports\": \"@typescript-eslint/no-restricted-imports\",\n      \"no-shadow\": \"@typescript-eslint/no-shadow\",\n      \"no-unused-expressions\": \"@typescript-eslint/no-unused-expressions\",\n      \"no-unused-vars\": \"@typescript-eslint/no-unused-vars\",\n      \"no-use-before-define\": \"@typescript-eslint/no-use-before-define\",\n      \"no-useless-constructor\": \"@typescript-eslint/no-useless-constructor\",\n      \"no-throw-literal\": \"@typescript-eslint/only-throw-error\",\n      \"prefer-destructuring\": \"@typescript-eslint/prefer-destructuring\",\n      \"prefer-promise-reject-errors\":\n        \"@typescript-eslint/prefer-promise-reject-errors\",\n      \"require-await\": \"@typescript-eslint/require-await\",\n      \"no-return-await\": \"@typescript-eslint/return-await\", // no-return-await has been deprecated\n    } as const;\n\n    type Js2TsRuleMap = typeof extensionRuleMap;\n    type Ts2JsRuleMap = {\n      [K in keyof Js2TsRuleMap as Js2TsRuleMap[K]]: K; // reverse\n    };\n\n    type JsExtensionKey = Extract<\n      keyof Js2TsRuleMap,\n      keyof typeof jsBase.rules\n    >; // Extract\n    type TsExtensionKey = Js2TsRuleMap[JsExtensionKey];\n\n    type JsResult = Record<JsExtensionKey, \"off\">;\n    type TsResult = {\n      [Key in TsExtensionKey]: (typeof jsBase.rules)[Ts2JsRuleMap[Key]];\n    };\n    type Result = JsResult & TsResult;\n\n    const isInExtensionRuleMap = (\n      key: string,\n    ): key is keyof typeof extensionRuleMap => key in extensionRuleMap;\n    return Object.entries(jsBase.rules).reduce(\n      (result, [jsRuleKey, jsRuleValue]) =>\n        isInExtensionRuleMap(jsRuleKey)\n          ? {\n              ...result,\n              [jsRuleKey]: \"off\",\n              [extensionRuleMap[jsRuleKey]]: jsRuleValue,\n            }\n          : result,\n      {} as Result,\n    );\n  };\n\n  return {\n    ...jsBase,\n    name: \"fenge/typescript\",\n    files: [\"**/*.{ts,cts,mts,tsx}\"],\n    languageOptions: {\n      ...jsBase.languageOptions,\n      parser: tsParser, // Unfortunately parser cannot be a string. Eslint should support it. https://eslint.org/docs/latest/use/configure/configuration-files-new#configuring-a-custom-parser-and-its-options\n      parserOptions: {\n        ...jsBase.languageOptions.parserOptions,\n        // Setting `projectService: true` or `project: true` is pretty slow when lint a monorepo with many tsconfig.json files in each sub-app.\n        // But setting `project: \"tsconfig.json\"` will cause parser error when the project root tsconfig.json is `{ extends: \"fenge/tsconfig\" }`\n        projectService: true,\n      },\n    },\n    plugins: {\n      ...jsBase.plugins,\n      \"@fenge-ts\": fengeTsPlugin,\n    },\n    rules: {\n      ...jsBase.rules,\n      ...getTsExtensionRules(),\n\n      // fenge\n      \"@fenge-ts/exact-map-set-type\": \"error\",\n      \"@fenge-ts/no-const-enum\": \"error\",\n      \"@fenge-ts/no-declares\": \"error\",\n      \"@fenge-ts/no-export-assignment\": \"error\",\n      \"@fenge-ts/no-property-decorator\": \"error\",\n      \"@fenge-ts/no-untyped-empty-array\": \"error\",\n      // typescript\n      \"@typescript-eslint/adjacent-overload-signatures\": \"error\",\n      // \"@typescript-eslint/array-type\": [\"error\", 'array-simple'], // The default option is 'array'. Not very sure if we need to change the option. So disabled it.\n      \"@typescript-eslint/await-thenable\": \"error\",\n      \"@typescript-eslint/consistent-generic-constructors\": \"error\",\n      \"@typescript-eslint/consistent-indexed-object-style\": \"error\",\n      \"@typescript-eslint/consistent-type-assertions\": [\n        \"error\",\n        {\n          assertionStyle: \"as\",\n          objectLiteralTypeAssertions: \"allow-as-parameter\",\n        },\n      ],\n      \"@typescript-eslint/consistent-type-definitions\": [\"error\", \"interface\"], // TODO should we change to 'type'?\n      \"@typescript-eslint/consistent-type-exports\": \"error\",\n      // \"@typescript-eslint/consistent-type-imports\": \"error,\n      \"@typescript-eslint/dot-notation\": [\"error\", { allowKeywords: true }],\n      \"@typescript-eslint/method-signature-style\": \"error\",\n      \"@typescript-eslint/naming-convention\": [\n        \"error\",\n        {\n          selector: \"function\",\n          format: [\"camelCase\", \"PascalCase\"],\n        },\n        {\n          selector: \"variable\",\n          types: [\"function\"],\n          format: [\"camelCase\", \"PascalCase\"], // decorators need PascalCase\n        },\n        {\n          selector: \"class\",\n          format: [\"PascalCase\"],\n        },\n        {\n          selector: \"interface\",\n          format: [\"PascalCase\"],\n        },\n        {\n          selector: \"typeAlias\",\n          format: [\"PascalCase\"],\n        },\n        {\n          selector: \"typeParameter\",\n          format: [\"UPPER_CASE\", \"PascalCase\"],\n        },\n      ],\n      \"@typescript-eslint/no-array-delete\": \"error\",\n      \"@typescript-eslint/no-base-to-string\": [\n        \"error\",\n        { ignoredTypeNames: [] },\n      ],\n      \"@typescript-eslint/no-confusing-non-null-assertion\": \"error\",\n      \"@typescript-eslint/no-deprecated\": \"error\",\n      \"@typescript-eslint/no-duplicate-enum-values\": \"error\",\n      \"@typescript-eslint/no-duplicate-type-constituents\": \"error\",\n      \"@typescript-eslint/no-empty-object-type\": \"error\",\n      \"@typescript-eslint/no-extra-non-null-assertion\": \"error\",\n      // \"@typescript-eslint/no-extraneous-class\": \"error\", // Classes have only static member is reasonable sometimes. Nestjs modules use it a lot.\n      \"@typescript-eslint/no-floating-promises\": [\n        \"error\",\n        {\n          ignoreVoid: false,\n        },\n      ],\n      \"@typescript-eslint/no-for-in-array\": \"error\",\n      \"@typescript-eslint/no-import-type-side-effects\": \"error\",\n      \"@typescript-eslint/no-inferrable-types\": \"error\",\n      \"@typescript-eslint/no-invalid-void-type\": \"error\",\n      \"@typescript-eslint/no-misused-new\": \"error\",\n      \"@typescript-eslint/no-misused-promises\": \"error\",\n      \"@typescript-eslint/no-mixed-enums\": \"error\",\n      \"@typescript-eslint/no-namespace\": \"error\", // consider to add option `{\"allowDefinitionFiles\": false}` to strictly forbid `namespace` keyword\n      \"@typescript-eslint/no-non-null-asserted-nullish-coalescing\": \"error\",\n      \"@typescript-eslint/no-non-null-asserted-optional-chain\": \"error\",\n      \"@typescript-eslint/no-non-null-assertion\": \"error\",\n      \"@typescript-eslint/no-redundant-type-constituents\": \"error\",\n      \"@typescript-eslint/no-require-imports\": \"error\",\n      // \"@typescript-eslint/no-unnecessary-boolean-literal-compare\": \"error\", // unsafe when `strictNullChecks` in tsconfig.json is disabled\n      \"@typescript-eslint/no-unnecessary-condition\": \"error\",\n      \"@typescript-eslint/no-unnecessary-parameter-property-assignment\":\n        \"error\",\n      \"@typescript-eslint/no-unnecessary-template-expression\": \"error\", // js also need this rule\n      \"@typescript-eslint/no-unnecessary-type-arguments\": \"error\",\n      \"@typescript-eslint/no-unnecessary-type-assertion\": \"error\",\n      \"@typescript-eslint/no-unnecessary-type-constraint\": \"error\",\n      \"@typescript-eslint/no-unsafe-declaration-merging\": \"error\",\n      \"@typescript-eslint/no-unsafe-enum-comparison\": \"error\",\n      \"@typescript-eslint/no-unsafe-function-type\": \"error\",\n      \"@typescript-eslint/no-unsafe-return\": \"error\", // This rule is not very perfect. See https://github.com/typescript-eslint/typescript-eslint/issues/10439\n      \"@typescript-eslint/no-unsafe-unary-minus\": \"error\",\n      \"@typescript-eslint/no-wrapper-object-types\": \"error\",\n      \"@typescript-eslint/non-nullable-type-assertion-style\": \"error\",\n      \"@typescript-eslint/prefer-as-const\": \"error\",\n      \"@typescript-eslint/prefer-function-type\": \"error\",\n      \"@typescript-eslint/prefer-literal-enum-member\": \"error\",\n      \"@typescript-eslint/prefer-namespace-keyword\": \"error\",\n      \"@typescript-eslint/prefer-optional-chain\": \"error\",\n      \"@typescript-eslint/prefer-readonly\": \"error\",\n      \"@typescript-eslint/prefer-return-this-type\": \"error\",\n      \"@typescript-eslint/restrict-plus-operands\": [\n        \"error\",\n        {\n          // allowAny: false,\n          allowBoolean: false,\n          allowNullish: false,\n          allowNumberAndString: false,\n          allowRegExp: false,\n          skipCompoundAssignments: false,\n        },\n      ],\n      \"@typescript-eslint/restrict-template-expressions\": [\n        \"error\",\n        {\n          allow: [],\n          // allowAny: false,\n          allowBoolean: false,\n          allowNever: false,\n          allowNullish: false,\n          allowNumber: false,\n          allowRegExp: false,\n        },\n      ],\n      \"@typescript-eslint/related-getter-setter-pairs\": \"error\",\n      \"@typescript-eslint/return-await\": [\"error\", \"always\"],\n      \"@typescript-eslint/switch-exhaustiveness-check\": [\n        \"error\",\n        { requireDefaultForNonUnion: true },\n      ],\n      \"@typescript-eslint/unbound-method\": \"error\",\n      \"@typescript-eslint/unified-signatures\": \"error\",\n    },\n  } as const;\n}\n"]}
|
|
207
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"base.js","sourceRoot":"","sources":["../../../src/config/ts/base.ts"],"names":[],"mappings":"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","sourcesContent":["import * as fengeTsPlugin from \"@fenge/eslint-plugin-ts\";\nimport tsParser from \"@typescript-eslint/parser\";\nimport { getJsBase } from \"../js/base.js\";\n\nexport function getTsBase() {\n  const jsBase = getJsBase();\n\n  const getTsExtensionRules = () => {\n    // Key is js rule, value is ts rule\n    // https://typescript-eslint.io/rules/?=extension\n    const extensionRuleMap = {\n      \"class-methods-use-this\": \"@typescript-eslint/class-methods-use-this\",\n      \"consistent-return\": \"@typescript-eslint/consistent-return\",\n      \"default-param-last\": \"@typescript-eslint/default-param-last\",\n      \"dot-notation\": \"@typescript-eslint/dot-notation\",\n      \"init-declarations\": \"@typescript-eslint/init-declarations\",\n      \"max-params\": \"@typescript-eslint/max-params\",\n      \"no-array-constructor\": \"@typescript-eslint/no-array-constructor\",\n      \"no-dupe-class-members\": \"@typescript-eslint/no-dupe-class-members\",\n      \"no-empty-function\": \"@typescript-eslint/no-empty-function\",\n      \"no-implied-eval\": \"@typescript-eslint/no-implied-eval\",\n      \"no-invalid-this\": \"@typescript-eslint/no-invalid-this\",\n      \"no-loop-func\": \"@typescript-eslint/no-loop-func\",\n      // \"no-loss-of-precision\": \"@typescript-eslint/no-loss-of-precision\", // This rule has been deprecated\n      \"no-magic-numbers\": \"@typescript-eslint/no-magic-numbers\",\n      \"no-redeclare\": \"@typescript-eslint/no-redeclare\",\n      \"no-restricted-imports\": \"@typescript-eslint/no-restricted-imports\",\n      \"no-shadow\": \"@typescript-eslint/no-shadow\",\n      \"no-unused-expressions\": \"@typescript-eslint/no-unused-expressions\",\n      \"no-unused-vars\": \"@typescript-eslint/no-unused-vars\",\n      \"no-use-before-define\": \"@typescript-eslint/no-use-before-define\",\n      \"no-useless-constructor\": \"@typescript-eslint/no-useless-constructor\",\n      \"no-throw-literal\": \"@typescript-eslint/only-throw-error\",\n      \"prefer-destructuring\": \"@typescript-eslint/prefer-destructuring\",\n      \"prefer-promise-reject-errors\":\n        \"@typescript-eslint/prefer-promise-reject-errors\",\n      \"require-await\": \"@typescript-eslint/require-await\",\n      \"no-return-await\": \"@typescript-eslint/return-await\", // no-return-await has been deprecated\n    } as const;\n\n    type Js2TsRuleMap = typeof extensionRuleMap;\n    type Ts2JsRuleMap = {\n      [K in keyof Js2TsRuleMap as Js2TsRuleMap[K]]: K; // reverse\n    };\n\n    type JsExtensionKey = Extract<\n      keyof Js2TsRuleMap,\n      keyof typeof jsBase.rules\n    >; // Extract\n    type TsExtensionKey = Js2TsRuleMap[JsExtensionKey];\n\n    type JsResult = Record<JsExtensionKey, \"off\">;\n    type TsResult = {\n      [Key in TsExtensionKey]: (typeof jsBase.rules)[Ts2JsRuleMap[Key]];\n    };\n    type Result = JsResult & TsResult;\n\n    const isInExtensionRuleMap = (\n      key: string,\n    ): key is keyof typeof extensionRuleMap => key in extensionRuleMap;\n    return Object.entries(jsBase.rules).reduce(\n      (result, [jsRuleKey, jsRuleValue]) =>\n        isInExtensionRuleMap(jsRuleKey)\n          ? {\n              ...result,\n              [jsRuleKey]: \"off\",\n              [extensionRuleMap[jsRuleKey]]: jsRuleValue,\n            }\n          : result,\n      {} as Result,\n    );\n  };\n\n  return {\n    ...jsBase,\n    name: \"fenge/typescript\",\n    files: [\"**/*.{ts,cts,mts,tsx}\"],\n    languageOptions: {\n      ...jsBase.languageOptions,\n      parser: tsParser, // Unfortunately parser cannot be a string. Eslint should support it. https://eslint.org/docs/latest/use/configure/configuration-files-new#configuring-a-custom-parser-and-its-options\n      parserOptions: {\n        ...jsBase.languageOptions.parserOptions,\n        // Setting `projectService: true` or `project: true` is pretty slow when lint a monorepo with many tsconfig.json files in each sub-app.\n        // But setting `project: \"tsconfig.json\"` will cause parser error when the project root tsconfig.json is `{ extends: \"fenge/tsconfig\" }`\n        projectService: true,\n      },\n    },\n    plugins: {\n      ...jsBase.plugins,\n      \"@fenge-ts\": fengeTsPlugin,\n    },\n    rules: {\n      ...jsBase.rules,\n      ...getTsExtensionRules(),\n\n      // fenge\n      \"@fenge-ts/exact-map-set-type\": \"error\",\n      \"@fenge-ts/no-const-enum\": \"error\",\n      \"@fenge-ts/no-declares\": \"error\",\n      \"@fenge-ts/no-export-assignment\": \"error\",\n      \"@fenge-ts/no-property-decorator\": \"error\",\n      \"@fenge-ts/no-untyped-empty-array\": \"error\",\n      // typescript\n      \"@typescript-eslint/adjacent-overload-signatures\": \"error\",\n      // \"@typescript-eslint/array-type\": [\"error\", 'array-simple'], // The default option is 'array'. Not very sure if we need to change the option. So disabled it.\n      \"@typescript-eslint/await-thenable\": \"error\",\n      \"@typescript-eslint/class-literal-property-style\": \"error\",\n      \"@typescript-eslint/consistent-generic-constructors\": \"error\",\n      \"@typescript-eslint/consistent-indexed-object-style\": \"error\",\n      \"@typescript-eslint/consistent-type-assertions\": [\n        \"error\",\n        {\n          assertionStyle: \"as\",\n          objectLiteralTypeAssertions: \"allow-as-parameter\",\n        },\n      ],\n      \"@typescript-eslint/consistent-type-definitions\": [\"error\", \"interface\"], // TODO should we change to 'type'?\n      \"@typescript-eslint/consistent-type-exports\": \"error\",\n      // \"@typescript-eslint/consistent-type-imports\": \"error,\n      \"@typescript-eslint/dot-notation\": [\"error\", { allowKeywords: true }],\n      \"@typescript-eslint/method-signature-style\": \"error\",\n      \"@typescript-eslint/naming-convention\": [\n        \"error\",\n        {\n          selector: \"function\",\n          format: [\"camelCase\", \"PascalCase\"],\n        },\n        {\n          selector: \"variable\",\n          types: [\"function\"],\n          format: [\"camelCase\", \"PascalCase\"], // decorators need PascalCase\n        },\n        {\n          selector: \"class\",\n          format: [\"PascalCase\"],\n        },\n        {\n          selector: \"interface\",\n          format: [\"PascalCase\"],\n        },\n        {\n          selector: \"typeAlias\",\n          format: [\"PascalCase\"],\n        },\n        {\n          selector: \"typeParameter\",\n          format: [\"UPPER_CASE\", \"PascalCase\"],\n        },\n      ],\n      \"@typescript-eslint/no-array-delete\": \"error\",\n      \"@typescript-eslint/no-base-to-string\": [\n        \"error\",\n        { ignoredTypeNames: [] },\n      ],\n      \"@typescript-eslint/no-confusing-non-null-assertion\": \"error\",\n      \"@typescript-eslint/no-deprecated\": \"error\",\n      \"@typescript-eslint/no-duplicate-enum-values\": \"error\",\n      \"@typescript-eslint/no-duplicate-type-constituents\": \"error\",\n      \"@typescript-eslint/no-empty-object-type\": \"error\",\n      \"@typescript-eslint/no-extra-non-null-assertion\": \"error\",\n      // \"@typescript-eslint/no-extraneous-class\": \"error\", // Classes have only static member is reasonable sometimes. Nestjs modules use it a lot.\n      \"@typescript-eslint/no-floating-promises\": [\n        \"error\",\n        {\n          ignoreVoid: false,\n        },\n      ],\n      \"@typescript-eslint/no-for-in-array\": \"error\",\n      \"@typescript-eslint/no-import-type-side-effects\": \"error\",\n      \"@typescript-eslint/no-inferrable-types\": \"error\",\n      \"@typescript-eslint/no-invalid-void-type\": \"error\",\n      \"@typescript-eslint/no-misused-new\": \"error\",\n      \"@typescript-eslint/no-misused-promises\": \"error\",\n      \"@typescript-eslint/no-mixed-enums\": \"error\",\n      \"@typescript-eslint/no-namespace\": \"error\", // consider to add option `{\"allowDefinitionFiles\": false}` to strictly forbid `namespace` keyword\n      \"@typescript-eslint/no-non-null-asserted-nullish-coalescing\": \"error\",\n      \"@typescript-eslint/no-non-null-asserted-optional-chain\": \"error\",\n      \"@typescript-eslint/no-non-null-assertion\": \"error\",\n      \"@typescript-eslint/no-redundant-type-constituents\": \"error\",\n      \"@typescript-eslint/no-require-imports\": \"error\",\n      // \"@typescript-eslint/no-unnecessary-boolean-literal-compare\": \"error\", // unsafe when `strictNullChecks` in tsconfig.json is disabled\n      \"@typescript-eslint/no-unnecessary-condition\": \"error\",\n      \"@typescript-eslint/no-unnecessary-parameter-property-assignment\":\n        \"error\",\n      \"@typescript-eslint/no-unnecessary-template-expression\": \"error\", // js also need this rule\n      \"@typescript-eslint/no-unnecessary-type-arguments\": \"error\",\n      \"@typescript-eslint/no-unnecessary-type-assertion\": \"error\",\n      \"@typescript-eslint/no-unnecessary-type-constraint\": \"error\",\n      \"@typescript-eslint/no-unsafe-declaration-merging\": \"error\",\n      \"@typescript-eslint/no-unsafe-enum-comparison\": \"error\",\n      \"@typescript-eslint/no-unsafe-function-type\": \"error\",\n      \"@typescript-eslint/no-unsafe-return\": \"error\", // This rule is not very perfect. See https://github.com/typescript-eslint/typescript-eslint/issues/10439\n      \"@typescript-eslint/no-unsafe-unary-minus\": \"error\",\n      \"@typescript-eslint/no-wrapper-object-types\": \"error\",\n      \"@typescript-eslint/non-nullable-type-assertion-style\": \"error\",\n      \"@typescript-eslint/prefer-as-const\": \"error\",\n      \"@typescript-eslint/prefer-function-type\": \"error\",\n      \"@typescript-eslint/prefer-literal-enum-member\": \"error\",\n      \"@typescript-eslint/prefer-namespace-keyword\": \"error\",\n      \"@typescript-eslint/prefer-optional-chain\": \"error\",\n      \"@typescript-eslint/prefer-readonly\": \"error\",\n      \"@typescript-eslint/prefer-return-this-type\": \"error\",\n      \"@typescript-eslint/restrict-plus-operands\": [\n        \"error\",\n        {\n          // allowAny: false,\n          allowBoolean: false,\n          allowNullish: false,\n          allowNumberAndString: false,\n          allowRegExp: false,\n          skipCompoundAssignments: false,\n        },\n      ],\n      \"@typescript-eslint/restrict-template-expressions\": [\n        \"error\",\n        {\n          allow: [],\n          // allowAny: false,\n          allowBoolean: false,\n          allowNever: false,\n          allowNullish: false,\n          allowNumber: false,\n          allowRegExp: false,\n        },\n      ],\n      \"@typescript-eslint/related-getter-setter-pairs\": \"error\",\n      \"@typescript-eslint/return-await\": [\"error\", \"always\"],\n      \"@typescript-eslint/switch-exhaustiveness-check\": [\n        \"error\",\n        { requireDefaultForNonUnion: true },\n      ],\n      \"@typescript-eslint/unbound-method\": \"error\",\n      \"@typescript-eslint/unified-signatures\": \"error\",\n    },\n  } as const;\n}\n"]}
|
|
@@ -38,27 +38,7 @@ export declare function typescript(): readonly [{
|
|
|
38
38
|
'forbid-elements': import("eslint").Rule.RuleModule;
|
|
39
39
|
'forbid-foreign-prop-types': import("eslint").Rule.RuleModule;
|
|
40
40
|
'forbid-prop-types': import("eslint").Rule.RuleModule;
|
|
41
|
-
'forward-ref-uses-ref':
|
|
42
|
-
meta: {
|
|
43
|
-
docs: {
|
|
44
|
-
description: string;
|
|
45
|
-
category: string;
|
|
46
|
-
recommended: boolean;
|
|
47
|
-
url: string;
|
|
48
|
-
};
|
|
49
|
-
messages: {
|
|
50
|
-
missingRefParameter: string;
|
|
51
|
-
addRefParameter: string;
|
|
52
|
-
removeForwardRef: string;
|
|
53
|
-
};
|
|
54
|
-
schema: undefined[];
|
|
55
|
-
type: string;
|
|
56
|
-
hasSuggestions: boolean;
|
|
57
|
-
};
|
|
58
|
-
create(context: any): {
|
|
59
|
-
"FunctionExpression, ArrowFunctionExpression"(node: any): void;
|
|
60
|
-
};
|
|
61
|
-
};
|
|
41
|
+
'forward-ref-uses-ref': import("eslint").Rule.RuleModule;
|
|
62
42
|
'function-component-definition': import("eslint").Rule.RuleModule;
|
|
63
43
|
'hook-use-state': import("eslint").Rule.RuleModule;
|
|
64
44
|
'iframe-missing-sandbox': import("eslint").Rule.RuleModule;
|
|
@@ -83,23 +63,7 @@ export declare function typescript(): readonly [{
|
|
|
83
63
|
'jsx-no-constructed-context-values': import("eslint").Rule.RuleModule;
|
|
84
64
|
'jsx-no-duplicate-props': import("eslint").Rule.RuleModule;
|
|
85
65
|
'jsx-no-leaked-render': import("eslint").Rule.RuleModule;
|
|
86
|
-
'jsx-no-literals':
|
|
87
|
-
meta: import("eslint").Rule.RuleMetaData;
|
|
88
|
-
create(context: any): (false & {
|
|
89
|
-
Literal(node: any): void;
|
|
90
|
-
JSXAttribute(node: any): void;
|
|
91
|
-
JSXText(node: any): void;
|
|
92
|
-
TemplateLiteral(node: any): void;
|
|
93
|
-
}) | ({
|
|
94
|
-
ImportDeclaration(node: any): void;
|
|
95
|
-
VariableDeclaration(node: any): void;
|
|
96
|
-
} & {
|
|
97
|
-
Literal(node: any): void;
|
|
98
|
-
JSXAttribute(node: any): void;
|
|
99
|
-
JSXText(node: any): void;
|
|
100
|
-
TemplateLiteral(node: any): void;
|
|
101
|
-
});
|
|
102
|
-
};
|
|
66
|
+
'jsx-no-literals': import("eslint").Rule.RuleModule;
|
|
103
67
|
'jsx-no-script-url': import("eslint").Rule.RuleModule;
|
|
104
68
|
'jsx-no-target-blank': import("eslint").Rule.RuleModule;
|
|
105
69
|
'jsx-no-useless-fragment': import("eslint").Rule.RuleModule;
|
|
@@ -110,22 +74,7 @@ export declare function typescript(): readonly [{
|
|
|
110
74
|
'jsx-fragments': import("eslint").Rule.RuleModule;
|
|
111
75
|
'jsx-props-no-multi-spaces': import("eslint").Rule.RuleModule;
|
|
112
76
|
'jsx-props-no-spreading': import("eslint").Rule.RuleModule;
|
|
113
|
-
'jsx-props-no-spread-multi':
|
|
114
|
-
meta: {
|
|
115
|
-
docs: {
|
|
116
|
-
description: string;
|
|
117
|
-
category: string;
|
|
118
|
-
recommended: boolean;
|
|
119
|
-
url: string;
|
|
120
|
-
};
|
|
121
|
-
messages: {
|
|
122
|
-
noMultiSpreading: string;
|
|
123
|
-
};
|
|
124
|
-
};
|
|
125
|
-
create(context: any): {
|
|
126
|
-
JSXOpeningElement(node: any): void;
|
|
127
|
-
};
|
|
128
|
-
};
|
|
77
|
+
'jsx-props-no-spread-multi': import("eslint").Rule.RuleModule;
|
|
129
78
|
'jsx-sort-default-props': import("eslint").Rule.RuleModule;
|
|
130
79
|
'jsx-sort-props': import("eslint").Rule.RuleModule;
|
|
131
80
|
'jsx-space-before-closing': import("eslint").Rule.RuleModule;
|
|
@@ -194,27 +143,7 @@ export declare function typescript(): readonly [{
|
|
|
194
143
|
'forbid-elements': import("eslint").Rule.RuleModule;
|
|
195
144
|
'forbid-foreign-prop-types': import("eslint").Rule.RuleModule;
|
|
196
145
|
'forbid-prop-types': import("eslint").Rule.RuleModule;
|
|
197
|
-
'forward-ref-uses-ref':
|
|
198
|
-
meta: {
|
|
199
|
-
docs: {
|
|
200
|
-
description: string;
|
|
201
|
-
category: string;
|
|
202
|
-
recommended: boolean;
|
|
203
|
-
url: string;
|
|
204
|
-
};
|
|
205
|
-
messages: {
|
|
206
|
-
missingRefParameter: string;
|
|
207
|
-
addRefParameter: string;
|
|
208
|
-
removeForwardRef: string;
|
|
209
|
-
};
|
|
210
|
-
schema: undefined[];
|
|
211
|
-
type: string;
|
|
212
|
-
hasSuggestions: boolean;
|
|
213
|
-
};
|
|
214
|
-
create(context: any): {
|
|
215
|
-
"FunctionExpression, ArrowFunctionExpression"(node: any): void;
|
|
216
|
-
};
|
|
217
|
-
};
|
|
146
|
+
'forward-ref-uses-ref': import("eslint").Rule.RuleModule;
|
|
218
147
|
'function-component-definition': import("eslint").Rule.RuleModule;
|
|
219
148
|
'hook-use-state': import("eslint").Rule.RuleModule;
|
|
220
149
|
'iframe-missing-sandbox': import("eslint").Rule.RuleModule;
|
|
@@ -239,23 +168,7 @@ export declare function typescript(): readonly [{
|
|
|
239
168
|
'jsx-no-constructed-context-values': import("eslint").Rule.RuleModule;
|
|
240
169
|
'jsx-no-duplicate-props': import("eslint").Rule.RuleModule;
|
|
241
170
|
'jsx-no-leaked-render': import("eslint").Rule.RuleModule;
|
|
242
|
-
'jsx-no-literals':
|
|
243
|
-
meta: import("eslint").Rule.RuleMetaData;
|
|
244
|
-
create(context: any): (false & {
|
|
245
|
-
Literal(node: any): void;
|
|
246
|
-
JSXAttribute(node: any): void;
|
|
247
|
-
JSXText(node: any): void;
|
|
248
|
-
TemplateLiteral(node: any): void;
|
|
249
|
-
}) | ({
|
|
250
|
-
ImportDeclaration(node: any): void;
|
|
251
|
-
VariableDeclaration(node: any): void;
|
|
252
|
-
} & {
|
|
253
|
-
Literal(node: any): void;
|
|
254
|
-
JSXAttribute(node: any): void;
|
|
255
|
-
JSXText(node: any): void;
|
|
256
|
-
TemplateLiteral(node: any): void;
|
|
257
|
-
});
|
|
258
|
-
};
|
|
171
|
+
'jsx-no-literals': import("eslint").Rule.RuleModule;
|
|
259
172
|
'jsx-no-script-url': import("eslint").Rule.RuleModule;
|
|
260
173
|
'jsx-no-target-blank': import("eslint").Rule.RuleModule;
|
|
261
174
|
'jsx-no-useless-fragment': import("eslint").Rule.RuleModule;
|
|
@@ -266,22 +179,7 @@ export declare function typescript(): readonly [{
|
|
|
266
179
|
'jsx-fragments': import("eslint").Rule.RuleModule;
|
|
267
180
|
'jsx-props-no-multi-spaces': import("eslint").Rule.RuleModule;
|
|
268
181
|
'jsx-props-no-spreading': import("eslint").Rule.RuleModule;
|
|
269
|
-
'jsx-props-no-spread-multi':
|
|
270
|
-
meta: {
|
|
271
|
-
docs: {
|
|
272
|
-
description: string;
|
|
273
|
-
category: string;
|
|
274
|
-
recommended: boolean;
|
|
275
|
-
url: string;
|
|
276
|
-
};
|
|
277
|
-
messages: {
|
|
278
|
-
noMultiSpreading: string;
|
|
279
|
-
};
|
|
280
|
-
};
|
|
281
|
-
create(context: any): {
|
|
282
|
-
JSXOpeningElement(node: any): void;
|
|
283
|
-
};
|
|
284
|
-
};
|
|
182
|
+
'jsx-props-no-spread-multi': import("eslint").Rule.RuleModule;
|
|
285
183
|
'jsx-sort-default-props': import("eslint").Rule.RuleModule;
|
|
286
184
|
'jsx-sort-props': import("eslint").Rule.RuleModule;
|
|
287
185
|
'jsx-space-before-closing': import("eslint").Rule.RuleModule;
|
|
@@ -347,28 +245,28 @@ export declare function typescript(): readonly [{
|
|
|
347
245
|
};
|
|
348
246
|
};
|
|
349
247
|
rules: {
|
|
350
|
-
"react/display-name":
|
|
351
|
-
"react/jsx-key":
|
|
352
|
-
"react/jsx-no-comment-textnodes":
|
|
353
|
-
"react/jsx-no-duplicate-props":
|
|
354
|
-
"react/jsx-no-target-blank":
|
|
355
|
-
"react/jsx-no-undef":
|
|
356
|
-
"react/jsx-uses-react":
|
|
357
|
-
"react/jsx-uses-vars":
|
|
358
|
-
"react/no-children-prop":
|
|
359
|
-
"react/no-danger-with-children":
|
|
360
|
-
"react/no-deprecated":
|
|
361
|
-
"react/no-direct-mutation-state":
|
|
362
|
-
"react/no-find-dom-node":
|
|
363
|
-
"react/no-is-mounted":
|
|
364
|
-
"react/no-render-return-value":
|
|
365
|
-
"react/no-string-refs":
|
|
366
|
-
"react/no-unescaped-entities":
|
|
367
|
-
"react/no-unknown-property":
|
|
368
|
-
"react/no-unsafe":
|
|
369
|
-
"react/prop-types":
|
|
370
|
-
"react/react-in-jsx-scope":
|
|
371
|
-
"react/require-render-return":
|
|
248
|
+
"react/display-name": 2;
|
|
249
|
+
"react/jsx-key": 2;
|
|
250
|
+
"react/jsx-no-comment-textnodes": 2;
|
|
251
|
+
"react/jsx-no-duplicate-props": 2;
|
|
252
|
+
"react/jsx-no-target-blank": 2;
|
|
253
|
+
"react/jsx-no-undef": 2;
|
|
254
|
+
"react/jsx-uses-react": 2;
|
|
255
|
+
"react/jsx-uses-vars": 2;
|
|
256
|
+
"react/no-children-prop": 2;
|
|
257
|
+
"react/no-danger-with-children": 2;
|
|
258
|
+
"react/no-deprecated": 2;
|
|
259
|
+
"react/no-direct-mutation-state": 2;
|
|
260
|
+
"react/no-find-dom-node": 2;
|
|
261
|
+
"react/no-is-mounted": 2;
|
|
262
|
+
"react/no-render-return-value": 2;
|
|
263
|
+
"react/no-string-refs": 2;
|
|
264
|
+
"react/no-unescaped-entities": 2;
|
|
265
|
+
"react/no-unknown-property": 2;
|
|
266
|
+
"react/no-unsafe": 0;
|
|
267
|
+
"react/prop-types": 2;
|
|
268
|
+
"react/react-in-jsx-scope": 2;
|
|
269
|
+
"react/require-render-return": 2;
|
|
372
270
|
};
|
|
373
271
|
};
|
|
374
272
|
all: {
|
|
@@ -389,8 +287,8 @@ export declare function typescript(): readonly [{
|
|
|
389
287
|
jsxPragma: any;
|
|
390
288
|
};
|
|
391
289
|
rules: {
|
|
392
|
-
"react/react-in-jsx-scope":
|
|
393
|
-
"react/jsx-uses-react":
|
|
290
|
+
"react/react-in-jsx-scope": 0;
|
|
291
|
+
"react/jsx-uses-react": 0;
|
|
394
292
|
};
|
|
395
293
|
};
|
|
396
294
|
} & {
|
|
@@ -426,6 +324,7 @@ export declare function typescript(): readonly [{
|
|
|
426
324
|
readonly "@fenge-ts/no-untyped-empty-array": "error";
|
|
427
325
|
readonly "@typescript-eslint/adjacent-overload-signatures": "error";
|
|
428
326
|
readonly "@typescript-eslint/await-thenable": "error";
|
|
327
|
+
readonly "@typescript-eslint/class-literal-property-style": "error";
|
|
429
328
|
readonly "@typescript-eslint/consistent-generic-constructors": "error";
|
|
430
329
|
readonly "@typescript-eslint/consistent-indexed-object-style": "error";
|
|
431
330
|
readonly "@typescript-eslint/consistent-type-assertions": readonly ["error", {
|
|
@@ -588,7 +487,14 @@ export declare function typescript(): readonly [{
|
|
|
588
487
|
readonly "unicorn/prefer-node-protocol": "error";
|
|
589
488
|
readonly "unicorn/escape-case": "error";
|
|
590
489
|
readonly "func-name-matching": "error";
|
|
490
|
+
readonly "func-names": "error";
|
|
491
|
+
readonly "func-style": readonly ["error", "declaration", {
|
|
492
|
+
readonly allowArrowFunctions: true;
|
|
493
|
+
}];
|
|
591
494
|
readonly "getter-return": "error";
|
|
495
|
+
readonly "logical-assignment-operators": readonly ["error", "always", {
|
|
496
|
+
readonly enforceForIfStatements: true;
|
|
497
|
+
}];
|
|
592
498
|
readonly "max-depth": readonly ["error", {
|
|
593
499
|
readonly max: 5;
|
|
594
500
|
}];
|
|
@@ -602,6 +508,7 @@ export declare function typescript(): readonly [{
|
|
|
602
508
|
readonly disallowTemplateShorthand: true;
|
|
603
509
|
readonly allow: readonly ["!!"];
|
|
604
510
|
}];
|
|
511
|
+
readonly "no-inner-declarations": "error";
|
|
605
512
|
readonly "no-lonely-if": "error";
|
|
606
513
|
readonly "no-multi-assign": "error";
|
|
607
514
|
readonly "no-new-native-nonconstructor": "error";
|
|
@@ -627,7 +534,6 @@ export declare function typescript(): readonly [{
|
|
|
627
534
|
readonly "es-x/no-hashbang": "error";
|
|
628
535
|
readonly "es-x/no-legacy-object-prototype-accessor-methods": "error";
|
|
629
536
|
readonly "es-x/no-top-level-await": "error";
|
|
630
|
-
readonly "esm/nearest-relative-path": "error";
|
|
631
537
|
readonly "esm/no-directory-imports": "error";
|
|
632
538
|
readonly "esm/no-dynamic-imports": "error";
|
|
633
539
|
readonly "esm/no-empty-exports": "error";
|
|
@@ -638,6 +544,7 @@ export declare function typescript(): readonly [{
|
|
|
638
544
|
readonly "esm/no-rename-imports": "error";
|
|
639
545
|
readonly "esm/no-side-effect-imports": "error";
|
|
640
546
|
readonly "esm/no-ts-file-imports": "error";
|
|
547
|
+
readonly "esm/no-useless-path-segments": "error";
|
|
641
548
|
readonly "esm/required-exports": "error";
|
|
642
549
|
readonly "fp/no-arguments": "error";
|
|
643
550
|
readonly "fp/no-delete": "error";
|
|
@@ -754,6 +661,7 @@ export declare function typescript(): readonly [{
|
|
|
754
661
|
readonly "unicorn/prefer-module": "error";
|
|
755
662
|
readonly "unicorn/prefer-negative-index": "error";
|
|
756
663
|
readonly "unicorn/prefer-number-properties": "error";
|
|
664
|
+
readonly "unicorn/prefer-object-from-entries": "error";
|
|
757
665
|
readonly "unicorn/prefer-optional-catch-binding": "error";
|
|
758
666
|
readonly "unicorn/prefer-regexp-test": "error";
|
|
759
667
|
readonly "unicorn/prefer-string-replace-all": "error";
|
|
@@ -773,7 +681,6 @@ export declare function typescript(): readonly [{
|
|
|
773
681
|
readonly "ts-ignore": true;
|
|
774
682
|
readonly "ts-nocheck": true;
|
|
775
683
|
}];
|
|
776
|
-
readonly "@typescript-eslint/class-literal-property-style": "error";
|
|
777
684
|
readonly "@typescript-eslint/no-this-alias": "error";
|
|
778
685
|
readonly "@typescript-eslint/no-useless-empty-export": "error";
|
|
779
686
|
readonly "@typescript-eslint/prefer-for-of": "error";
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"typescript.d.ts","sourceRoot":"","sources":["../../src/config/typescript.ts"],"names":[],"mappings":"AAMA,wBAAgB,UAAU;;;;;;;;;;;;;;;;;;;;;;;;;;;;;8CASyW,QAAQ;0CAAiD,QAAQ;gEAAuE,QAAQ;yDAAgE,QAAQ;mDAA0D,QAAQ;uCAA8C,QAAQ;iDAAwD,QAAQ;2CAAkD,QAAQ;0CAAiD,QAAQ;oDAA2D,QAAQ;4CAAmD,QAAQ
|
|
1
|
+
{"version":3,"file":"typescript.d.ts","sourceRoot":"","sources":["../../src/config/typescript.ts"],"names":[],"mappings":"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"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@fenge/eslint-config",
|
|
3
|
-
"version": "0.5.
|
|
3
|
+
"version": "0.5.2",
|
|
4
4
|
"description": "A super strict eslint config for linting js/ts/package.json.",
|
|
5
5
|
"keywords": [
|
|
6
6
|
"opinionated",
|
|
@@ -23,15 +23,15 @@
|
|
|
23
23
|
"type": "module",
|
|
24
24
|
"exports": "./dist/eslint.config.js",
|
|
25
25
|
"dependencies": {
|
|
26
|
-
"@typescript-eslint/eslint-plugin": "8.18.
|
|
27
|
-
"@typescript-eslint/parser": "8.18.
|
|
26
|
+
"@typescript-eslint/eslint-plugin": "8.18.2",
|
|
27
|
+
"@typescript-eslint/parser": "8.18.2",
|
|
28
28
|
"confusing-browser-globals": "1.0.11",
|
|
29
29
|
"eslint-plugin-es-x": "8.4.1",
|
|
30
30
|
"eslint-plugin-fp": "2.3.0",
|
|
31
31
|
"eslint-plugin-import": "2.31.0",
|
|
32
32
|
"eslint-plugin-n": "17.15.1",
|
|
33
33
|
"eslint-plugin-promise": "7.2.1",
|
|
34
|
-
"eslint-plugin-react": "7.37.
|
|
34
|
+
"eslint-plugin-react": "7.37.3",
|
|
35
35
|
"eslint-plugin-react-hooks": "5.1.0",
|
|
36
36
|
"eslint-plugin-simple-import-sort": "12.1.1",
|
|
37
37
|
"eslint-plugin-sonarjs": "1.0.4",
|
|
@@ -39,8 +39,8 @@
|
|
|
39
39
|
"globals": "15.14.0",
|
|
40
40
|
"@fenge/eslint-plugin": "0.1.2",
|
|
41
41
|
"@fenge/eslint-plugin-ts": "0.2.0",
|
|
42
|
-
"eslint-plugin-esm": "0.
|
|
43
|
-
"eslint-plugin-pkg-json": "0.1.
|
|
42
|
+
"eslint-plugin-esm": "0.4.0",
|
|
43
|
+
"eslint-plugin-pkg-json": "0.1.3",
|
|
44
44
|
"eslint-plugin-publint": "0.0.5"
|
|
45
45
|
},
|
|
46
46
|
"devDependencies": {
|
package/src/config/js/base.ts
CHANGED
|
@@ -312,8 +312,15 @@ export function getJsBase() {
|
|
|
312
312
|
// 3. ban some syntaxes to reduce mistakes
|
|
313
313
|
"default-param-last": "error",
|
|
314
314
|
"func-name-matching": "error",
|
|
315
|
+
"func-names": "error", // always require a name for function declaration
|
|
316
|
+
"func-style": ["error", "declaration", { allowArrowFunctions: true }],
|
|
315
317
|
"getter-return": "error",
|
|
316
318
|
"init-declarations": "error",
|
|
319
|
+
"logical-assignment-operators": [
|
|
320
|
+
"error",
|
|
321
|
+
"always",
|
|
322
|
+
{ enforceForIfStatements: true },
|
|
323
|
+
],
|
|
317
324
|
"max-depth": ["error", { max: 5 }],
|
|
318
325
|
"max-params": ["error", { max: 4 }],
|
|
319
326
|
"no-bitwise": "error",
|
|
@@ -327,6 +334,7 @@ export function getJsBase() {
|
|
|
327
334
|
"error",
|
|
328
335
|
{ disallowTemplateShorthand: true, allow: ["!!"] },
|
|
329
336
|
], // forbid code like `const num = +str`;
|
|
337
|
+
"no-inner-declarations": "error", // TODO: change the rule value to `["error","functions",{blockScopedFunctions:"disallow"}]` when eslint is v9
|
|
330
338
|
"no-invalid-this": "error",
|
|
331
339
|
"no-lonely-if": "error",
|
|
332
340
|
"no-multi-assign": "error",
|
|
@@ -359,7 +367,6 @@ export function getJsBase() {
|
|
|
359
367
|
"es-x/no-legacy-object-prototype-accessor-methods": "error",
|
|
360
368
|
"es-x/no-top-level-await": "error",
|
|
361
369
|
// esm
|
|
362
|
-
"esm/nearest-relative-path": "error",
|
|
363
370
|
"esm/no-directory-imports": "error",
|
|
364
371
|
"esm/no-dynamic-imports": "error",
|
|
365
372
|
"esm/no-empty-exports": "error",
|
|
@@ -370,6 +377,7 @@ export function getJsBase() {
|
|
|
370
377
|
"esm/no-rename-imports": "error",
|
|
371
378
|
"esm/no-side-effect-imports": "error",
|
|
372
379
|
"esm/no-ts-file-imports": "error",
|
|
380
|
+
"esm/no-useless-path-segments": "error",
|
|
373
381
|
"esm/required-exports": "error",
|
|
374
382
|
// fp
|
|
375
383
|
"fp/no-arguments": "error",
|
|
@@ -480,6 +488,7 @@ export function getJsBase() {
|
|
|
480
488
|
"unicorn/prefer-module": "error",
|
|
481
489
|
"unicorn/prefer-negative-index": "error",
|
|
482
490
|
"unicorn/prefer-number-properties": "error",
|
|
491
|
+
"unicorn/prefer-object-from-entries": "error",
|
|
483
492
|
"unicorn/prefer-optional-catch-binding": "error",
|
|
484
493
|
"unicorn/prefer-regexp-test": "error",
|
|
485
494
|
"unicorn/prefer-string-replace-all": "error",
|
|
@@ -504,7 +513,6 @@ export function getJsBase() {
|
|
|
504
513
|
"ts-nocheck": true,
|
|
505
514
|
},
|
|
506
515
|
],
|
|
507
|
-
"@typescript-eslint/class-literal-property-style": "error",
|
|
508
516
|
"@typescript-eslint/no-this-alias": "error",
|
|
509
517
|
"@typescript-eslint/no-useless-empty-export": "error",
|
|
510
518
|
"@typescript-eslint/prefer-for-of": "error",
|
package/src/config/ts/base.ts
CHANGED
|
@@ -104,6 +104,7 @@ export function getTsBase() {
|
|
|
104
104
|
"@typescript-eslint/adjacent-overload-signatures": "error",
|
|
105
105
|
// "@typescript-eslint/array-type": ["error", 'array-simple'], // The default option is 'array'. Not very sure if we need to change the option. So disabled it.
|
|
106
106
|
"@typescript-eslint/await-thenable": "error",
|
|
107
|
+
"@typescript-eslint/class-literal-property-style": "error",
|
|
107
108
|
"@typescript-eslint/consistent-generic-constructors": "error",
|
|
108
109
|
"@typescript-eslint/consistent-indexed-object-style": "error",
|
|
109
110
|
"@typescript-eslint/consistent-type-assertions": [
|