From 2e4e0791e7629275a9a11d08b0308bca05fba6ca Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=E3=82=A2=E3=83=AC=E3=82=AF=E3=82=B5=E3=83=B3=E3=83=80?= =?UTF-8?q?=E3=83=BC=2Eeth?= Date: Wed, 11 Dec 2024 07:04:31 +0900 Subject: [PATCH] fix(eslint): config to ignore dist and js --- eslint.config.mjs | 259 ++++++++++++++++--------------- static/scripts/fetch-manifest.ts | 4 +- 2 files changed, 132 insertions(+), 131 deletions(-) diff --git a/eslint.config.mjs b/eslint.config.mjs index c56fce8..75d1225 100644 --- a/eslint.config.mjs +++ b/eslint.config.mjs @@ -1,137 +1,138 @@ -// @ts-check -import tsEslint from "typescript-eslint"; import eslint from "@eslint/js"; -import sonarjs from "eslint-plugin-sonarjs"; import checkFile from "eslint-plugin-check-file"; +import sonarjs from "eslint-plugin-sonarjs"; +import tsEslint from "typescript-eslint"; -export default tsEslint.config({ - plugins: { - "@typescript-eslint": tsEslint.plugin, - "check-file": checkFile, +export default [ + { + ignores: ["dist/**/*", "**/*.js", ".github/*.ts", "cypress.config.ts"], }, - // static\dist\main.js - ignores: [".github/*.ts", "static/dist/*.js", "static/dist/*.ts", "static/dist/*.d.ts", "cypress.config.ts", "coverage/*"], - extends: [eslint.configs.recommended, ...tsEslint.configs.recommended, sonarjs.configs.recommended], - languageOptions: { - parser: tsEslint.parser, - parserOptions: { - projectService: { - defaultProject: "tsconfig.json", - allowDefaultProject: ["*.mjs"], - }, - tsconfigRootDir: import.meta.dirname, + eslint.configs.recommended, + ...tsEslint.configs.recommended, + sonarjs.configs.recommended, + { + plugins: { + "@typescript-eslint": tsEslint.plugin, + "check-file": checkFile, }, - }, - rules: { - "check-file/filename-naming-convention": [ - "error", - { - "**/*.{js,ts}": "+([-._a-z0-9])", - }, - ], - "prefer-arrow-callback": [ - "warn", - { - allowNamedFunctions: true, - }, - ], - "func-style": [ - "warn", - "declaration", - { - allowArrowFunctions: false, - }, - ], - "@typescript-eslint/no-floating-promises": "error", - "@typescript-eslint/no-non-null-assertion": "error", - "constructor-super": "error", - "no-invalid-this": "off", - "@typescript-eslint/no-invalid-this": ["error"], - "no-restricted-syntax": ["error", "ForInStatement"], - "use-isnan": "error", - "no-unneeded-ternary": "error", - "no-nested-ternary": "error", - "@typescript-eslint/no-unused-vars": [ - "error", - { - args: "after-used", - ignoreRestSiblings: true, - vars: "all", - varsIgnorePattern: "^_", - argsIgnorePattern: "^_", + languageOptions: { + parser: tsEslint.parser, + parserOptions: { + project: "./tsconfig.json", + tsconfigRootDir: import.meta.dirname, }, - ], - "@typescript-eslint/await-thenable": "error", - "@typescript-eslint/no-misused-new": "error", - "@typescript-eslint/restrict-plus-operands": "error", - "sonarjs/no-all-duplicated-branches": "error", - "sonarjs/no-collection-size-mischeck": "error", - "sonarjs/no-duplicated-branches": "error", - "sonarjs/no-element-overwrite": "error", - "sonarjs/no-identical-conditions": "error", - "sonarjs/no-identical-expressions": "error", - "sonarjs/new-cap": "off", - "sonarjs/different-types-comparison": "off", - "sonarjs/sonar-prefer-regexp-exec": "off", - "sonarjs/function-return-type": "off", - "sonarjs/no-misleading-array-reverse": "off", - "sonarjs/slow-regex": "off", - "@typescript-eslint/naming-convention": [ - "error", - { - selector: "interface", - format: ["StrictPascalCase"], - custom: { - regex: "^I[A-Z]", - match: false, + }, + rules: { + "check-file/filename-naming-convention": [ + "error", + { + "**/*.{js,ts}": "+([-._a-z0-9])", }, - }, - { - selector: "memberLike", - modifiers: ["private"], - format: ["strictCamelCase"], - leadingUnderscore: "require", - }, - { - selector: "typeLike", - format: ["StrictPascalCase"], - }, - { - selector: "typeParameter", - format: ["StrictPascalCase"], - prefix: ["T"], - }, - { - selector: "variable", - format: ["strictCamelCase", "UPPER_CASE"], - leadingUnderscore: "allow", - trailingUnderscore: "allow", - }, - { - selector: "variable", - format: ["strictCamelCase"], - leadingUnderscore: "allow", - trailingUnderscore: "allow", - }, - { - selector: "variable", - modifiers: ["destructured"], - format: null, - }, - { - selector: "variable", - types: ["boolean"], - format: ["StrictPascalCase"], - prefix: ["is", "should", "has", "can", "did", "will", "does"], - }, - { - selector: "variableLike", - format: ["strictCamelCase"], - }, - { - selector: ["function", "variable"], - format: ["strictCamelCase"], - }, - ], + ], + "prefer-arrow-callback": [ + "warn", + { + allowNamedFunctions: true, + }, + ], + "func-style": [ + "warn", + "declaration", + { + allowArrowFunctions: false, + }, + ], + "@typescript-eslint/no-floating-promises": "error", + "@typescript-eslint/no-non-null-assertion": "error", + "constructor-super": "error", + "no-invalid-this": "off", + "@typescript-eslint/no-invalid-this": ["error"], + "no-restricted-syntax": ["error", "ForInStatement"], + "use-isnan": "error", + "no-unneeded-ternary": "error", + "no-nested-ternary": "error", + "@typescript-eslint/no-unused-vars": [ + "error", + { + args: "after-used", + ignoreRestSiblings: true, + vars: "all", + varsIgnorePattern: "^_", + argsIgnorePattern: "^_", + }, + ], + "@typescript-eslint/await-thenable": "error", + "@typescript-eslint/no-misused-new": "error", + "@typescript-eslint/restrict-plus-operands": "error", + "sonarjs/no-all-duplicated-branches": "error", + "sonarjs/no-collection-size-mischeck": "error", + "sonarjs/no-duplicated-branches": "error", + "sonarjs/no-element-overwrite": "error", + "sonarjs/no-identical-conditions": "error", + "sonarjs/no-identical-expressions": "error", + "sonarjs/new-cap": "off", + "sonarjs/different-types-comparison": "off", + "sonarjs/sonar-prefer-regexp-exec": "off", + "sonarjs/function-return-type": "off", + "sonarjs/no-misleading-array-reverse": "off", + "sonarjs/slow-regex": "off", + "@typescript-eslint/naming-convention": [ + "error", + { + selector: "interface", + format: ["StrictPascalCase"], + custom: { + regex: "^I[A-Z]", + match: false, + }, + }, + { + selector: "memberLike", + modifiers: ["private"], + format: ["strictCamelCase"], + leadingUnderscore: "require", + }, + { + selector: "typeLike", + format: ["StrictPascalCase"], + }, + { + selector: "typeParameter", + format: ["StrictPascalCase"], + prefix: ["T"], + }, + { + selector: "variable", + format: ["strictCamelCase", "UPPER_CASE"], + leadingUnderscore: "allow", + trailingUnderscore: "allow", + }, + { + selector: "variable", + format: ["strictCamelCase"], + leadingUnderscore: "allow", + trailingUnderscore: "allow", + }, + { + selector: "variable", + modifiers: ["destructured"], + format: null, + }, + { + selector: "variable", + types: ["boolean"], + format: ["StrictPascalCase"], + prefix: ["is", "should", "has", "can", "did", "will", "does"], + }, + { + selector: "variableLike", + format: ["strictCamelCase"], + }, + { + selector: ["function", "variable"], + format: ["strictCamelCase"], + }, + ], + }, }, -}); +]; diff --git a/static/scripts/fetch-manifest.ts b/static/scripts/fetch-manifest.ts index 6ead971..a7d3a0e 100644 --- a/static/scripts/fetch-manifest.ts +++ b/static/scripts/fetch-manifest.ts @@ -37,7 +37,7 @@ export class ManifestFetcher { for (const repo of repos.data) { const manifestUrl = this.createGithubRawEndpoint(org, repo.name, "development", "manifest.json"); const manifest = await this.fetchPluginManifest(manifestUrl); - const decoded = this.decodeManifestFromFetch(manifest, repo.name); + const decoded = this.decodeManifestFromFetch(manifest); const readme = await this.fetchPluginReadme(this.createGithubRawEndpoint(org, repo.name, "development", "README.md")); if (decoded) { @@ -190,7 +190,7 @@ export class ManifestFetcher { } } - decodeManifestFromFetch(manifest: ManifestPreDecode, repoName: string) { + decodeManifestFromFetch(manifest: ManifestPreDecode) { if (manifest.error) { return null; }