Initial commit

This commit is contained in:
2023-07-27 21:56:03 +02:00
commit 251589f71d
14 changed files with 5111 additions and 0 deletions

202
configs/generic.js Normal file
View File

@ -0,0 +1,202 @@
'use strict';
/**
* Generic ESLint configuration for all modern JavaScript runtimes.
*
* @package yeslint!
* @author Romein van Buren
* @license MIT
* @type {import('eslint').Linter.Config}
*/
const generic = {
parserOptions: {
ecmaVersion: 2021,
},
env: {
es6: true,
},
extends: [ 'eslint:recommended' ],
plugins: [ 'import' ],
rules: {
'no-undef': [
'error',
{
typeof: true,
},
],
'require-atomic-updates': 0,
indent: [
'error',
2,
{ SwitchCase: 1 },
],
strict: [
'error',
'safe',
],
quotes: [
'error',
'single',
],
semi: [
'warn',
'always',
],
'accessor-pairs': 'error',
'array-bracket-spacing': [
'error',
'always',
],
'array-element-newline': [ 'warn' ],
'array-bracket-newline': [
'warn',
{ minItems: 2 },
],
'arrow-body-style': [
'error',
'as-needed',
{ requireReturnForObjectLiteral: true },
],
'arrow-parens': [
'error',
'as-needed',
],
'arrow-spacing': 'error',
'block-spacing': [
'error',
'always',
],
'comma-dangle': [
'warn',
{
arrays: 'always-multiline',
objects: 'always-multiline',
imports: 'never',
exports: 'never',
functions: 'never',
},
],
'comma-spacing': 'error',
'comma-style': [
'error',
'last',
],
'computed-property-spacing': [
'error',
'never',
],
'generator-star-spacing': 'error',
'id-blacklist': 'error',
'id-match': 'error',
'jsx-quotes': 'error',
'keyword-spacing': 'error',
'key-spacing': [
'warn',
{
beforeColon: false,
},
],
'linebreak-style': [
'error',
'unix',
],
'no-unused-vars': 'warn',
'no-alert': 'error',
'no-caller': 'error',
'no-confusing-arrow': [
'error',
{ allowParens: true },
],
'no-console': 'off',
'no-div-regex': 'error',
'no-duplicate-imports': 'error',
'import/extensions': [
'warn',
'ignorePackages',
],
'no-extend-native': 'error',
'no-extra-label': 'error',
'no-fallthrough': 'off',
'no-floating-decimal': 'error',
'no-implicit-coercion': [
'error',
{
boolean: false,
number: false,
string: false,
},
],
'no-inner-declarations': [
'error',
'functions',
],
'no-iterator': 'error',
'no-label-var': 'error',
'no-lone-blocks': 'error',
'no-new-object': 'error',
'no-new-require': 'error',
'no-new-wrappers': 'error',
'no-restricted-globals': [
'error',
'event',
'name',
],
'no-restricted-imports': 'error',
'no-restricted-modules': 'error',
'no-restricted-syntax': 'error',
'no-script-url': 'error',
'no-self-compare': 'error',
'no-sequences': 'error',
'no-shadow-restricted-names': 'error',
'no-spaced-func': 'error',
'no-trailing-spaces': 'error',
'no-unmodified-loop-condition': 'error',
'no-useless-constructor': 'error',
'no-whitespace-before-property': 'error',
'no-with': 'error',
'object-curly-spacing': [
'error',
'always',
],
'object-shorthand': [
'error',
'properties',
],
'quote-props': [
'error',
'as-needed',
],
'prefer-const': 'error',
'require-yield': 'error',
'semi-spacing': [ 'error' ],
'space-before-blocks': 'error',
'space-before-function-paren': [
'error',
'never',
],
'space-in-parens': [
'error',
'never',
],
'space-infix-ops': 'error',
'space-unary-ops': 'error',
'template-curly-spacing': 'error',
curly: 2,
'brace-style': [
'error',
'stroustrup',
],
'wrap-iife': [
'error',
'any',
],
'yield-star-spacing': 'error',
'multiline-ternary': [
'error',
'never',
],
'no-nested-ternary': 'error',
},
};
module.exports = generic;

25
configs/node.js Normal file
View File

@ -0,0 +1,25 @@
'use strict';
const generic = require('./generic.js');
/**
* An extension on the default yeslint! generic config, with rules specific to
* Node.js environments.
*
* @package yeslint!
* @author Romein van Buren
* @license MIT
* @type {import('eslint').Linter.Config}
*/
const node = {
parserOptions: { ...generic.parserOptions },
env: {
...generic.env,
node: true,
},
extends: [ ...generic.extends ],
plugins: [ ...generic.plugins ],
rules: { ...generic.rules },
};
module.exports = node;

100
configs/svelte.js Normal file
View File

@ -0,0 +1,100 @@
'use strict';
const generic = require('./generic.js');
/**
* An extension on the default yeslint! generic config, with rules specific to
* Svelte codebases and JavaScript source code for browser environments.
*
* @package yeslint!
* @author Romein van Buren
* @license MIT
* @type {import('eslint').Linter.Config}
*/
const svelte = {
parserOptions: {
...generic.parserOptions,
ecmaVersion: 2020,
sourceType: 'module',
},
env: {
...generic.browser,
browser: true,
node: true,
es6: true,
},
extends: [
...generic.extends,
'plugin:svelte/recommended',
],
plugins: [
...generic.plugins,
'svelte',
],
overrides: [ {
files: '*.svelte',
parser: 'svelte-eslint-parser',
rules: {
'no-inner-declarations': 0,
'svelte/no-inner-declarations': [
'error',
'functions',
],
'svelte/html-quotes': [
'error',
{
prefer: 'double',
dynamic: {
quoted: false,
avoidInvalidUnquotedInHTML: false,
},
},
],
'svelte/no-useless-mustaches': 'warn',
'svelte/require-store-reactive-access': 'warn',
'svelte/no-reactive-literals': 'error',
'svelte/html-closing-bracket-spacing': 'warn',
'svelte/indent': [
'warn',
{
indent: 2,
ignoredNodes: [],
switchCase: 1,
alignAttributesVertically: false,
},
],
'svelte/max-attributes-per-line': [
'warn',
{
multiline: 1,
singleline: 4,
},
],
'svelte/first-attribute-linebreak': [
'warn',
{
multiline: 'below',
singleline: 'beside',
},
],
'svelte/mustache-spacing': 'warn',
'svelte/no-extra-reactive-curlies': 'error',
'svelte/no-spaces-around-equal-signs-in-attribute': 'warn',
'svelte/prefer-class-directive': 'warn',
'svelte/shorthand-attribute': 'warn',
'svelte/shorthand-directive': 'warn',
'svelte/spaced-html-comment': 'warn',
'svelte/no-at-html-tags': 0,
'svelte/html-self-closing': [
'warn',
'all',
],
},
} ],
rules: {
...generic.rules,
strict: 0,
},
};
module.exports = svelte;