3a4992633e
Sorry for the very big commit that may lead to git log issues and merge conflicts, but it's a major step forward: * Server can be faster at startup because imports() are async and we can easily lazy import big modules * Angular doesn't seem to support ES import (with .js extension), so we had to correctly organize peertube into a monorepo: * Use yarn workspace feature * Use typescript reference projects for dependencies * Shared projects have been moved into "packages", each one is now a node module (with a dedicated package.json/tsconfig.json) * server/tools have been moved into apps/ and is now a dedicated app bundled and published on NPM so users don't have to build peertube cli tools manually * server/tests have been moved into packages/ so we don't compile them every time we want to run the server * Use isolatedModule option: * Had to move from const enum to const (https://www.typescriptlang.org/docs/handbook/enums.html#objects-vs-enums) * Had to explictely specify "type" imports when used in decorators * Prefer tsx (that uses esbuild under the hood) instead of ts-node to load typescript files (tests with mocha or scripts): * To reduce test complexity as esbuild doesn't support decorator metadata, we only test server files that do not import server models * We still build tests files into js files for a faster CI * Remove unmaintained peertube CLI import script * Removed some barrels to speed up execution (less imports)
146 lines
3.7 KiB
JSON
146 lines
3.7 KiB
JSON
{
|
|
"extends": "standard-with-typescript",
|
|
"root": true,
|
|
"rules": {
|
|
"eol-last": [
|
|
"error",
|
|
"always"
|
|
],
|
|
"indent": "off",
|
|
"no-lone-blocks": "off",
|
|
"no-mixed-operators": "off",
|
|
"max-len": [
|
|
"error",
|
|
{
|
|
"code": 140
|
|
}
|
|
],
|
|
"array-bracket-spacing": [
|
|
"error",
|
|
"always"
|
|
],
|
|
"quote-props": [
|
|
"error",
|
|
"consistent-as-needed"
|
|
],
|
|
"padded-blocks": "off",
|
|
"prefer-regex-literals": "off",
|
|
"no-async-promise-executor": "off",
|
|
"dot-notation": "off",
|
|
"promise/param-names": "off",
|
|
"import/first": "off",
|
|
"operator-linebreak": [
|
|
"error",
|
|
"after",
|
|
{
|
|
"overrides": {
|
|
"?": "before",
|
|
":": "before"
|
|
}
|
|
}
|
|
],
|
|
"quotes": "off",
|
|
"@typescript-eslint/indent": [
|
|
"error",
|
|
2,
|
|
{
|
|
"SwitchCase": 1,
|
|
"MemberExpression": "off",
|
|
// https://github.com/eslint/eslint/issues/15299
|
|
"ignoredNodes": ["PropertyDefinition"]
|
|
}
|
|
],
|
|
"@typescript-eslint/consistent-type-assertions": [
|
|
"error",
|
|
{
|
|
"assertionStyle": "as"
|
|
}
|
|
],
|
|
"@typescript-eslint/array-type": [
|
|
"error",
|
|
{
|
|
"default": "array"
|
|
}
|
|
],
|
|
"@typescript-eslint/restrict-template-expressions": [
|
|
"off",
|
|
{
|
|
"allowNumber": "true"
|
|
}
|
|
],
|
|
"@typescript-eslint/no-this-alias": [
|
|
"error",
|
|
{
|
|
"allowDestructuring": true, // Allow `const { props, state } = this`; false by default
|
|
"allowedNames": ["self"] // Allow `const self = this`; `[]` by default
|
|
}
|
|
],
|
|
|
|
"@typescript-eslint/return-await": "off",
|
|
"@typescript-eslint/dot-notation": "off",
|
|
"@typescript-eslint/method-signature-style": "off",
|
|
"@typescript-eslint/no-base-to-string": "off",
|
|
"@typescript-eslint/quotes": [
|
|
"error",
|
|
"single",
|
|
{
|
|
"avoidEscape": true,
|
|
"allowTemplateLiterals": true
|
|
}
|
|
],
|
|
"@typescript-eslint/no-var-requires": "off",
|
|
"@typescript-eslint/explicit-function-return-type": "off",
|
|
"@typescript-eslint/promise-function-async": "off",
|
|
"@typescript-eslint/no-dynamic-delete": "off",
|
|
"@typescript-eslint/no-unnecessary-boolean-literal-compare": "off",
|
|
"@typescript-eslint/strict-boolean-expressions": "off",
|
|
"@typescript-eslint/consistent-type-definitions": "off",
|
|
"@typescript-eslint/no-misused-promises": "off",
|
|
"@typescript-eslint/no-namespace": "off",
|
|
"@typescript-eslint/no-empty-interface": "off",
|
|
"@typescript-eslint/no-extraneous-class": "off",
|
|
"@typescript-eslint/no-use-before-define": "off",
|
|
|
|
"require-await": "off",
|
|
"@typescript-eslint/require-await": "error",
|
|
|
|
// bugged but useful
|
|
"@typescript-eslint/restrict-plus-operands": "off",
|
|
|
|
// Requires strictNullChecks
|
|
"@typescript-eslint/prefer-nullish-coalescing": "off",
|
|
"@typescript-eslint/consistent-type-imports": "off",
|
|
"@typescript-eslint/consistent-indexed-object-style": "off",
|
|
"@typescript-eslint/no-confusing-void-expression": "off",
|
|
"@typescript-eslint/consistent-type-exports": "off",
|
|
"@typescript-eslint/key-spacing": "off",
|
|
|
|
"@typescript-eslint/ban-types": [
|
|
"error",
|
|
{
|
|
"types": {
|
|
"{}": false,
|
|
"Function": false
|
|
},
|
|
"extendDefaults": true
|
|
}
|
|
]
|
|
},
|
|
"ignorePatterns": [
|
|
"node_modules",
|
|
"packages/tests/fixtures",
|
|
"apps/**/dist",
|
|
"packages/**/dist",
|
|
"server/dist",
|
|
"packages/types-generator/tests",
|
|
"*.js",
|
|
"/client",
|
|
"/dist"
|
|
],
|
|
"parserOptions": {
|
|
"project": [
|
|
"./tsconfig.eslint.json"
|
|
],
|
|
"EXPERIMENTAL_useSourceOfProjectReferenceRedirect": true
|
|
}
|
|
}
|