From d5847e2d2b68a1eb41d43be170cd4ddff9003cff Mon Sep 17 00:00:00 2001
From: tobi <31960611+tsmethurst@users.noreply.github.com>
Date: Mon, 17 Mar 2025 15:06:17 +0100
Subject: [feature] Application creation + management via API + settings panel
(#3906)
* [feature] Application creation + management via API + settings panel
* fix docs links
* add errnorows test
* use known application as shorter
* add comment about side effects
---
.../settings/components/authorization/index.tsx | 12 +++---
.../settings/components/authorization/login.tsx | 2 +-
web/source/settings/components/highlightedcode.tsx | 44 ++++++++++++++++++++++
web/source/settings/components/status.tsx | 2 +-
.../settings/components/user-logout-card.tsx | 2 +-
5 files changed, 53 insertions(+), 9 deletions(-)
create mode 100644 web/source/settings/components/highlightedcode.tsx
(limited to 'web/source/settings/components')
diff --git a/web/source/settings/components/authorization/index.tsx b/web/source/settings/components/authorization/index.tsx
index 7c6373399..3eeeb393a 100644
--- a/web/source/settings/components/authorization/index.tsx
+++ b/web/source/settings/components/authorization/index.tsx
@@ -17,7 +17,7 @@
along with this program. If not, see .
*/
-import { useLogoutMutation, useVerifyCredentialsQuery } from "../../lib/query/oauth";
+import { useLogoutMutation, useVerifyCredentialsQuery } from "../../lib/query/login";
import { store } from "../../redux/store";
import React, { ReactNode } from "react";
@@ -27,8 +27,8 @@ import { Error } from "../error";
import { NoArg } from "../../lib/types/query";
export function Authorization({ App }) {
- const { loginState, expectingRedirect } = store.getState().oauth;
- const skip = (loginState == "none" || loginState == "logout" || expectingRedirect);
+ const { current: loginState, expectingRedirect } = store.getState().login;
+ const skip = (loginState == "none" || loginState == "loggedout" || expectingRedirect);
const [ logoutQuery ] = useLogoutMutation();
const {
@@ -46,9 +46,9 @@ export function Authorization({ App }) {
showLogin = false;
let loadingInfo = "";
- if (loginState == "callback") {
+ if (loginState == "awaitingcallback") {
loadingInfo = "Processing OAUTH callback.";
- } else if (loginState == "login") {
+ } else if (loginState == "loggedin") {
loadingInfo = "Verifying stored login.";
}
@@ -70,7 +70,7 @@ export function Authorization({ App }) {
);
}
- if (loginState == "login" && isSuccess) {
+ if (loginState == "loggedin" && isSuccess) {
return ;
} else {
return (
diff --git a/web/source/settings/components/authorization/login.tsx b/web/source/settings/components/authorization/login.tsx
index 28ed7953c..c54125972 100644
--- a/web/source/settings/components/authorization/login.tsx
+++ b/web/source/settings/components/authorization/login.tsx
@@ -19,7 +19,7 @@
import React from "react";
-import { useAuthorizeFlowMutation } from "../../lib/query/oauth";
+import { useAuthorizeFlowMutation } from "../../lib/query/login";
import { useTextInput, useValue } from "../../lib/form";
import useFormSubmit from "../../lib/form/submit";
import MutationButton from "../form/mutation-button";
diff --git a/web/source/settings/components/highlightedcode.tsx b/web/source/settings/components/highlightedcode.tsx
new file mode 100644
index 000000000..eccecd709
--- /dev/null
+++ b/web/source/settings/components/highlightedcode.tsx
@@ -0,0 +1,44 @@
+/*
+ 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";
+
+// Used for syntax highlighting of json result.
+import Prism from "../../frontend/prism";
+
+export function HighlightedCode({ code, lang }: { code: string, lang: 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 (
+
+ );
+}
diff --git a/web/source/settings/components/status.tsx b/web/source/settings/components/status.tsx
index ec7af3ad3..701a9f8b7 100644
--- a/web/source/settings/components/status.tsx
+++ b/web/source/settings/components/status.tsx
@@ -18,7 +18,7 @@
*/
import React from "react";
-import { useVerifyCredentialsQuery } from "../lib/query/oauth";
+import { useVerifyCredentialsQuery } from "../lib/query/login";
import { MediaAttachment, Status as StatusType } from "../lib/types/status";
import sanitize from "sanitize-html";
diff --git a/web/source/settings/components/user-logout-card.tsx b/web/source/settings/components/user-logout-card.tsx
index f9acc9698..e15a1ee6a 100644
--- a/web/source/settings/components/user-logout-card.tsx
+++ b/web/source/settings/components/user-logout-card.tsx
@@ -20,7 +20,7 @@
import React from "react";
import Loading from "./loading";
import { Error as ErrorC } from "./error";
-import { useVerifyCredentialsQuery, useLogoutMutation } from "../lib/query/oauth";
+import { useVerifyCredentialsQuery, useLogoutMutation } from "../lib/query/login";
import { useInstanceV1Query } from "../lib/query/gts-api";
export default function UserLogoutCard() {
--
cgit v1.2.3