From aecf74951cecb4de9ca94dd93e48af6f62300a0f Mon Sep 17 00:00:00 2001 From: tobi <31960611+tsmethurst@users.noreply.github.com> Date: Thu, 25 Apr 2024 18:24:24 +0200 Subject: [chore] Settings refactor 2: the re-refactoring-ing (#2866) * [chore] Bit more refactoring of settings panel * fix up some remaining things * groovy baby yeah! * remove unused Suspense --- .../views/admin/actions/keys/expireremote.tsx | 2 +- .../settings/views/admin/actions/media/cleanup.tsx | 2 +- .../settings/views/admin/emoji/local/new-emoji.tsx | 2 +- .../settings/views/admin/emoji/local/overview.tsx | 2 +- .../settings/views/admin/instance/ruledetail.tsx | 103 +++++++++++ web/source/settings/views/admin/instance/rules.tsx | 75 ++++++++ .../settings/views/admin/instance/settings.tsx | 186 +++++++++++++++++++ web/source/settings/views/admin/menu.tsx | 129 +++++++++++++ web/source/settings/views/admin/router.tsx | 151 ++++++++++++++++ web/source/settings/views/admin/routes.tsx | 177 ------------------ web/source/settings/views/admin/settings/index.tsx | 190 ------------------- web/source/settings/views/admin/settings/rules.tsx | 151 ---------------- .../views/moderation/accounts/detail/actions.tsx | 5 +- .../moderation/accounts/detail/handlesignup.tsx | 6 +- .../views/moderation/accounts/detail/index.tsx | 5 +- .../views/moderation/accounts/pending/index.tsx | 2 +- .../views/moderation/accounts/search/index.tsx | 3 +- .../views/moderation/domain-permissions/form.tsx | 4 - .../moderation/domain-permissions/overview.tsx | 3 - .../moderation/domain-permissions/process.tsx | 2 - web/source/settings/views/moderation/menu.tsx | 121 +++++++++++++ .../settings/views/moderation/reports/detail.tsx | 10 +- .../settings/views/moderation/reports/overview.tsx | 4 +- .../settings/views/moderation/reports/username.tsx | 36 ++-- web/source/settings/views/moderation/router.tsx | 149 +++++++++++++++ web/source/settings/views/moderation/routes.tsx | 201 --------------------- web/source/settings/views/user/menu.tsx | 52 ++++++ web/source/settings/views/user/profile.tsx | 3 +- web/source/settings/views/user/router.tsx | 52 ++++++ web/source/settings/views/user/routes.tsx | 80 -------- web/source/settings/views/user/settings.tsx | 9 +- 31 files changed, 1068 insertions(+), 849 deletions(-) create mode 100644 web/source/settings/views/admin/instance/ruledetail.tsx create mode 100644 web/source/settings/views/admin/instance/rules.tsx create mode 100644 web/source/settings/views/admin/instance/settings.tsx create mode 100644 web/source/settings/views/admin/menu.tsx create mode 100644 web/source/settings/views/admin/router.tsx delete mode 100644 web/source/settings/views/admin/routes.tsx delete mode 100644 web/source/settings/views/admin/settings/index.tsx delete mode 100644 web/source/settings/views/admin/settings/rules.tsx create mode 100644 web/source/settings/views/moderation/menu.tsx create mode 100644 web/source/settings/views/moderation/router.tsx delete mode 100644 web/source/settings/views/moderation/routes.tsx create mode 100644 web/source/settings/views/user/menu.tsx create mode 100644 web/source/settings/views/user/router.tsx delete mode 100644 web/source/settings/views/user/routes.tsx (limited to 'web/source/settings/views') diff --git a/web/source/settings/views/admin/actions/keys/expireremote.tsx b/web/source/settings/views/admin/actions/keys/expireremote.tsx index c7a410267..82045942c 100644 --- a/web/source/settings/views/admin/actions/keys/expireremote.tsx +++ b/web/source/settings/views/admin/actions/keys/expireremote.tsx @@ -18,10 +18,10 @@ */ import React from "react"; -import { useInstanceKeysExpireMutation } from "../../../../lib/query"; import { TextInput } from "../../../../components/form/inputs"; import MutationButton from "../../../../components/form/mutation-button"; import { useTextInput } from "../../../../lib/form"; +import { useInstanceKeysExpireMutation } from "../../../../lib/query/admin"; export default function ExpireRemote({}) { const domainField = useTextInput("domain"); diff --git a/web/source/settings/views/admin/actions/media/cleanup.tsx b/web/source/settings/views/admin/actions/media/cleanup.tsx index d4bae24a6..c1df511e1 100644 --- a/web/source/settings/views/admin/actions/media/cleanup.tsx +++ b/web/source/settings/views/admin/actions/media/cleanup.tsx @@ -19,10 +19,10 @@ import React from "react"; -import { useMediaCleanupMutation } from "../../../../lib/query"; import { useTextInput } from "../../../../lib/form"; import { TextInput } from "../../../../components/form/inputs"; import MutationButton from "../../../../components/form/mutation-button"; +import { useMediaCleanupMutation } from "../../../../lib/query/admin"; export default function Cleanup({}) { const daysField = useTextInput("days", { defaultValue: "30" }); diff --git a/web/source/settings/views/admin/emoji/local/new-emoji.tsx b/web/source/settings/views/admin/emoji/local/new-emoji.tsx index 73e846f16..8ff8236a7 100644 --- a/web/source/settings/views/admin/emoji/local/new-emoji.tsx +++ b/web/source/settings/views/admin/emoji/local/new-emoji.tsx @@ -26,7 +26,7 @@ import { CategorySelect } from '../category-select'; import FakeToot from "../../../../components/fake-toot"; import MutationButton from "../../../../components/form/mutation-button"; import { useAddEmojiMutation } from "../../../../lib/query/admin/custom-emoji"; -import { useInstanceV1Query } from "../../../../lib/query"; +import { useInstanceV1Query } from "../../../../lib/query/gts-api"; export default function NewEmojiForm() { const shortcode = useShortcode(); diff --git a/web/source/settings/views/admin/emoji/local/overview.tsx b/web/source/settings/views/admin/emoji/local/overview.tsx index b28af59f3..b4fa48d74 100644 --- a/web/source/settings/views/admin/emoji/local/overview.tsx +++ b/web/source/settings/views/admin/emoji/local/overview.tsx @@ -29,7 +29,7 @@ import { TextInput } from "../../../../components/form/inputs"; import { useListEmojiQuery } from "../../../../lib/query/admin/custom-emoji"; import { CustomEmoji } from "../../../../lib/types/custom-emoji"; -export function EmojiOverview() { +export default function EmojiOverview() { const { data: emoji = [], isLoading, isError, error } = useListEmojiQuery({ filter: "domain:local" }); let content: React.JSX.Element; diff --git a/web/source/settings/views/admin/instance/ruledetail.tsx b/web/source/settings/views/admin/instance/ruledetail.tsx new file mode 100644 index 000000000..31447c74b --- /dev/null +++ b/web/source/settings/views/admin/instance/ruledetail.tsx @@ -0,0 +1,103 @@ +/* + GoToSocial + Copyright (C) GoToSocial Authors admin@gotosocial.org + SPDX-License-Identifier: AGPL-3.0-or-later + + This program is free software: you can redistribute it and/or modify + it under the terms of the GNU Affero General Public License as published by + the Free Software Foundation, either version 3 of the License, or + (at your option) any later version. + + This program is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + GNU Affero General Public License for more details. + + You should have received a copy of the GNU Affero General Public License + along with this program. If not, see . +*/ + +import React from "react"; +import { Redirect, useParams } from "wouter"; +import { useBaseUrl } from "../../../lib/navigation/util"; +import { useValue, useTextInput } from "../../../lib/form"; +import useFormSubmit from "../../../lib/form/submit"; +import { TextArea } from "../../../components/form/inputs"; +import MutationButton from "../../../components/form/mutation-button"; +import BackButton from "../../../components/back-button"; +import Loading from "../../../components/loading"; +import { useDeleteInstanceRuleMutation, useInstanceRulesQuery, useUpdateInstanceRuleMutation } from "../../../lib/query/admin"; +import { Error } from "../../../components/error"; + +export default function InstanceRuleDetail() { + const baseUrl = useBaseUrl(); + const params: { ruleId: string } = useParams(); + + const { data: rules, isLoading, isError, error } = useInstanceRulesQuery(); + if (isLoading) { + return ; + } else if (isError) { + return ; + } + + if (rules === undefined) { + throw "undefined rules"; + } + + return ( + <> + + + + ); +} + +function EditInstanceRuleForm({ rule }) { + const baseUrl = useBaseUrl(); + const form = { + id: useValue("id", rule.id), + rule: useTextInput("text", { defaultValue: rule.text }) + }; + + const [submitForm, result] = useFormSubmit(form, useUpdateInstanceRuleMutation()); + + const [deleteRule, deleteResult] = useDeleteInstanceRuleMutation({ fixedCacheKey: rule.id }); + + if (result.isSuccess || deleteResult.isSuccess) { + return ( + + ); + } + + return ( +
+
+