From 5579795e7045b0724b0f9f74949f90e3614289a9 Mon Sep 17 00:00:00 2001 From: Griffin Tarpenning Date: Thu, 10 Oct 2024 11:11:30 -0700 Subject: [PATCH] chore: added/removed evals reflected in URL state (#2665) --- .../PagePanelComponents/Home/Browse3.tsx | 11 ++++++++ .../Home/Browse3/pages/CallPage/CallPage.tsx | 2 ++ .../CompareEvaluationsPage.tsx | 3 +++ .../compareEvaluationsContext.tsx | 14 ++++++++-- .../EvaluationDefinition.tsx | 26 ++++++++++--------- 5 files changed, 42 insertions(+), 14 deletions(-) diff --git a/weave-js/src/components/PagePanelComponents/Home/Browse3.tsx b/weave-js/src/components/PagePanelComponents/Home/Browse3.tsx index fc004b04717c..0635fbfbb501 100644 --- a/weave-js/src/components/PagePanelComponents/Home/Browse3.tsx +++ b/weave-js/src/components/PagePanelComponents/Home/Browse3.tsx @@ -921,16 +921,27 @@ const OpPageBinding = () => { }; const CompareEvaluationsBinding = () => { + const history = useHistory(); + const location = useLocation(); const {entity, project} = useParamsDecoded(); const query = useURLSearchParamsDict(); const evaluationCallIds = useMemo(() => { return JSON.parse(query.evaluationCallIds); }, [query.evaluationCallIds]); + const onEvaluationCallIdsUpdate = useCallback( + (newEvaluationCallIds: string[]) => { + const newQuery = new URLSearchParams(location.search); + newQuery.set('evaluationCallIds', JSON.stringify(newEvaluationCallIds)); + history.push({search: newQuery.toString()}); + }, + [history, location.search] + ); return ( ); }; diff --git a/weave-js/src/components/PagePanelComponents/Home/Browse3/pages/CallPage/CallPage.tsx b/weave-js/src/components/PagePanelComponents/Home/Browse3/pages/CallPage/CallPage.tsx index 9f8852686421..8e179da6742e 100644 --- a/weave-js/src/components/PagePanelComponents/Home/Browse3/pages/CallPage/CallPage.tsx +++ b/weave-js/src/components/PagePanelComponents/Home/Browse3/pages/CallPage/CallPage.tsx @@ -64,6 +64,8 @@ const useCallTabs = (call: CallSchema) => { entity={call.entity} project={call.project} evaluationCallIds={[call.callId]} + // Dont persist changes to evaluationCallIds in the URL + onEvaluationCallIdsUpdate={() => {}} /> ), }, diff --git a/weave-js/src/components/PagePanelComponents/Home/Browse3/pages/CompareEvaluationsPage/CompareEvaluationsPage.tsx b/weave-js/src/components/PagePanelComponents/Home/Browse3/pages/CompareEvaluationsPage/CompareEvaluationsPage.tsx index 05da3ba49ed0..7cd3385f8aee 100644 --- a/weave-js/src/components/PagePanelComponents/Home/Browse3/pages/CompareEvaluationsPage/CompareEvaluationsPage.tsx +++ b/weave-js/src/components/PagePanelComponents/Home/Browse3/pages/CompareEvaluationsPage/CompareEvaluationsPage.tsx @@ -38,6 +38,7 @@ type CompareEvaluationsPageProps = { entity: string; project: string; evaluationCallIds: string[]; + onEvaluationCallIdsUpdate: (newEvaluationCallIds: string[]) => void; }; export const CompareEvaluationsPage: React.FC< @@ -55,6 +56,7 @@ export const CompareEvaluationsPage: React.FC< entity={props.entity} project={props.project} evaluationCallIds={props.evaluationCallIds} + onEvaluationCallIdsUpdate={props.onEvaluationCallIdsUpdate} /> ), }, @@ -113,6 +115,7 @@ export const CompareEvaluationsPageContent: React.FC< initialEvaluationCallIds={props.evaluationCallIds} baselineEvaluationCallId={baselineEvaluationCallId ?? undefined} comparisonDimensions={comparisonDimensions ?? undefined} + onEvaluationCallIdsUpdate={props.onEvaluationCallIdsUpdate} setBaselineEvaluationCallId={setBaselineEvaluationCallId} setComparisonDimensions={setComparisonDimensionsAndClearInputDigest} selectedInputDigest={selectedInputDigest ?? undefined} diff --git a/weave-js/src/components/PagePanelComponents/Home/Browse3/pages/CompareEvaluationsPage/compareEvaluationsContext.tsx b/weave-js/src/components/PagePanelComponents/Home/Browse3/pages/CompareEvaluationsPage/compareEvaluationsContext.tsx index aa26f7ca5160..768ab2555a25 100644 --- a/weave-js/src/components/PagePanelComponents/Home/Browse3/pages/CompareEvaluationsPage/compareEvaluationsContext.tsx +++ b/weave-js/src/components/PagePanelComponents/Home/Browse3/pages/CompareEvaluationsPage/compareEvaluationsContext.tsx @@ -32,6 +32,7 @@ export const CompareEvaluationsProvider: React.FC<{ entity: string; project: string; initialEvaluationCallIds: string[]; + onEvaluationCallIdsUpdate: (newEvaluationCallIds: string[]) => void; setBaselineEvaluationCallId: React.Dispatch< React.SetStateAction >; @@ -46,6 +47,7 @@ export const CompareEvaluationsProvider: React.FC<{ entity, project, initialEvaluationCallIds, + onEvaluationCallIdsUpdate, setBaselineEvaluationCallId, setComparisonDimensions, @@ -78,15 +80,23 @@ export const CompareEvaluationsProvider: React.FC<{ setComparisonDimensions, setSelectedInputDigest, addEvaluationCall: (newCallId: string) => { - setEvaluationCallIds(prev => [...prev, newCallId]); + const newEvaluationCallIds = [...evaluationCallIds, newCallId]; + setEvaluationCallIds(newEvaluationCallIds); + onEvaluationCallIdsUpdate(newEvaluationCallIds); }, removeEvaluationCall: (callId: string) => { - setEvaluationCallIds(prev => prev.filter(id => id !== callId)); + const newEvaluationCallIds = evaluationCallIds.filter( + id => id !== callId + ); + setEvaluationCallIds(newEvaluationCallIds); + onEvaluationCallIdsUpdate(newEvaluationCallIds); }, }; }, [ initialState.loading, initialState.result, + evaluationCallIds, + onEvaluationCallIdsUpdate, setEvaluationCallIds, setBaselineEvaluationCallId, setComparisonDimensions, diff --git a/weave-js/src/components/PagePanelComponents/Home/Browse3/pages/CompareEvaluationsPage/sections/ComparisonDefinitionSection/EvaluationDefinition.tsx b/weave-js/src/components/PagePanelComponents/Home/Browse3/pages/CompareEvaluationsPage/sections/ComparisonDefinitionSection/EvaluationDefinition.tsx index 7fdb0c6c9482..adc80d044f6e 100644 --- a/weave-js/src/components/PagePanelComponents/Home/Browse3/pages/CompareEvaluationsPage/sections/ComparisonDefinitionSection/EvaluationDefinition.tsx +++ b/weave-js/src/components/PagePanelComponents/Home/Browse3/pages/CompareEvaluationsPage/sections/ComparisonDefinitionSection/EvaluationDefinition.tsx @@ -75,18 +75,20 @@ export const EvaluationDefinition: React.FC<{ {props.callId === props.state.baselineEvaluationCallId && ( )} - - } - /> +
+ + } + /> +
); };