Skip to content

Commit

Permalink
refactor: visible columns
Browse files Browse the repository at this point in the history
  • Loading branch information
alexfreska committed Dec 20, 2024
1 parent b7e5ea1 commit 438b71b
Show file tree
Hide file tree
Showing 44 changed files with 194 additions and 290 deletions.
5 changes: 5 additions & 0 deletions .changeset/cyan-lamps-hang.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
---
'@siafoundation/design-system': minor
---

useTableState now handles column filtering.
5 changes: 5 additions & 0 deletions .changeset/silly-zebras-collect.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
---
'@siafoundation/design-system': minor
---

Renamed enabledColumns to visibleColumns and removed disabled categories from useTableState.
14 changes: 7 additions & 7 deletions apps/hostd/components/Contracts/ContractsViewDropdownMenu.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -30,7 +30,7 @@ export function ContractsViewDropdownMenu() {
setSortField,
sortDirection,
setSortDirection,
enabledColumns,
visibleColumnIds,
} = useContracts()

const generalColumns = configurableColumns
Expand Down Expand Up @@ -128,42 +128,42 @@ export function ContractsViewDropdownMenu() {
<MenuSectionLabelToggleAll
label="General"
columns={generalColumns.map((c) => c.value)}
enabled={enabledColumns}
enabled={visibleColumnIds}
setColumnsVisible={setColumnsVisible}
setColumnsHidden={setColumnsHidden}
/>
<BaseMenuItem>
<PoolCombo
options={generalColumns}
values={enabledColumns}
values={visibleColumnIds}
onChange={(value) => toggleColumnVisibility(value)}
/>
</BaseMenuItem>
<MenuSectionLabelToggleAll
label="Time"
columns={timeColumns.map((c) => c.value)}
enabled={enabledColumns}
enabled={visibleColumnIds}
setColumnsVisible={setColumnsVisible}
setColumnsHidden={setColumnsHidden}
/>
<BaseMenuItem>
<PoolCombo
options={timeColumns}
values={enabledColumns}
values={visibleColumnIds}
onChange={(value) => toggleColumnVisibility(value)}
/>
</BaseMenuItem>
<MenuSectionLabelToggleAll
label="Usage"
columns={financialColumns.map((c) => c.value)}
enabled={enabledColumns}
enabled={visibleColumnIds}
setColumnsVisible={setColumnsVisible}
setColumnsHidden={setColumnsHidden}
/>
<BaseMenuItem>
<PoolCombo
options={financialColumns}
values={enabledColumns}
values={visibleColumnIds}
onChange={(value) => toggleColumnVisibility(value)}
/>
</BaseMenuItem>
Expand Down
4 changes: 2 additions & 2 deletions apps/hostd/components/Contracts/index.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -6,7 +6,7 @@ import { StateError } from './StateError'

export function Contracts() {
const {
columns,
visibleColumns,
datasetPage,
sortField,
sortDirection,
Expand All @@ -33,7 +33,7 @@ export function Contracts() {
}
pageSize={limit}
data={datasetPage}
columns={columns}
columns={visibleColumns}
sortableColumns={sortableColumns}
sortDirection={sortDirection}
sortField={sortField}
Expand Down
10 changes: 5 additions & 5 deletions apps/hostd/components/Volumes/VolumesViewDropdownMenu.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -21,7 +21,7 @@ export function VolumesViewDropdownMenu() {
resetDefaultColumnVisibility,
setColumnsVisible,
setColumnsHidden,
enabledColumns,
visibleColumnIds,
} = useVolumes()

const generalColumns = configurableColumns
Expand Down Expand Up @@ -68,28 +68,28 @@ export function VolumesViewDropdownMenu() {
<MenuSectionLabelToggleAll
label="General"
columns={generalColumns.map((c) => c.value)}
enabled={enabledColumns}
enabled={visibleColumnIds}
setColumnsVisible={setColumnsVisible}
setColumnsHidden={setColumnsHidden}
/>
<BaseMenuItem>
<PoolCombo
options={generalColumns}
values={enabledColumns}
values={visibleColumnIds}
onChange={(value) => toggleColumnVisibility(value)}
/>
</BaseMenuItem>
<MenuSectionLabelToggleAll
label="Operations"
columns={opsColumns.map((c) => c.value)}
enabled={enabledColumns}
enabled={visibleColumnIds}
setColumnsVisible={setColumnsVisible}
setColumnsHidden={setColumnsHidden}
/>
<BaseMenuItem>
<PoolCombo
options={opsColumns}
values={enabledColumns}
values={visibleColumnIds}
onChange={(value) => toggleColumnVisibility(value)}
/>
</BaseMenuItem>
Expand Down
4 changes: 2 additions & 2 deletions apps/hostd/components/Volumes/index.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -3,15 +3,15 @@ import { useVolumes } from '../../contexts/volumes'
import { StateNoneYet } from './StateNoneYet'

export function Volumes() {
const { dataset, datasetState, isLoading, columns } = useVolumes()
const { dataset, datasetState, isLoading, visibleColumns } = useVolumes()
return (
<div className="p-6 min-w-fit">
<Table
testId="volumesTable"
isLoading={isLoading}
pageSize={20}
data={dataset}
columns={columns}
columns={visibleColumns}
emptyState={
<EmptyState datasetState={datasetState} noneYet={<StateNoneYet />} />
}
Expand Down
4 changes: 2 additions & 2 deletions apps/hostd/components/Wallet/index.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -14,7 +14,7 @@ export function Wallet() {
metrics,
datasetPage,
datasetState,
columns,
visibleColumns,
cellContext,
sortableColumns,
sortDirection,
Expand Down Expand Up @@ -45,7 +45,7 @@ export function Wallet() {
pageSize={defaultPageSize}
data={datasetPage}
context={cellContext}
columns={columns}
columns={visibleColumns}
sortableColumns={sortableColumns}
sortDirection={sortDirection}
sortField={sortField}
Expand Down
16 changes: 5 additions & 11 deletions apps/hostd/contexts/contracts/index.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -14,9 +14,7 @@ import {
columnsDefaultVisible,
ContractData,
defaultSortField,
SortField,
sortOptions,
TableColumnId,
} from './types'
import { columns } from './columns'
import { useDataset } from './dataset'
Expand All @@ -33,7 +31,8 @@ function useContractsMain() {

const {
configurableColumns,
enabledColumns,
visibleColumnIds,
visibleColumns,
sortableColumns,
toggleColumnVisibility,
setColumnsVisible,
Expand All @@ -44,7 +43,7 @@ function useContractsMain() {
sortField,
sortDirection,
resetDefaultColumnVisibility,
} = useTableState<TableColumnId, SortField>('hostd/v0/contracts', {
} = useTableState('hostd/v0/contracts', {
columns,
columnsDefaultVisible,
sortOptions,
Expand Down Expand Up @@ -75,11 +74,6 @@ function useContractsMain() {
response,
})

const filteredTableColumns = useMemo(
() => columns.filter((column) => enabledColumns.includes(column.id)),
[enabledColumns]
)

const { estimatedBlockHeight, isSynced, nodeBlockHeight } = useSyncStatus()
const currentHeight = isSynced ? nodeBlockHeight : estimatedBlockHeight

Expand Down Expand Up @@ -133,10 +127,10 @@ function useContractsMain() {
cellContext,
datasetPageTotal: datasetPage?.length || 0,
datasetFilteredTotal: response.data?.count,
columns: filteredTableColumns,
visibleColumns,
datasetPage,
configurableColumns,
enabledColumns,
visibleColumnIds,
sortableColumns,
toggleColumnVisibility,
setColumnsVisible,
Expand Down
16 changes: 4 additions & 12 deletions apps/hostd/contexts/transactions/index.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -107,7 +107,8 @@ function useTransactionsMain() {

const {
configurableColumns,
enabledColumns,
visibleColumnIds,
visibleColumns,
sortableColumns,
toggleColumnVisibility,
setColumnsVisible,
Expand All @@ -125,14 +126,6 @@ function useTransactionsMain() {
defaultSortField,
})

const filteredTableColumns = useMemo(
() =>
columns.filter(
(column) => column.fixed || enabledColumns.includes(column.id)
),
[enabledColumns]
)

const siascanUrl = useSiascanUrl()
const cellContext = useMemo<CellContext>(
() => ({
Expand Down Expand Up @@ -190,7 +183,7 @@ function useTransactionsMain() {
defaultPageSize,
cellContext,
configurableColumns,
enabledColumns,
visibleColumnIds,
sortableColumns,
toggleColumnVisibility,
setColumnsVisible,
Expand All @@ -206,8 +199,7 @@ function useTransactionsMain() {
removeFilter,
removeLastFilter,
resetFilters,
filteredTableColumns,
columns,
visibleColumns,
}
}

Expand Down
18 changes: 7 additions & 11 deletions apps/hostd/contexts/volumes/index.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -7,8 +7,8 @@ import {
} from '@siafoundation/design-system'
import { VolumeMeta } from '@siafoundation/hostd-types'
import { useVolumes as useVolumesData } from '@siafoundation/hostd-react'
import { createContext, useContext, useMemo } from 'react'
import { columnsDefaultVisible, TableColumnId, VolumeData } from './types'
import { createContext, useContext } from 'react'
import { columnsDefaultVisible, VolumeData } from './types'
import { columns } from './columns'
import { useDataset } from './dataset'
import { defaultDatasetRefreshInterval } from '../../config/swr'
Expand All @@ -22,7 +22,8 @@ function useVolumesMain() {

const {
configurableColumns,
enabledColumns,
visibleColumnIds,
visibleColumns,
toggleColumnVisibility,
setColumnsVisible,
setColumnsHidden,
Expand All @@ -32,7 +33,7 @@ function useVolumesMain() {
sortField,
sortDirection,
resetDefaultColumnVisibility,
} = useTableState<TableColumnId, never>('hostd/v0/volumes', {
} = useTableState('hostd/v0/volumes', {
columns,
columnsDefaultVisible,
})
Expand Down Expand Up @@ -61,11 +62,6 @@ function useVolumesMain() {
limit,
})

const filteredTableColumns = useMemo(
() => columns.filter((column) => enabledColumns.includes(column.id)),
[enabledColumns]
)

const isValidating = response.isValidating
const error = response.error
const datasetState = useDatasetState({
Expand All @@ -80,13 +76,13 @@ function useVolumesMain() {
datasetFilteredTotal: datasetFiltered?.length || 0,
datasetPageTotal: datasetPage?.length || 0,
isLoading: response.isValidating,
columns: filteredTableColumns,
visibleColumns,
dataset,
datasetPage,
offset,
limit,
configurableColumns,
enabledColumns,
visibleColumnIds,
toggleColumnVisibility,
setColumnsVisible,
setColumnsHidden,
Expand Down
6 changes: 3 additions & 3 deletions apps/renterd/components/Alerts/AlertsViewDropdownMenu.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -21,7 +21,7 @@ export function AlertsViewDropdownMenu() {
resetDefaultColumnVisibility,
setColumnsVisible,
setColumnsHidden,
enabledColumns,
visibleColumnIds,
} = useAlerts()

const generalColumns = configurableColumns
Expand Down Expand Up @@ -62,14 +62,14 @@ export function AlertsViewDropdownMenu() {
<MenuSectionLabelToggleAll
label="General"
columns={generalColumns.map((c) => c.value)}
enabled={enabledColumns}
enabled={visibleColumnIds}
setColumnsVisible={setColumnsVisible}
setColumnsHidden={setColumnsHidden}
/>
<BaseMenuItem>
<PoolCombo
options={generalColumns}
values={enabledColumns}
values={visibleColumnIds}
onChange={(value) => toggleColumnVisibility(value)}
/>
</BaseMenuItem>
Expand Down
4 changes: 2 additions & 2 deletions apps/renterd/components/Alerts/index.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -6,7 +6,7 @@ import { useAlerts } from '../../contexts/alerts'

export function Alerts() {
const {
columns,
visibleColumns,
datasetPage,
sortField,
sortDirection,
Expand All @@ -32,7 +32,7 @@ export function Alerts() {
sortableColumns={sortableColumns}
pageSize={limit}
data={datasetPage}
columns={columns}
columns={visibleColumns}
sortDirection={sortDirection}
sortField={sortField}
toggleSort={toggleSort}
Expand Down
Loading

0 comments on commit 438b71b

Please sign in to comment.