mediahub-fe/app/[locale]/(protected)/dashboard/routine-task/components/columns.tsx

175 lines
5.2 KiB
TypeScript

import * as React from "react";
import { ColumnDef } from "@tanstack/react-table";
import { Eye, MoreVertical, SquarePen, Trash2 } from "lucide-react";
import { cn } from "@/lib/utils";
import {
DropdownMenu,
DropdownMenuContent,
DropdownMenuTrigger,
DropdownMenuItem,
} from "@/components/ui/dropdown-menu";
import { Button } from "@/components/ui/button";
import { format } from "date-fns";
const columns: ColumnDef<any>[] = [
{
accessorKey: "no",
header: "No",
cell: ({ row }) => (
<div className="flex items-center gap-5">
<div className="flex-1 text-start">
<h4 className="text-sm font-medium text-default-600 whitespace-nowrap mb-1">
{row.getValue("no")}
</h4>
</div>
</div>
),
},
{
accessorKey: "title",
header: "Title",
cell: ({ row }: { row: { getValue: (key: string) => string } }) => {
const title: string = row.getValue("title");
return (
<span className="">
{title.length > 50 ? `${title.slice(0, 10)}...` : title}
</span>
);
},
},
{
accessorKey: "createdAt",
header: "Upload Date",
cell: ({ row }) => {
const createdAt = row.getValue("createdAt") as
| string
| number
| undefined;
const formattedDate =
createdAt && !isNaN(new Date(createdAt).getTime())
? format(new Date(createdAt), "dd-MM-yyyy HH:mm:ss")
: "-";
return <span className="whitespace-nowrap">{formattedDate}</span>;
},
},
{
accessorKey: "fileTypeName",
header: "Type Content",
cell: ({ row }: { row: { getValue: (key: string) => string } }) => {
const title: string = row.getValue("fileTypeName");
return (
<span className="whitespace-nowrap">
{title.length > 50 ? `${title.slice(0, 30)}...` : title}
</span>
);
},
},
// {
// accessorKey: "creatorGroup",
// header: "Creator Group",
// cell: ({ row }) => (
// <span className="whitespace-nowrap">{row.getValue("creatorGroup")}</span>
// ),
// },
// {
// accessorKey: "creatorName",
// header: "Sumber",
// cell: ({ row }) => (
// <span className="whitespace-nowrap">{row.getValue("creatorName")}</span>
// ),
// },
// {
// accessorKey: "publishedOn",
// header: "Published",
// cell: ({ row }) => {
// const isPublish = row.original.isPublish;
// const isPublishOnPolda = row.original.isPublishOnPolda;
// let displayText = "-";
// if (isPublish && !isPublishOnPolda) {
// displayText = "Mabes";
// } else if (isPublish && isPublishOnPolda) {
// displayText = "Mabes & Polda";
// } else if (!isPublish && isPublishOnPolda) {
// displayText = "Polda";
// }
// return (
// <div className="text-center whitespace-nowrap" title={displayText}>
// {displayText}
// </div>
// );
// },
// },
{
accessorKey: "statusName",
header: "Status",
cell: ({ row }) => {
// Mendapatkan nilai statusName
const statusName = row.getValue<string>("statusName");
// Mapping warna berdasarkan statusName
const colorMapping: Record<string, string> = {
"Menunggu Review": "text-orange-500 border-orange-500",
Diterima: "text-green-500 border-green-500",
"Minta Update": "text-blue-500 border-blue-500",
Ditolak: "text-red-500 border-red-500",
};
// Mendapatkan kelas warna dari mapping, default ke abu-abu jika tidak ditemukan
const buttonClass =
colorMapping[statusName] || "text-gray-500 border-gray-500";
return (
<div>
<Button
size="sm"
variant="outline"
className={`btn btn-sm pill-btn ml-1 ${buttonClass}`}
>
{statusName || "Tidak Diketahui"}
</Button>
</div>
);
},
},
{
id: "actions",
accessorKey: "action",
header: "Actions",
enableHiding: false,
cell: ({ row }) => {
return (
<DropdownMenu>
<DropdownMenuTrigger asChild>
<Button
size="icon"
className="bg-transparent ring-offset-transparent hover:bg-transparent hover:ring-0 hover:ring-transparent"
>
<span className="sr-only">Open menu</span>
<MoreVertical className="h-4 w-4 text-default-800" />
</Button>
</DropdownMenuTrigger>
<DropdownMenuContent className="p-0" align="end">
<a href="/en/task/detail/[id]">
<DropdownMenuItem className="p-2 border-b text-default-700 group focus:bg-default focus:text-primary-foreground rounded-none">
<Eye className="w-4 h-4 me-1.5" />
View
</DropdownMenuItem>
</a>
<DropdownMenuItem className="p-2 border-b text-destructive bg-destructive/30 focus:bg-destructive focus:text-destructive-foreground rounded-none">
<Trash2 className="w-4 h-4 me-1.5" />
Delete
</DropdownMenuItem>
</DropdownMenuContent>
</DropdownMenu>
);
},
},
];
export default columns;