X-Git-Url: https://git.arvados.org/arvados-workbench2.git/blobdiff_plain/5cc899fc13465c57f16adf69a593a4354e6e0eb3..77f285190a3ae77a1075b249ca964b1afeed7ca2:/src/routes/routes.ts diff --git a/src/routes/routes.ts b/src/routes/routes.ts index 30040e6d..b1da9496 100644 --- a/src/routes/routes.ts +++ b/src/routes/routes.ts @@ -2,14 +2,10 @@ // // SPDX-License-Identifier: AGPL-3.0 -import { History, Location } from 'history'; -import { RootStore } from '~/store/store'; import { matchPath } from 'react-router'; import { ResourceKind, RESOURCE_UUID_PATTERN, extractUuidKind } from '~/models/resource'; -import { getProjectUrl } from '../models/project'; +import { getProjectUrl } from '~/models/project'; import { getCollectionUrl } from '~/models/collection'; -import { loadProject, loadFavorites, loadCollection, loadProcessLog } from '~/store/workbench/workbench-actions'; -import { loadProcessPanel } from '~/store/process-panel/process-panel-actions'; export const Routes = { ROOT: '/', @@ -18,7 +14,26 @@ export const Routes = { COLLECTIONS: `/collections/:id(${RESOURCE_UUID_PATTERN})`, PROCESSES: `/processes/:id(${RESOURCE_UUID_PATTERN})`, FAVORITES: '/favorites', - PROCESS_LOGS: `/process-logs/:id(${RESOURCE_UUID_PATTERN})` + TRASH: '/trash', + PROCESS_LOGS: `/process-logs/:id(${RESOURCE_UUID_PATTERN})`, + REPOSITORIES: '/repositories', + SHARED_WITH_ME: '/shared-with-me', + RUN_PROCESS: '/run-process', + 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', + 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' }; export const getResourceUrl = (uuid: string) => { @@ -28,6 +43,8 @@ export const getResourceUrl = (uuid: string) => { return getProjectUrl(uuid); case ResourceKind.COLLECTION: return getCollectionUrl(uuid); + case ResourceKind.PROCESS: + return getProcessUrl(uuid); default: return undefined; } @@ -37,11 +54,11 @@ export const getProcessUrl = (uuid: string) => `/processes/${uuid}`; export const getProcessLogUrl = (uuid: string) => `/process-logs/${uuid}`; -export const addRouteChangeHandlers = (history: History, store: RootStore) => { - const handler = handleLocationChange(store); - handler(history.location); - history.listen(handler); -}; +export const getGroupUrl = (uuid: string) => `/group/${uuid}`; + +export interface ResourceRouteParams { + id: string; +} export const matchRootRoute = (route: string) => matchPath(route, { path: Routes.ROOT, exact: true }); @@ -49,9 +66,8 @@ export const matchRootRoute = (route: string) => export const matchFavoritesRoute = (route: string) => matchPath(route, { path: Routes.FAVORITES }); -export interface ResourceRouteParams { - id: string; -} +export const matchTrashRoute = (route: string) => + matchPath(route, { path: Routes.TRASH }); export const matchProjectRoute = (route: string) => matchPath(route, { path: Routes.PROJECTS }); @@ -65,22 +81,56 @@ export const matchProcessRoute = (route: string) => export const matchProcessLogRoute = (route: string) => matchPath(route, { path: Routes.PROCESS_LOGS }); -const handleLocationChange = (store: RootStore) => ({ pathname }: Location) => { - const projectMatch = matchProjectRoute(pathname); - const collectionMatch = matchCollectionRoute(pathname); - const favoriteMatch = matchFavoritesRoute(pathname); - const processMatch = matchProcessRoute(pathname); - const processLogMatch = matchProcessLogRoute(pathname); +export const matchSharedWithMeRoute = (route: string) => + matchPath(route, { path: Routes.SHARED_WITH_ME }); + +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 matchKeepServicesRoute = (route: string) => + matchPath(route, { path: Routes.KEEP_SERVICES }); + +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 }); - if (projectMatch) { - store.dispatch(loadProject(projectMatch.params.id)); - } else if (collectionMatch) { - store.dispatch(loadCollection(collectionMatch.params.id)); - } else if (favoriteMatch) { - store.dispatch(loadFavorites()); - } else if (processMatch) { - store.dispatch(loadProcessPanel(processMatch.params.id)); - } else if (processLogMatch) { - store.dispatch(loadProcessLog(processLogMatch.params.id)); - } -}; +export const matchLinksRoute = (route: string) => + matchPath(route, { path: Routes.LINKS });