Skip to content

Commit

Permalink
Store sorting state for download/popular/search tables
Browse files Browse the repository at this point in the history
  • Loading branch information
egbertbouman committed Nov 14, 2024
1 parent ce62a4f commit ff75a9d
Show file tree
Hide file tree
Showing 4 changed files with 26 additions and 3 deletions.
26 changes: 23 additions & 3 deletions src/tribler/ui/src/components/ui/simple-table.tsx
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
import { SetStateAction, useEffect, useRef, useState } from 'react';
import { Table, TableBody, TableCell, TableHead, TableHeader, TableRow } from "@/components/ui/table";
import { getCoreRowModel, useReactTable, flexRender, getFilteredRowModel, getPaginationRowModel, getExpandedRowModel, getSortedRowModel } from '@tanstack/react-table';
import type { ColumnDef, Row, PaginationState, RowSelectionState, ColumnFiltersState, ExpandedState, ColumnDefTemplate, HeaderContext } from '@tanstack/react-table';
import type { ColumnDef, Row, PaginationState, RowSelectionState, ColumnFiltersState, ExpandedState, ColumnDefTemplate, HeaderContext, SortingState } from '@tanstack/react-table';
import { cn } from '@/lib/utils';
import { Select, SelectContent, SelectGroup, SelectItem, SelectLabel } from './select';
import { Button } from './button';
Expand Down Expand Up @@ -41,6 +41,15 @@ export function getHeader<T>(name: string, translate: boolean = true, addSorting
}
}

function getStoredSortingState(key?: string) {
if (key) {
let sortingString = localStorage.getItem(key);
if (sortingString) {
return JSON.parse(sortingString);
}
}
}

interface ReactTableProps<T extends object> {
data: T[];
columns: ColumnDef<T>[];
Expand All @@ -58,6 +67,7 @@ interface ReactTableProps<T extends object> {
filters?: { id: string, value: string }[];
maxHeight?: string | number;
expandable?: boolean;
storeSortingState?: string;
}

function SimpleTable<T extends object>({
Expand All @@ -75,7 +85,8 @@ function SimpleTable<T extends object>({
allowMultiSelect,
filters,
maxHeight,
expandable
expandable,
storeSortingState
}: ReactTableProps<T>) {
const [pagination, setPagination] = useState<PaginationState>({
pageIndex: pageIndex ?? 0,
Expand All @@ -84,6 +95,7 @@ function SimpleTable<T extends object>({
const [rowSelection, setRowSelection] = useState<RowSelectionState>(initialRowSelection || {});
const [columnFilters, setColumnFilters] = useState<ColumnFiltersState>(filters || [])
const [expanded, setExpanded] = useState<ExpandedState>({});
const [sorting, setSorting] = useState<SortingState>(getStoredSortingState(storeSortingState) || []);

const table = useReactTable({
data,
Expand All @@ -98,7 +110,8 @@ function SimpleTable<T extends object>({
pagination,
rowSelection,
columnFilters,
expanded
expanded,
sorting
},
getFilteredRowModel: getFilteredRowModel(),
onColumnFiltersChange: setColumnFilters,
Expand All @@ -107,6 +120,7 @@ function SimpleTable<T extends object>({
if (allowSelect || allowSelectCheckbox || allowMultiSelect) setRowSelection(arg);
},
onExpandedChange: setExpanded,
onSortingChange: setSorting,
getSubRows: (row: any) => row?.subRows,
});

Expand All @@ -133,6 +147,12 @@ function SimpleTable<T extends object>({
}
}, [filters])

useEffect(() => {
if (storeSortingState) {
localStorage.setItem(storeSortingState, JSON.stringify(sorting));
}
}, [sorting]);

// For some reason the ScrollArea scrollbar is only shown when it's set to a specific height.
// So, we wrap it in a parent div, monitor its size, and set the height of the table accordingly.
const parentRef = useRef<HTMLTableElement>(null);
Expand Down
1 change: 1 addition & 0 deletions src/tribler/ui/src/pages/Downloads/index.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -194,6 +194,7 @@ export default function Downloads({ statusFilter }: { statusFilter: number[] })
allowMultiSelect={true}
onSelectedRowsChange={setSelectedDownloads}
maxHeight={Math.max((parentRect?.height ?? 50)-50, 50)}
storeSortingState="download-sorting"
/>
</Card>
</div>
Expand Down
1 change: 1 addition & 0 deletions src/tribler/ui/src/pages/Popular/index.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -111,6 +111,7 @@ export default function Popular() {
<SimpleTable
data={torrents}
columns={torrentColumns}
storeSortingState="popular-sorting"
/>
</>
)
Expand Down
1 change: 1 addition & 0 deletions src/tribler/ui/src/pages/Search/index.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -150,6 +150,7 @@ export default function Search() {
<SimpleTable
data={torrents}
columns={torrentColumns}
storeSortingState="search-sorting"
/>
</>
)
Expand Down

0 comments on commit ff75a9d

Please sign in to comment.