From d941dd5bd460e8d9dda005c68fadcace8239fc5c Mon Sep 17 00:00:00 2001 From: Jong Eun Lee Date: Mon, 18 Nov 2024 15:56:21 +0800 Subject: [PATCH] feat: user can open a session detail panel in notifications --- react/src/App.tsx | 6 +++++- react/src/components/WebUINavigate.tsx | 16 ++++++++-------- react/src/pages/SessionLauncherPage.tsx | 5 +++++ 3 files changed, 18 insertions(+), 9 deletions(-) diff --git a/react/src/App.tsx b/react/src/App.tsx index 23d67e5335..123b595931 100644 --- a/react/src/App.tsx +++ b/react/src/App.tsx @@ -19,6 +19,7 @@ import { IndexRouteObject, RouterProvider, createBrowserRouter, + useLocation, } from 'react-router-dom'; import { QueryParamProvider } from 'use-query-params'; import { ReactRouter6Adapter } from 'use-query-params/adapters/react-router-6'; @@ -147,7 +148,10 @@ const router = createBrowserRouter([ children: [ { path: '', - element: , + Component: () => { + const location = useLocation(); + return ; + }, }, { path: '/session/start', diff --git a/react/src/components/WebUINavigate.tsx b/react/src/components/WebUINavigate.tsx index fa16fa052a..c0bc720ba0 100644 --- a/react/src/components/WebUINavigate.tsx +++ b/react/src/components/WebUINavigate.tsx @@ -3,20 +3,20 @@ import _ from 'lodash'; import React, { useEffect } from 'react'; import { Navigate, NavigateProps } from 'react-router-dom'; -interface WebUINavigateProps extends NavigateProps { - options?: { - params?: any; - }; -} -const WebUINavigate: React.FC = ({ options, ...props }) => { +interface WebUINavigateProps extends NavigateProps {} +const WebUINavigate: React.FC = ({ ...props }) => { useSuspendedBackendaiClient(); const pathName = _.isString(props.to) ? props.to : props.to.pathname || ''; + const [path, query] = pathName.split('?'); + const params = { + params: Object.fromEntries(new URLSearchParams(query)), + }; useEffect(() => { document.dispatchEvent( new CustomEvent('move-to-from-react', { detail: { - path: pathName, - params: options?.params, + path: path, + params, }, }), ); diff --git a/react/src/pages/SessionLauncherPage.tsx b/react/src/pages/SessionLauncherPage.tsx index e937fd94f5..2c9877d35f 100644 --- a/react/src/pages/SessionLauncherPage.tsx +++ b/react/src/pages/SessionLauncherPage.tsx @@ -606,6 +606,11 @@ const SessionLauncherPage = () => { sessionName: string; servicePorts: Array<{ name: string }>; }>) => { + // After the session is created, add a "See Details" button to navigate to the session page. + upsertNotification({ + key: 'session-launcher:' + sessionName, + to: `/session?sessionDetail=${firstSession.sessionId}`, + }); pushSessionHistory({ id: firstSession.sessionId, params: usedSearchParams,