'use client'; import Button from '@/components/Button'; import { FormHeader } from '@/components/helper/form/FormHeader'; import Table, { TABLE_DEFAULT_STYLING } from '@/components/Table'; import { ProductionStandard } from '@/types/api/master-data/production-standard'; import { Icon } from '@iconify/react'; import useSWR from 'swr'; import { ProductionStandardApi } from '@/services/api/master-data'; import { isResponseSuccess } from '@/lib/api-helper'; import RowOptionsMenuWrapper from '@/components/table/RowOptionsMenuWrapper'; import { CellContext } from '@tanstack/react-table'; import { useModal } from '@/components/Modal'; import { useState } from 'react'; import RowDropdownOptions from '@/components/table/RowDropdownOptions'; import RowCollapseOptions from '@/components/table/RowCollapseOptions'; import ConfirmationModal from '@/components/modal/ConfirmationModal'; import toast from 'react-hot-toast'; import { cn } from '@/lib/helper'; import RequirePermission from '@/components/helper/RequirePermission'; const RowOptionsMenu = ({ type = 'dropdown', props, deleteClickHandler, }: { type: 'dropdown' | 'collapse'; props: CellContext; deleteClickHandler: () => void; }) => { return ( ); }; const ProductionStandardTable = () => { const deleteModal = useModal(); const [selectedProductionStandard, setSelectedProductionStandard] = useState< ProductionStandard | undefined >(undefined); const [isDeleteLoading, setIsDeleteLoading] = useState(false); const { data: productionStandards, isLoading: productionStandardsLoading, mutate: refreshProductionStandards, } = useSWR( `${ProductionStandardApi.basePath}`, ProductionStandardApi.getAllFetcher ); const confirmationModalDeleteClickHandler = async () => { setIsDeleteLoading(true); await ProductionStandardApi.delete( selectedProductionStandard?.id as number ); refreshProductionStandards(); deleteModal.closeModal(); toast.success('Successfully delete Production Standard!'); setIsDeleteLoading(false); }; return ( <>
data={ isResponseSuccess(productionStandards) ? productionStandards.data : [] } columns={[ { header: 'No', accessorFn: (row, index) => index + 1, }, { header: 'Nama', accessorKey: 'name', }, { header: 'Kategori', accessorFn: (row) => row.project_category, }, { header: 'Aksi', cell: (props) => { const currentPageSize = props.table.getPaginationRowModel().rows.length; const currentPageRows = props.table.getPaginationRowModel().flatRows; const currentRowRelativeIndex = currentPageRows.findIndex((r) => r.id === props.row.id) + 1; const isLast2Rows = currentRowRelativeIndex > currentPageSize - 2; const deleteClickHandler = () => { setSelectedProductionStandard(props.row.original); deleteModal.openModal(); }; return ( <> {currentPageSize > 2 && ( )} {currentPageSize <= 2 && ( )} ); }, }, ]} className={{ headerColumnClassName: cn( TABLE_DEFAULT_STYLING.headerColumnClassName, 'last:flex last:flex-row last:justify-end' ), bodyColumnClassName: cn( TABLE_DEFAULT_STYLING.bodyColumnClassName, 'last:flex last:flex-row last:justify-end' ), }} />
); }; export default ProductionStandardTable;