Skip to content
This repository has been archived by the owner on Nov 28, 2024. It is now read-only.

Commit

Permalink
Sort by name NNS
Browse files Browse the repository at this point in the history
  • Loading branch information
upalatucci committed Dec 11, 2023
1 parent 916e5c5 commit a828fe6
Show file tree
Hide file tree
Showing 3 changed files with 74 additions and 13 deletions.
40 changes: 27 additions & 13 deletions src/views/states/list/StatesList.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -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';
Expand All @@ -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 useSortStates from './hooks/useSortStates';
import useStateColumns 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();
Expand All @@ -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 (
<>
<ListPageHeader title={t(NodeNetworkStateModel.label)}></ListPageHeader>
<ListPageBody>
<StatusBox loaded={statesLoaded} error={statesError}>
<div className="list-managment-group">
<div className="nns-list-management-group">
<ListPageFilter
data={data}
loaded={statesLoaded}
Expand Down Expand Up @@ -95,21 +100,30 @@ const StatesList: FC = () => {
}
className="list-managment-group__pagination"
defaultToFullPage
itemCount={filteredData?.length}
itemCount={sortedStates?.length}
page={pagination?.page}
perPage={pagination?.perPage}
perPageOptions={paginationDefaultValues}
/>
</div>

{filteredData.length > 0 ? (
<Table
cells={activeColumns}
rows={paginatedData}
gridBreakPoint={TableGridBreakpoint.none}
role="presentation"
>
<TableHeader />
{sortedStates.length > 0 ? (
<TableComposable gridBreakPoint={TableGridBreakpoint.none} role="presentation">
<Thead>
<Tr>
{activeColumns.map((column) => (
<Th
{...column.props}
id={column.id}
sort={column.id === 'name' ? nameSortParams : null}
key={column.id}
>
{column.title}
</Th>
))}
</Tr>
</Thead>

{paginatedData.map((nnstate, index) => (
<StateRow
key={nnstate?.metadata?.name}
Expand All @@ -118,7 +132,7 @@ const StatesList: FC = () => {
rowData={{ rowIndex: index, selectedFilters }}
/>
))}
</Table>
</TableComposable>
) : (
<NNStateEmptyState />
)}
Expand Down
40 changes: 40 additions & 0 deletions src/views/states/list/hooks/useSortStates.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,40 @@
import { useState } from 'react';

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<number | null>(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;
const bValue = b.metadata.name;

if (activeSortDirection === 'asc') {
return (aValue as string).localeCompare(bValue as string);
}
return (bValue as string).localeCompare(aValue as string);
});
}

const nameSortParams: ThSortType = {
sortBy: {
index: activeSortIndex,
direction: activeSortDirection,
},
onSort: (_event, index, direction) => {
setActiveSortIndex(index);
setActiveSortDirection(direction);
},
columnIndex: 1,
};

return { sortedStates, nameSortParams };
};

export default useSortStates;
7 changes: 7 additions & 0 deletions src/views/states/list/states-list.scss
Original file line number Diff line number Diff line change
@@ -0,0 +1,7 @@
.nns-list-management-group {
display: flex;
justify-content: space-between;
&__pagination {
flex-grow: 1;
}
}

0 comments on commit a828fe6

Please sign in to comment.