X-Git-Url: https://git.arvados.org/arvados-workbench2.git/blobdiff_plain/847ac07f82a1432d6472390aab5e8c2198d425a5..eb9611ea28acee0a8fdef772ef8d1b31ac689e4c:/src/routes/routes.ts diff --git a/src/routes/routes.ts b/src/routes/routes.ts index 432cf750..7e6897a8 100644 --- a/src/routes/routes.ts +++ b/src/routes/routes.ts @@ -2,7 +2,7 @@ // // SPDX-License-Identifier: AGPL-3.0 -import { matchPath } from 'react-router'; +import { matchPath, Router } from 'react-router'; import { ResourceKind, RESOURCE_UUID_PATTERN, extractUuidKind } from '~/models/resource'; import { getProjectUrl } from '~/models/project'; import { getCollectionUrl } from '~/models/collection'; @@ -10,15 +10,34 @@ import { getCollectionUrl } from '~/models/collection'; export const Routes = { ROOT: '/', TOKEN: '/token', + FED_LOGIN: '/fedtoken', PROJECTS: `/projects/:id(${RESOURCE_UUID_PATTERN})`, COLLECTIONS: `/collections/:id(${RESOURCE_UUID_PATTERN})`, PROCESSES: `/processes/:id(${RESOURCE_UUID_PATTERN})`, FAVORITES: '/favorites', TRASH: '/trash', PROCESS_LOGS: `/process-logs/:id(${RESOURCE_UUID_PATTERN})`, + REPOSITORIES: '/repositories', SHARED_WITH_ME: '/shared-with-me', RUN_PROCESS: '/run-process', - WORKFLOWS: '/workflows' + VIRTUAL_MACHINES_ADMIN: '/virtual-machines-admin', + VIRTUAL_MACHINES_USER: '/virtual-machines-user', + WORKFLOWS: '/workflows', + SEARCH_RESULTS: '/search-results', + SSH_KEYS_ADMIN: `/ssh-keys-admin`, + SSH_KEYS_USER: `/ssh-keys-user`, + SITE_MANAGER: `/site-manager`, + MY_ACCOUNT: '/my-account', + LINK_ACCOUNT: '/link_account', + KEEP_SERVICES: `/keep-services`, + COMPUTE_NODES: `/nodes`, + USERS: '/users', + API_CLIENT_AUTHORIZATIONS: `/api_client_authorizations`, + GROUPS: '/groups', + GROUP_DETAILS: `/group/:id(${RESOURCE_UUID_PATTERN})`, + LINKS: '/links', + PUBLIC_FAVORITES: '/public-favorites', + COLLECTIONS_CONTENT_ADDRESS: '/collections/:id', }; export const getResourceUrl = (uuid: string) => { @@ -39,6 +58,8 @@ export const getProcessUrl = (uuid: string) => `/processes/${uuid}`; export const getProcessLogUrl = (uuid: string) => `/process-logs/${uuid}`; +export const getGroupUrl = (uuid: string) => `/group/${uuid}`; + export interface ResourceRouteParams { id: string; } @@ -69,6 +90,66 @@ export const matchSharedWithMeRoute = (route: string) => export const matchRunProcessRoute = (route: string) => matchPath(route, { path: Routes.RUN_PROCESS }); - + export const matchWorkflowRoute = (route: string) => matchPath(route, { path: Routes.WORKFLOWS }); + +export const matchSearchResultsRoute = (route: string) => + matchPath(route, { path: Routes.SEARCH_RESULTS }); + +export const matchUserVirtualMachineRoute = (route: string) => + matchPath(route, { path: Routes.VIRTUAL_MACHINES_USER }); + +export const matchAdminVirtualMachineRoute = (route: string) => + matchPath(route, { path: Routes.VIRTUAL_MACHINES_ADMIN }); + +export const matchRepositoriesRoute = (route: string) => + matchPath(route, { path: Routes.REPOSITORIES }); + +export const matchSshKeysUserRoute = (route: string) => + matchPath(route, { path: Routes.SSH_KEYS_USER }); + +export const matchSshKeysAdminRoute = (route: string) => + matchPath(route, { path: Routes.SSH_KEYS_ADMIN }); + +export const matchSiteManagerRoute = (route: string) => + matchPath(route, { path: Routes.SITE_MANAGER }); + +export const matchMyAccountRoute = (route: string) => + matchPath(route, { path: Routes.MY_ACCOUNT }); + +export const matchLinkAccountRoute = (route: string) => + matchPath(route, { path: Routes.LINK_ACCOUNT }); + +export const matchKeepServicesRoute = (route: string) => + matchPath(route, { path: Routes.KEEP_SERVICES }); + +export const matchTokenRoute = (route: string) => + matchPath(route, { path: Routes.TOKEN }); + +export const matchFedTokenRoute = (route: string) => + matchPath(route, {path: Routes.FED_LOGIN}); + +export const matchUsersRoute = (route: string) => + matchPath(route, { path: Routes.USERS }); + +export const matchComputeNodesRoute = (route: string) => + matchPath(route, { path: Routes.COMPUTE_NODES }); + +export const matchApiClientAuthorizationsRoute = (route: string) => + matchPath(route, { path: Routes.API_CLIENT_AUTHORIZATIONS }); + +export const matchGroupsRoute = (route: string) => + matchPath(route, { path: Routes.GROUPS }); + +export const matchGroupDetailsRoute = (route: string) => + matchPath(route, { path: Routes.GROUP_DETAILS }); + +export const matchLinksRoute = (route: string) => + matchPath(route, { path: Routes.LINKS }); + +export const matchPublicFavoritesRoute = (route: string) => + matchPath(route, { path: Routes.PUBLIC_FAVORITES }); + +export const matchCollectionsContentAddressRoute = (route: string) => + matchPath(route, { path: Routes.COLLECTIONS_CONTENT_ADDRESS });