X-Git-Url: https://git.arvados.org/arvados-workbench2.git/blobdiff_plain/6149700b801fc2cdb83b0e700bbb319850ed471d..9b28d6d29d9609adc86e3fdc136873c3cf6114ed:/src/routes/routes.ts diff --git a/src/routes/routes.ts b/src/routes/routes.ts index 0bf71101..20dd1359 100644 --- a/src/routes/routes.ts +++ b/src/routes/routes.ts @@ -3,19 +3,20 @@ // SPDX-License-Identifier: AGPL-3.0 import { History, Location } from 'history'; -import { RootStore } from '../store/store'; +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 { getCollectionUrl } from '~/models/collection'; -import { loadProject, loadFavorites, loadCollection } from '../store/workbench/workbench-actions'; +import { loadProject, loadFavorites, loadCollection } from '~/store/workbench/workbench-actions'; +import { loadProcess } from '~/store/processes/processes-actions'; export const Routes = { ROOT: '/', TOKEN: '/token', PROJECTS: `/projects/:id(${RESOURCE_UUID_PATTERN})`, COLLECTIONS: `/collections/:id(${RESOURCE_UUID_PATTERN})`, - PROCESS: `/processes/:id(${RESOURCE_UUID_PATTERN})`, + PROCESSES: `/processes/:id(${RESOURCE_UUID_PATTERN})`, FAVORITES: '/favorites', }; @@ -31,6 +32,8 @@ export const getResourceUrl = (uuid: string) => { } }; +export const getProcessUrl = (uuid: string) => `/processes/${uuid}`; + export const addRouteChangeHandlers = (history: History, store: RootStore) => { const handler = handleLocationChange(store); handler(history.location); @@ -43,30 +46,32 @@ export const matchRootRoute = (route: string) => export const matchFavoritesRoute = (route: string) => matchPath(route, { path: Routes.FAVORITES }); -export interface ProjectRouteParams { +export interface ResourceRouteParams { id: string; } export const matchProjectRoute = (route: string) => - matchPath(route, { path: Routes.PROJECTS }); - -export interface CollectionRouteParams { - id: string; -} + matchPath(route, { path: Routes.PROJECTS }); export const matchCollectionRoute = (route: string) => - matchPath(route, { path: Routes.COLLECTIONS }); + matchPath(route, { path: Routes.COLLECTIONS }); + +export const matchProcessRoute = (route: string) => + matchPath(route, { path: Routes.PROCESSES }); const handleLocationChange = (store: RootStore) => ({ pathname }: Location) => { const projectMatch = matchProjectRoute(pathname); const collectionMatch = matchCollectionRoute(pathname); const favoriteMatch = matchFavoritesRoute(pathname); + const processMatch = matchProcessRoute(pathname); 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(loadProcess(processMatch.params.id)); } };