feat(contents): improve table responsiveness and replace action buttons with dropdown menu

- Enhanced table layout by hiding columns on smaller screens for better responsiveness.
- Replaced action buttons with `DropdownMenu` for improved accessibility and cleaner UI.
- Adjusted skeleton loaders to align with the updated table structure.
This commit is contained in:
Mathis HERRIOT
2026-01-21 15:43:09 +01:00
parent 939448d15c
commit c3f57db1e5

View File

@@ -7,12 +7,21 @@ import {
Edit, Edit,
Eye, Eye,
Image as ImageIcon, Image as ImageIcon,
MoreHorizontal,
Trash2, Trash2,
Video, Video,
} from "lucide-react"; } from "lucide-react";
import { useCallback, useEffect, useState } from "react"; import { useCallback, useEffect, useState } from "react";
import { Badge } from "@/components/ui/badge"; import { Badge } from "@/components/ui/badge";
import { Button } from "@/components/ui/button"; import { Button } from "@/components/ui/button";
import {
DropdownMenu,
DropdownMenuContent,
DropdownMenuItem,
DropdownMenuLabel,
DropdownMenuSeparator,
DropdownMenuTrigger,
} from "@/components/ui/dropdown-menu";
import { Skeleton } from "@/components/ui/skeleton"; import { Skeleton } from "@/components/ui/skeleton";
import { import {
Table, Table,
@@ -77,10 +86,10 @@ export default function AdminContentsPage() {
<TableHeader> <TableHeader>
<TableRow> <TableRow>
<TableHead>Contenu</TableHead> <TableHead>Contenu</TableHead>
<TableHead>Catégorie</TableHead> <TableHead className="hidden sm:table-cell">Catégorie</TableHead>
<TableHead>Auteur</TableHead> <TableHead className="hidden md:table-cell">Auteur</TableHead>
<TableHead>Stats</TableHead> <TableHead className="hidden lg:table-cell">Stats</TableHead>
<TableHead>Date</TableHead> <TableHead className="hidden xl:table-cell">Date</TableHead>
<TableHead className="w-[100px]"></TableHead> <TableHead className="w-[100px]"></TableHead>
</TableRow> </TableRow>
</TableHeader> </TableHeader>
@@ -92,16 +101,16 @@ export default function AdminContentsPage() {
<TableCell> <TableCell>
<Skeleton className="h-10 w-[200px]" /> <Skeleton className="h-10 w-[200px]" />
</TableCell> </TableCell>
<TableCell> <TableCell className="hidden sm:table-cell">
<Skeleton className="h-4 w-[100px]" /> <Skeleton className="h-4 w-[100px]" />
</TableCell> </TableCell>
<TableCell> <TableCell className="hidden md:table-cell">
<Skeleton className="h-4 w-[100px]" /> <Skeleton className="h-4 w-[100px]" />
</TableCell> </TableCell>
<TableCell> <TableCell className="hidden lg:table-cell">
<Skeleton className="h-4 w-[80px]" /> <Skeleton className="h-4 w-[80px]" />
</TableCell> </TableCell>
<TableCell> <TableCell className="hidden xl:table-cell">
<Skeleton className="h-4 w-[100px]" /> <Skeleton className="h-4 w-[100px]" />
</TableCell> </TableCell>
<TableCell> <TableCell>
@@ -135,13 +144,15 @@ export default function AdminContentsPage() {
</div> </div>
</div> </div>
</TableCell> </TableCell>
<TableCell> <TableCell className="hidden sm:table-cell">
<Badge variant="outline"> <Badge variant="outline">
{content.category?.name || "Sans catégorie"} {content.category?.name || "Sans catégorie"}
</Badge> </Badge>
</TableCell> </TableCell>
<TableCell>@{content.author.username}</TableCell> <TableCell className="hidden md:table-cell">
<TableCell> @{content.author.username}
</TableCell>
<TableCell className="hidden lg:table-cell">
<div className="flex flex-col gap-1 text-xs"> <div className="flex flex-col gap-1 text-xs">
<div className="flex items-center gap-1"> <div className="flex items-center gap-1">
<Eye className="h-3 w-3" /> {content.views} <Eye className="h-3 w-3" /> {content.views}
@@ -151,27 +162,31 @@ export default function AdminContentsPage() {
</div> </div>
</div> </div>
</TableCell> </TableCell>
<TableCell className="whitespace-nowrap"> <TableCell className="hidden xl:table-cell whitespace-nowrap">
{format(new Date(content.createdAt), "dd/MM/yyyy", { locale: fr })} {format(new Date(content.createdAt), "dd/MM/yyyy", { locale: fr })}
</TableCell> </TableCell>
<TableCell> <TableCell>
<div className="flex items-center gap-2"> <DropdownMenu>
<Button <DropdownMenuTrigger asChild>
variant="ghost" <Button variant="ghost" size="icon">
size="icon" <MoreHorizontal className="h-4 w-4" />
onClick={() => handleEdit(content)} <span className="sr-only">Actions</span>
> </Button>
<Edit className="h-4 w-4" /> </DropdownMenuTrigger>
</Button> <DropdownMenuContent align="end">
<Button <DropdownMenuLabel>Actions</DropdownMenuLabel>
variant="ghost" <DropdownMenuSeparator />
size="icon" <DropdownMenuItem onClick={() => handleEdit(content)}>
onClick={() => handleDelete(content.id)} <Edit className="mr-2 h-4 w-4" /> Modifier
className="text-destructive hover:text-destructive hover:bg-destructive/10" </DropdownMenuItem>
> <DropdownMenuItem
<Trash2 className="h-4 w-4" /> onClick={() => handleDelete(content.id)}
</Button> className="text-destructive focus:text-destructive"
</div> >
<Trash2 className="mr-2 h-4 w-4" /> Supprimer
</DropdownMenuItem>
</DropdownMenuContent>
</DropdownMenu>
</TableCell> </TableCell>
</TableRow> </TableRow>
)) ))