Skip to content

Commit

Permalink
Eslint flat config (#574)
Browse files Browse the repository at this point in the history
* Update eslint-plugin-import

* Use flat config

* Configure eslint-plugin-deprecation
  • Loading branch information
mbraak authored Sep 9, 2024
1 parent bbd6fc8 commit 6d170b4
Show file tree
Hide file tree
Showing 9 changed files with 293 additions and 127 deletions.

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

Large diffs are not rendered by default.

Large diffs are not rendered by default.

Large diffs are not rendered by default.

37 changes: 0 additions & 37 deletions frontend/.eslintrc

This file was deleted.

52 changes: 31 additions & 21 deletions frontend/django_mptt_admin.ts
Original file line number Diff line number Diff line change
Expand Up @@ -58,13 +58,14 @@ function initTree(
const insertAtUrl = new URL($tree.data("insert_at_url") as string, baseUrl);

function createLi(node: INode, $li: JQuery, isSelected: boolean) {
if (node.id == null) {
return;
}

// Create edit link
const $title = $li.find(".jqtree-title");

insertAtUrl.searchParams.set(
"insert_at",
`${node.id as string | number}`
);
insertAtUrl.searchParams.set("insert_at", node.id.toString());

const insertUrlString = insertAtUrl
.toString()
Expand All @@ -89,11 +90,10 @@ function initTree(

function getCsrfToken() {
function getFromMiddleware() {
return (
document.querySelector(
'[name="csrfmiddlewaretoken"]'
) as HTMLInputElement
).value;
const inputElement = document.querySelector<HTMLInputElement>(
'[name="csrfmiddlewaretoken"]'
);
return inputElement?.value;
}

function getFromCookie() {
Expand All @@ -104,7 +104,7 @@ function initTree(
}
}

return getFromCookie() || getFromMiddleware();
return getFromCookie() ?? getFromMiddleware() ?? "";
}

function handleMove(eventParam: JQuery.Event) {
Expand Down Expand Up @@ -161,11 +161,15 @@ function initTree(

const spinners: Record<number | string, HTMLElement | null> = {};

function getSpinnerId(node: INode | null): string | number {
function getSpinnerId(node: INode | null): string | number | null {
if (!node) {
return "__root__";
} else {
return node.id as string | number;
if (node.id == null) {
return null;
} else {
return node.id as string | number;
}
}
}

Expand All @@ -174,22 +178,30 @@ function initTree(
if (node) {
return node.element;
} else {
return $tree.get(0) as HTMLElement;
return $tree.get(0);
}
}

const container = getContainer();
const spinnerId = getSpinnerId(node);

if (!container || spinnerId == null) {
return;
}

const spinner = document.createElement("span");
spinner.className = "jqtree-spin";
container.append(spinner);

const spinnerId = getSpinnerId(node);
spinners[spinnerId] = spinner;
}

function handleLoaded(node: INode | null) {
const spinnerId = getSpinnerId(node);

if (spinnerId == null) {
return;
}

const spinner = spinners[spinnerId];

if (spinner) {
Expand All @@ -206,10 +218,8 @@ function initTree(
jQuery(deselected_node.element).find(".edit").attr("tabindex", -1);
}

if (node) {
// selected: add tabindex
jQuery(node.element).find(".edit").attr("tabindex", 0);
}
// selected: add tabindex
jQuery(node.element).find(".edit").attr("tabindex", 0);
}

function handleLoadingEvent(e: JQuery.Event) {
Expand Down Expand Up @@ -239,11 +249,11 @@ function initTree(
};

if (animationSpeed !== null) {
treeOptions["animationSpeed"] = animationSpeed;
treeOptions.animationSpeed = animationSpeed;
}

if (mouseDelay != null) {
treeOptions["startDndDelay"] = mouseDelay;
treeOptions.startDndDelay = mouseDelay;
}

$tree.on("tree.loading_data", handleLoadingEvent);
Expand Down
27 changes: 27 additions & 0 deletions frontend/eslint.config.mjs
Original file line number Diff line number Diff line change
@@ -0,0 +1,27 @@
import eslint from "@eslint/js";
import tseslint from "typescript-eslint";
import importPlugin from "eslint-plugin-import";
import eslintPluginDeprecation from "eslint-plugin-deprecation";

export default [
eslint.configs.recommended,
...tseslint.configs.strictTypeChecked,
...tseslint.configs.stylisticTypeChecked,
importPlugin.flatConfigs.recommended,
importPlugin.flatConfigs.typescript,
{
languageOptions: {
parserOptions: {
projectService: true,
tsconfigRootDir: import.meta.dirname,
},
},
plugins: {
deprecation: eslintPluginDeprecation,
},
rules: {
"@typescript-eslint/restrict-template-expressions": "error",
"deprecation/deprecation": "error",
},
},
];
7 changes: 4 additions & 3 deletions frontend/package.json
Original file line number Diff line number Diff line change
Expand Up @@ -29,19 +29,20 @@
"@babel/plugin-transform-runtime": "^7.24.3",
"@babel/preset-env": "^7.24.4",
"@babel/preset-typescript": "^7.24.1",
"@eslint/js": "^9.9.1",
"@types/cookie": "^0.6.0",
"@types/eslint__js": "^8.42.3",
"@types/jquery": "^3.5.29",
"@types/node": "^20.12.5",
"@typescript-eslint/eslint-plugin": "^7.5.0",
"@typescript-eslint/parser": "^7.5.0",
"babel-loader": "^9.1.3",
"babel-plugin-istanbul": "^6.1.1",
"eslint": "^8.57.0",
"eslint-import-resolver-typescript": "^3.6.1",
"eslint-plugin-deprecation": "^3.0.0",
"eslint-plugin-import": "^2.29.1",
"eslint-plugin-import": "^2.30.0",
"sass": "^1.74.1",
"typescript": "^5.4.4",
"typescript-eslint": "^8.4.0",
"webpack": "^5.91.0",
"webpack-cli": "^5.1.4"
},
Expand Down
Loading

0 comments on commit 6d170b4

Please sign in to comment.