diff options
| author | 2025-03-17 15:06:17 +0100 | |
|---|---|---|
| committer | 2025-03-17 14:06:17 +0000 | |
| commit | d5847e2d2b68a1eb41d43be170cd4ddff9003cff (patch) | |
| tree | 7352e79110b081eb72d483358f5c07c8d34c29ff /web/source/settings/views/user/router.tsx | |
| parent | [feature/frontend] Add visibility icon for posts (#3908) (diff) | |
| download | gotosocial-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.tsx | 59 |
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> ); |
