[Feature Request] Table component : expand row #1282
Replies: 8 comments 2 replies
-
Found any workaround on that? |
Beta Was this translation helpful? Give feedback.
-
Beta Was this translation helpful? Give feedback.
-
+1, but i managed to kinda improve previous workaround. thought someone might find it useful. it removes expanded row's height (it was caused by padding). and is more generalized which allows to map a collection of items to the table. but the amount of cells in expanded row has to be equal to the amount of columns. could not find a way around that "use client";
import {
Table,
TableHeader,
TableColumn,
TableBody,
TableRow,
TableCell,
} from "@nextui-org/react";
import { motion, AnimatePresence } from "framer-motion";
import { useState } from "react";
export function SomeTable() {
const items = [
{
name: "Tony Reicher",
role: "CEO",
status: "Active",
uid: "1",
},
{
name: "Jane Fisher",
role: "Senior Developer",
status: "Active",
uid: "2",
},
{
name: "Jane Reicher",
role: "CTO",
status: "Active",
uid: "3",
},
{
name: "Tony Fisher",
role: "Devops",
status: "Active",
uid: "4",
},
];
return (
<Table aria-label="Example static collection table">
<TableHeader>
<TableColumn>NAME</TableColumn>
<TableColumn>ROLE</TableColumn>
<TableColumn>STATUS</TableColumn>
</TableHeader>
<TableBody>
{items.map((i) => ExpandableRow(i)).flatMap((er) => er)}
</TableBody>
</Table>
);
}
const ExpandableRow = (props: {
name: string;
role: string;
status: string;
uid: string;
}) => {
const [isContentVisible, setContentVisible] = useState(false);
return [
<TableRow
key={props.uid}
className="cursor-pointer"
onClick={() => setContentVisible(!isContentVisible)}
>
<TableCell>{props.name}</TableCell>
<TableCell>{props.role}</TableCell>
<TableCell>{props.status}</TableCell>
</TableRow>,
<TableRow key={props.uid + " - expandable"}>
<TableCell aria-colspan={3} colSpan={3} className={"bg-red-200 py-0"}>
<AnimatePresence>
{isContentVisible && (
<motion.div
initial={{ opacity: 0, height: 0, padding: 0 }}
animate={{ opacity: 1, height: "auto", padding: "4px" }}
exit={{ opacity: 0, height: 0, padding: 0 }}
transition={{ duration: 0.2 }}
>
Expanded content
</motion.div>
)}
</AnimatePresence>
</TableCell>
<TableCell className="hidden"> </TableCell>
<TableCell className="hidden"> </TableCell>
</TableRow>,
];
}; |
Beta Was this translation helpful? Give feedback.
-
Beta Was this translation helpful? Give feedback.
-
I went through this thread and didn't see any mentions about dynamic sized rows as well as dynamic sized subrows. Here's an example of where you can have both in the same table. The key thing to notice here is that NextUI table expects either a What the crux of that looks like in code (includes a lot of other stuff which I need to improve but the main idea is using a reverse mapping from child node to parent row to get whether or not a child should be displayed).
Importantly, you MUST make shallow copies in your flattenTree function, or whenever you generate those rows which you finally render, from your original values. That's because when selectedKeys updates, the table DOES NOT necessarily have to rerender. i spent a long time on this. NextUI will memoize the items you pass into your table, and if they don't change, it won't alter attributes like classname to make things hidden or not. Hence you have to make shallow copies of your rows every time you want to rerender, e.g. upon clicking a parent row. |
Beta Was this translation helpful? Give feedback.
-
Is your feature request related to a problem? Please describe.
In some of our projects, we end up using many columns in our tables. However it is not really user friendly.
We would really benefit having a table where we can expand a row to show other informations.
This would prevent having to put every info about a row in columns, so we could have less, more useful columns, and the secondary infos would be visible when the row is expanded.
Describe the solution you'd like
We would like a table prop allowing rows to be expanded.
A row could be expanded when clicked or when a specific button in the row is clicked, depending on the developer's choice.
The developer could add any components he wishes in the expanded section of a row : cards, buttons, avatars etc.
The expansion of a row should be visually pleasing, with the next UI's magic sauce
Describe alternatives you've considered
You can find examples here : https://stackblitz.com/angular/ygdrrokyvkv?file=app%2Ftable-expandable-rows-example.html
and here : https://codepen.io/pc3b3r/pen/vLxONL
These examples are not pretty, are hard to customize and lack coherence with the concurrent use of next UI.
Screenshots or Videos
No response
Beta Was this translation helpful? Give feedback.
All reactions