X-Git-Url: https://git.arvados.org/arvados-workbench2.git/blobdiff_plain/59b24ea9a90ba60563316a5c2ad4c7ce8a8c423d..eda5e30d786d5d1224a552e962b6b711efab7369:/src/routes/routes.ts?ds=sidebyside diff --git a/src/routes/routes.ts b/src/routes/routes.ts index 0bf71101..34b15e11 100644 --- a/src/routes/routes.ts +++ b/src/routes/routes.ts @@ -2,21 +2,22 @@ // // 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 } from '../store/workbench/workbench-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', + TRASH: '/trash', + PROCESS_LOGS: `/process-logs/:id(${RESOURCE_UUID_PATTERN})`, + SHARED_WITH_ME: '/shared-with-me', + WORKFLOWS: '/workflows' }; export const getResourceUrl = (uuid: string) => { @@ -26,16 +27,20 @@ export const getResourceUrl = (uuid: string) => { return getProjectUrl(uuid); case ResourceKind.COLLECTION: return getCollectionUrl(uuid); + case ResourceKind.PROCESS: + return getProcessUrl(uuid); default: return undefined; } }; -export const addRouteChangeHandlers = (history: History, store: RootStore) => { - const handler = handleLocationChange(store); - handler(history.location); - history.listen(handler); -}; +export const getProcessUrl = (uuid: string) => `/processes/${uuid}`; + +export const getProcessLogUrl = (uuid: string) => `/process-logs/${uuid}`; + +export interface ResourceRouteParams { + id: string; +} export const matchRootRoute = (route: string) => matchPath(route, { path: Routes.ROOT, exact: true }); @@ -43,30 +48,23 @@ export const matchRootRoute = (route: string) => export const matchFavoritesRoute = (route: string) => matchPath(route, { path: Routes.FAVORITES }); -export interface ProjectRouteParams { - id: string; -} +export const matchTrashRoute = (route: string) => + matchPath(route, { path: Routes.TRASH }); 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); - if (projectMatch) { - store.dispatch(loadProject(projectMatch.params.id)); - } else if (collectionMatch) { - store.dispatch(loadCollection(collectionMatch.params.id)); - } else if (favoriteMatch) { - store.dispatch(loadFavorites()); - } -}; +export const matchProcessLogRoute = (route: string) => + matchPath(route, { path: Routes.PROCESS_LOGS }); + +export const matchSharedWithMeRoute = (route: string) => + matchPath(route, { path: Routes.SHARED_WITH_ME }); + +export const matchWorkflowRoute = (route: string) => + matchPath(route, { path: Routes.WORKFLOWS });