summaryrefslogtreecommitdiff
path: root/web/source/settings/views/user/router.tsx
diff options
context:
space:
mode:
authorLibravatar tobi <31960611+tsmethurst@users.noreply.github.com>2025-03-17 15:06:17 +0100
committerLibravatar GitHub <noreply@github.com>2025-03-17 14:06:17 +0000
commitd5847e2d2b68a1eb41d43be170cd4ddff9003cff (patch)
tree7352e79110b081eb72d483358f5c07c8d34c29ff /web/source/settings/views/user/router.tsx
parent[feature/frontend] Add visibility icon for posts (#3908) (diff)
downloadgotosocial-d5847e2d2b68a1eb41d43be170cd4ddff9003cff.tar.xz
[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
Diffstat (limited to 'web/source/settings/views/user/router.tsx')
-rw-r--r--web/source/settings/views/user/router.tsx59
1 files changed, 45 insertions, 14 deletions
diff --git a/web/source/settings/views/user/router.tsx b/web/source/settings/views/user/router.tsx
index be1fa4434..0d34c171f 100644
--- a/web/source/settings/views/user/router.tsx
+++ b/web/source/settings/views/user/router.tsx
@@ -29,6 +29,10 @@ import ExportImport from "./export-import";
import InteractionRequests from "./interactions";
import InteractionRequestDetail from "./interactions/detail";
import Tokens from "./tokens";
+import Applications from "./applications";
+import NewApp from "./applications/new";
+import AppDetail from "./applications/detail";
+import { AppTokenCallback } from "./applications/callback";
/**
* - /settings/user/profile
@@ -37,7 +41,8 @@ import Tokens from "./tokens";
* - /settings/user/migration
* - /settings/user/export-import
* - /settings/user/tokens
- * - /settings/users/interaction_requests
+ * - /settings/user/interaction_requests
+ * - /settings/user/applications
*/
export default function UserRouter() {
const baseUrl = useBaseUrl();
@@ -47,16 +52,40 @@ export default function UserRouter() {
return (
<BaseUrlContext.Provider value={absBase}>
<Router base={thisBase}>
+ <Switch>
+ <Route path="/profile" component={UserProfile} />
+ <Route path="/posts" component={PostSettings} />
+ <Route path="/emailpassword" component={EmailPassword} />
+ <Route path="/migration" component={UserMigration} />
+ <Route path="/export-import" component={ExportImport} />
+ <Route path="/tokens" component={Tokens} />
+ </Switch>
+ <InteractionRequestsRouter />
+ <ApplicationsRouter />
+ </Router>
+ </BaseUrlContext.Provider>
+ );
+}
+
+/**
+ * - /settings/user/applications/search
+ * - /settings/user/applications/{appID}
+ */
+function ApplicationsRouter() {
+ const parentUrl = useBaseUrl();
+ const thisBase = "/applications";
+ const absBase = parentUrl + thisBase;
+
+ return (
+ <BaseUrlContext.Provider value={absBase}>
+ <Router base={thisBase}>
<ErrorBoundary>
<Switch>
- <Route path="/profile" component={UserProfile} />
- <Route path="/posts" component={PostSettings} />
- <Route path="/emailpassword" component={EmailPassword} />
- <Route path="/migration" component={UserMigration} />
- <Route path="/export-import" component={ExportImport} />
- <Route path="/tokens" component={Tokens} />
- <InteractionRequestsRouter />
- <Route><Redirect to="/profile" /></Route>
+ <Route path="/search" component={Applications} />
+ <Route path="/new" component={NewApp} />
+ <Route path="/callback" component={AppTokenCallback} />
+ <Route path="/:appId" component={AppDetail} />
+ <Route><Redirect to="/search"/></Route>
</Switch>
</ErrorBoundary>
</Router>
@@ -76,11 +105,13 @@ function InteractionRequestsRouter() {
return (
<BaseUrlContext.Provider value={absBase}>
<Router base={thisBase}>
- <Switch>
- <Route path="/search" component={InteractionRequests} />
- <Route path="/:reqId" component={InteractionRequestDetail} />
- <Route><Redirect to="/search"/></Route>
- </Switch>
+ <ErrorBoundary>
+ <Switch>
+ <Route path="/search" component={InteractionRequests} />
+ <Route path="/:reqId" component={InteractionRequestDetail} />
+ <Route><Redirect to="/search"/></Route>
+ </Switch>
+ </ErrorBoundary>
</Router>
</BaseUrlContext.Provider>
);