58 lines
2.2 KiB
TypeScript
58 lines
2.2 KiB
TypeScript
"use client"
|
|
|
|
import { ResourcePage } from "@/shared/data-view/resource-page"
|
|
import { ColumnHeader } from "@/shared/data-view/table-view"
|
|
import { ShopTimingForm } from "@/modules/shop-timings/shop-timing-form"
|
|
import { SHOP_TIMING_ROUTES } from "@repo/api"
|
|
import type { ShopTimingsClient } from "@repo/api"
|
|
import { CheckCircle2Icon } from "lucide-react"
|
|
|
|
export default function ShopTimingsPage() {
|
|
return (
|
|
<ResourcePage<ShopTimingsClient>
|
|
pageTitle="Shop Timings"
|
|
title="Shop Timing"
|
|
routeKey={SHOP_TIMING_ROUTES.INDEX}
|
|
getClient={(api) => api.shopTimings}
|
|
columns={({ actionsColumn }) => [
|
|
{
|
|
accessorKey: "title",
|
|
header: ({ column }) => <ColumnHeader column={column} title="Title" />,
|
|
},
|
|
{
|
|
accessorKey: "in_time",
|
|
header: ({ column }) => <ColumnHeader column={column} title="In Time" />,
|
|
},
|
|
{
|
|
accessorKey: "out_time",
|
|
header: ({ column }) => <ColumnHeader column={column} title="Out Time" />,
|
|
},
|
|
{
|
|
accessorKey: "full_day_hours",
|
|
header: ({ column }) => <ColumnHeader column={column} title="Full Day Hours" />,
|
|
},
|
|
{
|
|
accessorKey: "half_day_hours",
|
|
header: ({ column }) => <ColumnHeader column={column} title="Half Day Hours" />,
|
|
},
|
|
{
|
|
accessorKey: "is_default",
|
|
header: ({ column }) => <ColumnHeader column={column} title="Default" />,
|
|
cell: ({ row }) =>
|
|
row.original.is_default ? (
|
|
<CheckCircle2Icon className="text-green-600 h-5 w-5" />
|
|
) : null,
|
|
},
|
|
actionsColumn(),
|
|
]}
|
|
renderForm={({ resourceId, initialData, onSuccess }) => (
|
|
<ShopTimingForm
|
|
resourceId={resourceId}
|
|
initialData={initialData}
|
|
onSuccess={onSuccess}
|
|
/>
|
|
)}
|
|
/>
|
|
)
|
|
}
|