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

Commit

Permalink
CNV-39752: Button to expand all sections
Browse files Browse the repository at this point in the history
  • Loading branch information
upalatucci committed Mar 22, 2024
1 parent 3722840 commit 4f81e7a
Show file tree
Hide file tree
Showing 5 changed files with 64 additions and 38 deletions.
2 changes: 2 additions & 0 deletions locales/en/plugin__nmstate-console-plugin.json
Original file line number Diff line number Diff line change
Expand Up @@ -20,6 +20,7 @@
"Cannot delete in view-only mode": "Cannot delete in view-only mode",
"Cannot edit in view-only mode": "Cannot edit in view-only mode",
"Click <1>Create NodeNetworkConfigurationPolicy</1> to create your first policy": "Click <1>Create NodeNetworkConfigurationPolicy</1> to create your first policy",
"Collapse all": "Collapse all",
"Confirm deletion by typing <1>{{name}}</1> below:": "Confirm deletion by typing <1>{{name}}</1> below:",
"Copied": "Copied",
"Copy": "Copy",
Expand Down Expand Up @@ -51,6 +52,7 @@
"Enactment states": "Enactment states",
"Enactments categorized by status": "Enactments categorized by status",
"Enter name": "Enter name",
"Expand all": "Expand all",
"Explore {{kind}} list": "Explore {{kind}} list",
"Failing": "Failing",
"Features": "Features",
Expand Down
65 changes: 36 additions & 29 deletions src/views/states/list/StatesList.tsx
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
import React, { FC } from 'react';
import React, { FC, useState } from 'react';
import {
NodeNetworkStateModelGroupVersionKind,
NodeNetworkStateModelRef,
Expand All @@ -13,7 +13,7 @@ import {
useK8sWatchResource,
useListPageFilter,
} from '@openshift-console/dynamic-plugin-sdk';
import { Pagination } from '@patternfly/react-core';
import { Button, Flex, Pagination } from '@patternfly/react-core';
import { Table, TableGridBreakpoint, Th, Thead, Tr } from '@patternfly/react-table';
import { V1beta1NodeNetworkState } from '@types';
import usePagination from '@utils/hooks/usePagination/usePagination';
Expand All @@ -35,6 +35,8 @@ const StatesList: FC = () => {
const { t } = useNMStateTranslation();
const { selectedInterfaceName, selectedStateName, selectedInterfaceType } = useDrawerInterface();

const [expandAll, setExpandAll] = useState(false);

const [states, statesLoaded, statesError] = useK8sWatchResource<V1beta1NodeNetworkState[]>({
groupVersionKind: NodeNetworkStateModelGroupVersionKind,
isList: true,
Expand Down Expand Up @@ -67,32 +69,37 @@ const StatesList: FC = () => {
<ListPageBody>
<StatusBox loaded={statesLoaded} error={statesError}>
<div className="nns-list-management-group">
<ListPageFilter
data={data}
loaded={statesLoaded}
rowFilters={filters}
rowSearchFilters={searchFilters}
hideLabelFilter
onFilterChange={(...args) => {
onFilterChange(...args);
onPaginationChange({
endIndex: pagination?.perPage,
page: 1,
perPage: pagination?.perPage,
startIndex: 0,
});
}}
columnLayout={{
columns: columns?.map(({ id, title, additional }) => ({
id,
title,
additional,
})),
id: NodeNetworkStateModelRef,
selectedColumns: new Set(activeColumns?.map((col) => col?.id)),
type: t('NodeNetworkState'),
}}
/>
<Flex>
<ListPageFilter
data={data}
loaded={statesLoaded}
rowFilters={filters}
rowSearchFilters={searchFilters}
hideLabelFilter
onFilterChange={(...args) => {
onFilterChange(...args);
onPaginationChange({
endIndex: pagination?.perPage,
page: 1,
perPage: pagination?.perPage,
startIndex: 0,
});
}}
columnLayout={{
columns: columns?.map(({ id, title, additional }) => ({
id,
title,
additional,
})),
id: NodeNetworkStateModelRef,
selectedColumns: new Set(activeColumns?.map((col) => col?.id)),
type: t('NodeNetworkState'),
}}
/>
<Button onClick={() => setExpandAll(!expandAll)}>
{expandAll ? t('Collapse all') : t('Expand all')}
</Button>
</Flex>
<Pagination
onPerPageSelect={(_e, perPage, page, startIndex, endIndex) =>
onPaginationChange({ endIndex, page, perPage, startIndex })
Expand Down Expand Up @@ -128,7 +135,7 @@ const StatesList: FC = () => {
key={nnstate?.metadata?.name}
obj={nnstate}
activeColumnIDs={new Set(activeColumns.map(({ id }) => id))}
rowData={{ rowIndex: index, selectedFilters }}
rowData={{ rowIndex: index, selectedFilters, expandAll }}
/>
))}
</Table>
Expand Down
8 changes: 7 additions & 1 deletion src/views/states/list/components/InterfacesTable.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -12,9 +12,14 @@ import './interfaces-table.scss';
interface InterfacesTableProps {
interfacesByType: { [interfaceType in string]: NodeNetworkConfigurationInterface[] };
nodeNetworkState: V1beta1NodeNetworkState;
expandAll: boolean;
}

const InterfacesTable: FC<InterfacesTableProps> = ({ interfacesByType, nodeNetworkState }) => {
const InterfacesTable: FC<InterfacesTableProps> = ({
interfacesByType,
nodeNetworkState,
expandAll,
}) => {
const columns = useInterfaceColumns();

return (
Expand All @@ -41,6 +46,7 @@ const InterfacesTable: FC<InterfacesTableProps> = ({ interfacesByType, nodeNetwo
interfaceType={interfaceType}
interfaces={interfacesByType[interfaceType]}
nodeNetworkState={nodeNetworkState}
expandAll={expandAll}
/>
))}
</Tbody>
Expand Down
8 changes: 5 additions & 3 deletions src/views/states/list/components/InterfacesTypeSection.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -22,21 +22,23 @@ interface InterfacesTypeSectionProps {
interfaces: NodeNetworkConfigurationInterface[];
interfaceType: string;
nodeNetworkState: V1beta1NodeNetworkState;
expandAll: boolean;
}

const InterfacesTypeSection: FC<InterfacesTypeSectionProps> = memo(
({ interfaceType, interfaces, nodeNetworkState }) => {
const [isExpanded, setIsExpanded] = useState(false);
({ interfaceType, interfaces, nodeNetworkState, expandAll }) => {
const [expand, setExpand] = useState(false);

const { setSelectedInterfaceName } = useDrawerInterface();

const isExpanded = expandAll || expand;
return (
<>
<Tr className="interfaces-table__interface-type-row">
<Td colSpan={6}>
<ExpandableSectionToggle
isExpanded={isExpanded}
onToggle={setIsExpanded}
onToggle={setExpand}
className="expandable-section-interface-type"
data-test={`${interfaceType}-expandable-section-toggle`}
>
Expand Down
19 changes: 14 additions & 5 deletions src/views/states/list/components/StateRow.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -16,9 +16,12 @@ import { filterInterfaces, getInterfacesByType } from './utils';
import './state-row.scss';

const StateRow: FC<
RowProps<V1beta1NodeNetworkState, { rowIndex: number; selectedFilters: SelectedFilters }>
> = ({ obj, activeColumnIDs, rowData: { rowIndex, selectedFilters } }) => {
const [isExpanded, setIsExpanded] = useState(false);
RowProps<
V1beta1NodeNetworkState,
{ rowIndex: number; selectedFilters: SelectedFilters; expandAll: boolean }
>
> = ({ obj, activeColumnIDs, rowData: { rowIndex, selectedFilters, expandAll } }) => {
const [expand, setExpand] = useState(false);
const { t } = useNMStateTranslation();
const interfaces = obj?.status?.currentState?.interfaces as NodeNetworkConfigurationInterface[];

Expand All @@ -32,14 +35,16 @@ const StateRow: FC<
[filteredInterfaces],
);

const isExpanded = expandAll || expand;

return (
<Tbody key={obj.metadata.name} isExpanded={isExpanded} role="rowgroup" className="state-row">
<Tr>
<Td
expand={{
rowIndex,
isExpanded,
onToggle: (event, rowIndex, isOpen) => setIsExpanded(isOpen),
onToggle: (event, rowIndex, isOpen) => setExpand(isOpen),
expandId: 'expand-interfaces-list',
}}
/>
Expand Down Expand Up @@ -93,7 +98,11 @@ const StateRow: FC<
</small>
</Title>

<InterfacesTable interfacesByType={interfacesByType} nodeNetworkState={obj} />
<InterfacesTable
interfacesByType={interfacesByType}
nodeNetworkState={obj}
expandAll={expandAll}
/>
</ExpandableRowContent>
</Td>
</Tr>
Expand Down

0 comments on commit 4f81e7a

Please sign in to comment.