From 4e7107809a3d108e6cdcbb1934a7924242432ca3 Mon Sep 17 00:00:00 2001 From: Jennifer Chen Date: Tue, 31 Oct 2023 14:13:24 -0700 Subject: [PATCH 1/3] Fix vizualization page tabs --- src/components/Visualizations/VisualizationTabs.tsx | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/components/Visualizations/VisualizationTabs.tsx b/src/components/Visualizations/VisualizationTabs.tsx index 54f44f278..cb4376f3a 100644 --- a/src/components/Visualizations/VisualizationTabs.tsx +++ b/src/components/Visualizations/VisualizationTabs.tsx @@ -54,7 +54,7 @@ export const VisualizationsTabs = ({ selectedSection }: { selectedSection: VizSe const index = sections.findIndex((section) => section.id === selectedSection); const onPageChange = (index: number) => { - void router.push({ pathname: sections[index].path, query: router.query }, null, { shallow: true }); + void router.push({ pathname: sections[index].path, query: router.query }, null); }; return ( From 36fccaaa542b3b8547a8749397a8d83dba37159b Mon Sep 17 00:00:00 2001 From: Jennifer Chen Date: Tue, 31 Oct 2023 14:38:54 -0700 Subject: [PATCH 2/3] fix undefined error --- src/components/ResultList/Item/Item.tsx | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/components/ResultList/Item/Item.tsx b/src/components/ResultList/Item/Item.tsx index db214c0e7..2f6813709 100644 --- a/src/components/ResultList/Item/Item.tsx +++ b/src/components/ResultList/Item/Item.tsx @@ -64,7 +64,7 @@ export const Item = (props: IItemProps): ReactElement => { const formattedPubDate = getFomattedNumericPubdate(pubdate); const isClient = useIsClient(); const truncatedPub = - pub.length > APP_DEFAULTS.RESULT_ITEM_PUB_CUTOFF ? pub.slice(0, APP_DEFAULTS.RESULT_ITEM_PUB_CUTOFF) + '...' : pub; + pub?.length > APP_DEFAULTS.RESULT_ITEM_PUB_CUTOFF ? pub.slice(0, APP_DEFAULTS.RESULT_ITEM_PUB_CUTOFF) + '...' : pub; // memoize the isSelected callback on bibcode const isChecked = useStore(useCallback((state) => state.isDocSelected(bibcode), [bibcode])); From 9273ba5cb0d6ce83ef7e243a1104a0d58013926f Mon Sep 17 00:00:00 2001 From: Jennifer Chen Date: Tue, 31 Oct 2023 15:26:58 -0700 Subject: [PATCH 3/3] Fix an auto tab switch during render --- .../Containers/AuthorNetworkPageContainer.tsx | 3 +++ .../NetworkDetails/AuthorNetworkDetailsPane.tsx | 12 ++++++++++-- 2 files changed, 13 insertions(+), 2 deletions(-) diff --git a/src/components/Visualizations/Containers/AuthorNetworkPageContainer.tsx b/src/components/Visualizations/Containers/AuthorNetworkPageContainer.tsx index 915b52435..64a582ffe 100644 --- a/src/components/Visualizations/Containers/AuthorNetworkPageContainer.tsx +++ b/src/components/Visualizations/Containers/AuthorNetworkPageContainer.tsx @@ -49,6 +49,7 @@ interface IAuthorNetworkPageState { type AuthorNetworkPageAction = | { type: 'CHANGE_PAPER_LIMIT'; payload: number } | { type: 'SET_SELECTED'; payload: { node: IADSApiAuthorNetworkNode; dict: IBibcodeDict } } + | { type: 'DESELECT' } | { type: 'ADD_FILTER'; payload: IAuthorNetworkNodeDetails } | { type: 'REMOVE_FILTER'; payload: IAuthorNetworkNodeDetails } | { type: 'REMOVE_FILTER_TAG'; payload: ITagItem } @@ -60,6 +61,8 @@ const reducer: Reducer = (stat return { ...state, selected: null, filters: [], rowsToFetch: action.payload }; case 'SET_SELECTED': return { ...state, selected: getAuthorNetworkNodeDetails(action.payload.node, action.payload.dict) }; + case 'DESELECT': + return { ...state, selected: null }; case 'ADD_FILTER': return { ...state, filters: uniq([...state.filters, action.payload]) }; case 'REMOVE_FILTER': diff --git a/src/components/Visualizations/Panes/NetworkDetails/AuthorNetworkDetailsPane.tsx b/src/components/Visualizations/Panes/NetworkDetails/AuthorNetworkDetailsPane.tsx index 1cb6c66ed..106cde190 100644 --- a/src/components/Visualizations/Panes/NetworkDetails/AuthorNetworkDetailsPane.tsx +++ b/src/components/Visualizations/Panes/NetworkDetails/AuthorNetworkDetailsPane.tsx @@ -1,8 +1,10 @@ import { IDocsEntity } from '@api'; import { Flex, Tab, TabList, TabPanel, TabPanels, Tabs } from '@chakra-ui/react'; +import { IAuthor } from '@components/FeedbackForms'; import { Item } from '@components/ResultList/Item'; import { ILineGraph } from '@components/Visualizations/types'; -import { ReactElement, useEffect, useState } from 'react'; +import { equals } from 'ramda'; +import { memo, ReactElement, useEffect, useRef, useState } from 'react'; import { NodeDetailPane } from './NodeDetailsPane'; import { SummaryPane } from './SummaryPane'; @@ -34,9 +36,15 @@ export const AuthorNetworkDetailsPane = ({ }: AuthorNetworkDetailsProps): ReactElement => { const [tabIndex, setTabIndex] = useState(0); + // prevent tab switching during re-render + const prevNode = useRef(null); + // when selected node changes, change tab to node details useEffect(() => { - setTabIndex(node ? 1 : 0); + if (!equals(node, prevNode.current)) { + setTabIndex(node ? 1 : 0); + prevNode.current = node; + } }, [node]); const handleTabIndexChange = (index: number) => {