feat: integrate react-table in directory view

This commit is contained in:
Sylvia Crowe 2024-05-20 16:08:45 -07:00
parent 72dbf94f9a
commit 304a54a994
7 changed files with 358 additions and 257 deletions

View File

@ -0,0 +1,18 @@
.dir-table {
.dir-table-head {
.dir-table-head-row {
.dir-table-head-cell {
}
}
}
.dir-table-body {
.dir-table-body-row {
&:focus {
background-color: var(--highlight-bg-color);
}
.dir-table-body-cell {
}
}
}
}

View File

@ -0,0 +1,69 @@
// Copyright 2024, Command Line Inc.
// SPDX-License-Identifier: Apache-2.0
import React from "react";
import { createColumnHelper, flexRender, getCoreRowModel, useReactTable } from "@tanstack/react-table";
import "./directorytable.less";
interface DirectoryTableProps {
data: FileInfo[];
}
const columnHelper = createColumnHelper<FileInfo>();
const defaultColumns = [
columnHelper.accessor("path", {
cell: (info) => info.getValue(),
header: () => <span>Name</span>,
}),
columnHelper.accessor("size", {
cell: (info) => info.getValue(),
header: () => <span>Size</span>,
}),
columnHelper.accessor("mimetype", {
cell: (info) => info.getValue(),
header: () => <span>Mimetype</span>,
}),
];
function DirectoryTable<T, U>({ data }: DirectoryTableProps) {
const [columns] = React.useState<typeof defaultColumns>(() => [...defaultColumns]);
const table = useReactTable({
data,
columns,
columnResizeMode: "onChange",
getCoreRowModel: getCoreRowModel(),
});
return (
<table className="dir-table">
<thead className="dir-table-head">
{table.getHeaderGroups().map((headerGroup) => (
<tr className="dir-table-head-row" key={headerGroup.id}>
{headerGroup.headers.map((header) => (
<th className="dir-table-head-cell" key={header.id}>
{header.isPlaceholder
? null
: flexRender(header.column.columnDef.header, header.getContext())}
</th>
))}
</tr>
))}
</thead>
<tbody className="dir-table-body">
{table.getRowModel().rows.map((row) => (
<tr className="dir-table-body-row" key={row.id} tabIndex={0}>
{row.getVisibleCells().map((cell) => (
<td className="dir-table-body-cell" key={cell.id}>
{flexRender(cell.column.columnDef.cell, cell.getContext())}
</td>
))}
</tr>
))}
</tbody>
</table>
);
}
export { DirectoryTable };

View File

@ -1,3 +1,6 @@
// Copyright 2024, Command Line Inc.
// SPDX-License-Identifier: Apache-2.0
.modal-container { .modal-container {
position: absolute; position: absolute;
top: 0; top: 0;

View File

@ -1,3 +1,6 @@
// Copyright 2024, Command Line Inc.
// SPDX-License-Identifier: Apache-2.0
import React from "react"; import React from "react";
import { Button } from "@/element/button"; import { Button } from "@/element/button";

View File

@ -8,6 +8,7 @@ import { Markdown } from "@/element/markdown";
import * as FileService from "@/bindings/pkg/service/fileservice/FileService"; import * as FileService from "@/bindings/pkg/service/fileservice/FileService";
import * as util from "@/util/util"; import * as util from "@/util/util";
import { CenteredDiv } from "../element/quickelems"; import { CenteredDiv } from "../element/quickelems";
import { DirectoryTable } from "@/element/directorytable";
import "./view.less"; import "./view.less";
@ -56,13 +57,7 @@ function StreamingPreview({ fileInfo }: { fileInfo: FileInfo }) {
function DirectoryPreview({ contentAtom }: { contentAtom: jotai.Atom<Promise<string>> }) { function DirectoryPreview({ contentAtom }: { contentAtom: jotai.Atom<Promise<string>> }) {
const contentText = jotai.useAtomValue(contentAtom); const contentText = jotai.useAtomValue(contentAtom);
let content: FileInfo[] = JSON.parse(contentText); let content: FileInfo[] = JSON.parse(contentText);
return ( return <DirectoryTable data={content} />;
<div className="view-preview view-preview-directory">
{content.map((finfo) => (
<span>{finfo.path}</span>
))}
</div>
);
} }
function PreviewView({ blockId }: { blockId: string }) { function PreviewView({ blockId }: { blockId: string }) {

View File

@ -20,6 +20,7 @@
}, },
"dependencies": { "dependencies": {
"@observablehq/plot": "^0.6.14", "@observablehq/plot": "^0.6.14",
"@tanstack/react-table": "^8.17.3",
"@xterm/addon-fit": "^0.10.0", "@xterm/addon-fit": "^0.10.0",
"@xterm/xterm": "^5.5.0", "@xterm/xterm": "^5.5.0",
"base64-js": "^1.5.1", "base64-js": "^1.5.1",

512
yarn.lock

File diff suppressed because it is too large Load Diff