From d79c2f26888b512faaa0526936b8752cfb6c8b28 Mon Sep 17 00:00:00 2001
From: tobi <31960611+tsmethurst@users.noreply.github.com>
Date: Mon, 3 Jun 2024 11:20:53 +0200
Subject: [feature/frontend] Add debug sections to settings panel (#2950)
* [feature/frontend] Add debug sections to settings panel
* max-width
* swagger
---
.../settings/views/admin/debug/apurl/index.tsx | 124 +++++++++++++++++++++
1 file changed, 124 insertions(+)
create mode 100644 web/source/settings/views/admin/debug/apurl/index.tsx
(limited to 'web/source/settings/views/admin/debug/apurl')
diff --git a/web/source/settings/views/admin/debug/apurl/index.tsx b/web/source/settings/views/admin/debug/apurl/index.tsx
new file mode 100644
index 000000000..a0c2fc738
--- /dev/null
+++ b/web/source/settings/views/admin/debug/apurl/index.tsx
@@ -0,0 +1,124 @@
+/*
+ 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, { useEffect, useRef } from "react";
+import { useTextInput } from "../../../../lib/form";
+import { useLazyApURLQuery } from "../../../../lib/query/admin/debug";
+import { TextInput } from "../../../../components/form/inputs";
+import MutationButton from "../../../../components/form/mutation-button";
+import { ApURLResponse } from "../../../../lib/types/debug";
+import Loading from "../../../../components/loading";
+
+// Used for syntax highlighting of json result.
+import Prism from "../../../../../frontend/prism";
+
+export default function ApURL() {
+ const urlField = useTextInput("url");
+
+ const [apURL, apURLResult] = useLazyApURLQuery();
+ function submit(e) {
+ e.preventDefault();
+ apURL(urlField.value ?? "");
+ }
+
+ return (
+
+ );
+}
+
+interface ApURLResultProps {
+ isLoading: boolean;
+ isFetching: boolean;
+ isSuccess: boolean;
+ data?: ApURLResponse,
+ isError: boolean;
+}
+
+function ApURLResult({
+ isLoading,
+ isFetching,
+ isSuccess,
+ data,
+ isError,
+}: ApURLResultProps) {
+ if (!(isSuccess || isError)) {
+ // Hasn't been called yet.
+ return null;
+ }
+
+ if (isLoading || isFetching) {
+ return ;
+ }
+
+ if (!data) {
+ return "No data";
+ }
+
+ const jsonObj = {
+ ...data,
+ response_body: data.response_body.length > 0 ? JSON.parse(data.response_body) : "",
+ };
+
+ const jsonStr = JSON.stringify(jsonObj, null, 2);
+ return ;
+}
+
+function Highlighted({ jsonStr }: { jsonStr: string }) {
+ const ref = useRef(null);
+ useEffect(() => {
+ if (ref.current) {
+ Prism.highlightElement(ref.current);
+ }
+ }, []);
+
+ // Prism takes control of the `pre` so wrap
+ // the whole thing in a div that we control.
+ return (
+
+ );
+}
--
cgit v1.2.3