1
0
mirror of https://github.com/tobspr/shapez.io.git synced 2025-12-13 02:01:51 +00:00
tobspr_shapez.io/eslint.config.js

67 lines
1.7 KiB
JavaScript
Raw Normal View History

import eslint from "@eslint/js";
import globals from "globals";
import path from "path";
2024-06-18 11:43:55 +00:00
import tseslint from "typescript-eslint";
import { fileURLToPath } from "url";
const baseConfig = tseslint.config(
eslint.configs.recommended,
...tseslint.configs.recommendedTypeChecked,
// Enable type-aware linting
{
languageOptions: {
parserOptions: {
project: true,
// FIXME: Node.js 21.2.0 introduced import.meta.dirname
tsconfigRootDir: path.dirname(fileURLToPath(import.meta.url)),
},
},
},
// Disable type-aware linting for JS files as it causes issues
{
files: ["*.js"],
...tseslint.configs.disableTypeChecked,
}
);
const nodeConfig = tseslint.config(...baseConfig, {
languageOptions: {
sourceType: "module",
globals: {
...globals.node,
},
},
});
const runtimeConfig = tseslint.config(...baseConfig, {
languageOptions: {
sourceType: "module",
globals: {
...globals.browser,
},
},
rules: {
// Mostly caused by JSDoc imports, so don't annoy with errors but keep
// a reminder!
"@typescript-eslint/no-unused-vars": "warn",
// FIXME: enforce when we're ready to
"prefer-const": "warn",
},
});
// I don't know what the ESLint devs were thinking about. This is just horrible
export default [
{
ignores: ["build/*"],
},
...nodeConfig.map(config => ({
...config,
2024-06-18 11:43:55 +00:00
files: ["*.(ts|js)", "(gulp|electron)/**/*.(ts|js)"],
ignores: ["gulp/preloader/*.js"],
})),
...runtimeConfig.map(config => ({
...config,
2024-06-18 11:43:55 +00:00
files: ["src/**/*.(ts|js)x?"],
})),
];