'use client'; import { ChangeEventHandler, useCallback, useEffect, useState } from 'react'; import useSWR from 'swr'; import { CellContext, ColumnDef, ColumnSort, SortingState, } from '@tanstack/react-table'; import toast from 'react-hot-toast'; import { Icon } from '@iconify/react'; import Table from '@/components/Table'; import DebouncedTextInput from '@/components/input/DebouncedTextInput'; import Button from '@/components/Button'; import { useModal } from '@/components/Modal'; import ConfirmationModal from '@/components/modal/ConfirmationModal'; import SelectInput, { OptionType } from '@/components/input/SelectInput'; import RowDropdownOptions from '@/components/table/RowDropdownOptions'; import RowCollapseOptions from '@/components/table/RowCollapseOptions'; import RowOptionsMenuWrapper from '@/components/table/RowOptionsMenuWrapper'; import RequirePermission from '@/components/helper/RequirePermission'; import { Warehouse } from '@/types/api/master-data/warehouse'; import { WarehouseApi } from '@/services/api/master-data'; import { cn } from '@/lib/helper'; import { isResponseSuccess } from '@/lib/api-helper'; import { useTableFilter } from '@/services/hooks/useTableFilter'; import { ROWS_OPTIONS } from '@/config/constant'; const RowOptionsMenu = ({ type = 'dropdown', props, deleteClickHandler, }: { type: 'dropdown' | 'collapse'; props: CellContext; deleteClickHandler: () => void; }) => { return ( ); }; const WarehousesTable = () => { const { state: tableFilterState, updateFilter, setPage, setPageSize, toQueryString: getTableFilterQueryString, } = useTableFilter({ initial: { search: '', nameSort: '', typeSort: '', areaSort: '', locationSort: '', kandangSort: '', }, paramMap: { page: 'page', pageSize: 'limit', nameSort: 'sort_name', typeSort: 'sort_type', areaSort: ' sort_area', locationSort: ' sort_location', kandangSort: ' sort_kandang', }, }); const { data: warehouses, isLoading, mutate: refreshWarehouses, } = useSWR( `${WarehouseApi.basePath}${getTableFilterQueryString()}`, WarehouseApi.getAllFetcher ); const deleteModal = useModal(); const [selectedWarehouse, setSelectedWarehouse] = useState< Warehouse | undefined >(undefined); const [isDeleteLoading, setIsDeleteLoading] = useState(false); const [sorting, setSorting] = useState([]); const warehousesColumns: ColumnDef[] = [ { header: '#', cell: (props) => tableFilterState.pageSize * (tableFilterState.page - 1) + props.row.index + 1, }, { accessorKey: 'name', header: 'Nama', }, { accessorKey: 'type', header: 'Tipe', }, { accessorKey: 'area', header: 'Area', cell: (props) => props.row.original.area.name, }, { accessorKey: 'location', header: 'Lokasi', cell: (props) => { if ( props.row.original.type === 'LOKASI' || props.row.original.type === 'KANDANG' ) { return props.row.original.location.name; } else { return '-'; } }, }, { accessorKey: 'kandang', header: 'Kandang', cell: (props) => { if (props.row.original.type === 'KANDANG') { return props.row.original.kandang.name; } else { return '-'; } }, }, { 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 = () => { setSelectedWarehouse(props.row.original); deleteModal.openModal(); }; return ( <> {currentPageSize > 2 && ( )} {currentPageSize <= 2 && ( )} ); }, }, ]; const confirmationModalDeleteClickHandler = async () => { setIsDeleteLoading(true); await WarehouseApi.delete(selectedWarehouse?.id as number); refreshWarehouses(); deleteModal.closeModal(); toast.success('Successfully delete Warehouse!'); setIsDeleteLoading(false); }; const searchChangeHandler: ChangeEventHandler = (e) => { updateFilter('search', e.target.value); }; const pageSizeChangeHandler = (val: OptionType | OptionType[] | null) => { const newVal = val as OptionType; setPageSize(newVal.value as number); }; const updateSortingFilter = useCallback( ( sortName: Exclude, sortFilter: ColumnSort | undefined ) => { if (!sortFilter) { updateFilter(sortName, ''); } else { updateFilter(sortName, sortFilter.desc ? 'desc' : 'asc'); } }, [updateFilter] ); // track sorting useEffect(() => { const nameSortFilter = sorting.find((sortItem) => sortItem.id === 'name'); const typeSortFilter = sorting.find((sortItem) => sortItem.id === 'type'); const areaSortFilter = sorting.find((sortItem) => sortItem.id === 'area'); const locationSortFilter = sorting.find( (sortItem) => sortItem.id === 'location' ); const kandangSortFilter = sorting.find( (sortItem) => sortItem.id === 'kandang' ); updateSortingFilter('nameSort', nameSortFilter); updateSortingFilter('typeSort', typeSortFilter); updateSortingFilter('areaSort', areaSortFilter); updateSortingFilter('locationSort', locationSortFilter); updateSortingFilter('kandangSort', kandangSortFilter); }, [sorting, updateSortingFilter]); return ( <>
data={isResponseSuccess(warehouses) ? warehouses?.data : []} columns={warehousesColumns} pageSize={tableFilterState.pageSize} page={isResponseSuccess(warehouses) ? warehouses?.meta?.page : 0} totalItems={ isResponseSuccess(warehouses) ? warehouses?.meta?.total_results : 0 } onPageChange={setPage} isLoading={isLoading} sorting={sorting} setSorting={setSorting} className={{ containerClassName: cn({ 'mb-20': isResponseSuccess(warehouses) && warehouses?.data?.length === 0, }), tableWrapperClassName: 'overflow-x-auto min-h-full!', tableClassName: 'font-inter w-full table-auto min-h-full!', headerRowClassName: 'border-b border-b-gray-200', headerColumnClassName: 'px-6 py-3 text-xs font-semibold text-gray-500 last:flex last:flex-row last:justify-end', bodyRowClassName: 'border-b border-b-gray-200', bodyColumnClassName: 'px-6 py-3 last:flex last:flex-row last:justify-end', }} />
); }; export default WarehousesTable;