From 8b950ff0e232ab056bf13bea420ce8292f33e23c Mon Sep 17 00:00:00 2001 From: Ugo Palatucci Date: Mon, 11 Dec 2023 11:17:36 +0100 Subject: [PATCH] Sort by name NNS --- src/views/states/list/StatesList.tsx | 42 ++++++++++++------- src/views/states/list/hooks/useSortStates.ts | 41 ++++++++++++++++++ .../states/list/hooks/useStateColumns.ts | 4 +- src/views/states/list/states-list.scss | 7 ++++ 4 files changed, 79 insertions(+), 15 deletions(-) create mode 100644 src/views/states/list/hooks/useSortStates.ts create mode 100644 src/views/states/list/states-list.scss diff --git a/src/views/states/list/StatesList.tsx b/src/views/states/list/StatesList.tsx index 88a3e4f4..7d5782f7 100644 --- a/src/views/states/list/StatesList.tsx +++ b/src/views/states/list/StatesList.tsx @@ -14,7 +14,7 @@ import { useListPageFilter, } from '@openshift-console/dynamic-plugin-sdk'; import { Pagination } from '@patternfly/react-core'; -import { Table, TableGridBreakpoint, TableHeader } from '@patternfly/react-table'; +import { TableComposable, TableGridBreakpoint, Th, Thead, Tr } from '@patternfly/react-table'; import { V1beta1NodeNetworkState } from '@types'; import usePagination from '@utils/hooks/usePagination/usePagination'; import { paginationDefaultValues } from '@utils/hooks/usePagination/utils/constants'; @@ -25,10 +25,13 @@ import StateRow from './components/StateRow'; import StatusBox from './components/StatusBox'; import useDrawerInterface from './hooks/useDrawerInterface'; import useSelectedFilters from './hooks/useSelectedFilters'; -import useStateColumns from './hooks/useStateColumns'; +import useSortStates from './hooks/useSortStates'; +import useStateColumns, { COLUMN_NAME_ID } from './hooks/useStateColumns'; import useStateFilters from './hooks/useStateFilters'; import { FILTER_TYPES } from './constants'; +import './states-list.scss'; + const StatesList: FC = () => { const { t } = useNMStateTranslation(); const { selectedInterfaceName, selectedStateName, selectedInterfaceType } = useDrawerInterface(); @@ -50,14 +53,16 @@ const StatesList: FC = () => { const selectedFilters = useSelectedFilters(); const [data, filteredData, onFilterChange] = useListPageFilter(states, filters); - const paginatedData = filteredData.slice(pagination?.startIndex, pagination?.endIndex + 1); + const { sortedStates, nameSortParams } = useSortStates(filteredData); + + const paginatedData = sortedStates.slice(pagination?.startIndex, pagination?.endIndex + 1); return ( <> -
+
{ } className="list-managment-group__pagination" defaultToFullPage - itemCount={filteredData?.length} + itemCount={sortedStates?.length} page={pagination?.page} perPage={pagination?.perPage} perPageOptions={paginationDefaultValues} />
- {filteredData.length > 0 ? ( - - + {sortedStates?.length ? ( + + + + {activeColumns.map((column) => ( + + ))} + + + {paginatedData.map((nnstate, index) => ( { rowData={{ rowIndex: index, selectedFilters }} /> ))} -
+ {column.title} +
+ ) : ( )} diff --git a/src/views/states/list/hooks/useSortStates.ts b/src/views/states/list/hooks/useSortStates.ts new file mode 100644 index 00000000..c96737b6 --- /dev/null +++ b/src/views/states/list/hooks/useSortStates.ts @@ -0,0 +1,41 @@ +import { MouseEvent, useState } from 'react'; + +import { SortByDirection } from '@patternfly/react-table'; +import { ThSortType } from '@patternfly/react-table/dist/esm/components/Table/base'; +import { V1beta1NodeNetworkState } from '@types'; + +const useSortStates = ( + nodeNetworkStates: V1beta1NodeNetworkState[], +): { sortedStates: V1beta1NodeNetworkState[]; nameSortParams: ThSortType } => { + const [activeSortIndex, setActiveSortIndex] = useState(null); + const [activeSortDirection, setActiveSortDirection] = useState<'asc' | 'desc' | null>(null); + + let sortedStates = nodeNetworkStates; + if (activeSortIndex === 1) { + sortedStates = nodeNetworkStates.sort((a, b) => { + const aValue = a.metadata.name as string; + const bValue = b.metadata.name as string; + + if (activeSortDirection === 'asc') { + return (aValue as string).localeCompare(bValue); + } + return (bValue as string).localeCompare(aValue); + }); + } + + const nameSortParams: ThSortType = { + sortBy: { + index: activeSortIndex, + direction: activeSortDirection, + }, + onSort: (_event: MouseEvent, index: number, direction: SortByDirection) => { + setActiveSortIndex(index); + setActiveSortDirection(direction); + }, + columnIndex: 1, + }; + + return { sortedStates, nameSortParams }; +}; + +export default useSortStates; diff --git a/src/views/states/list/hooks/useStateColumns.ts b/src/views/states/list/hooks/useStateColumns.ts index c68cde81..c17ab530 100644 --- a/src/views/states/list/hooks/useStateColumns.ts +++ b/src/views/states/list/hooks/useStateColumns.ts @@ -7,6 +7,8 @@ import { useActiveColumns, } from '@openshift-console/dynamic-plugin-sdk'; +export const COLUMN_NAME_ID = 'name'; + const useStateColumns = (): [ TableColumn[], TableColumn[], @@ -21,7 +23,7 @@ const useStateColumns = (): [ }, { title: t('Name'), - id: 'name', + id: COLUMN_NAME_ID, }, { title: t('Network interface'), diff --git a/src/views/states/list/states-list.scss b/src/views/states/list/states-list.scss new file mode 100644 index 00000000..2bfa3440 --- /dev/null +++ b/src/views/states/list/states-list.scss @@ -0,0 +1,7 @@ +.nns-list-management-group { + display: flex; + justify-content: space-between; + &__pagination { + flex-grow: 1; + } +}