'use client'; import Button from '@/components/Button'; import SelectInput, { OptionType } from '@/components/input/SelectInput'; import Modal, { useModal } from '@/components/Modal'; import ConfirmationModal from '@/components/modal/ConfirmationModal'; import ChickinForm from '@/components/pages/production/chickin/form/ChickinForm'; import Table from '@/components/Table'; import { isResponseError, isResponseSuccess } from '@/lib/api-helper'; import { cn } from '@/lib/helper'; import { ProjectFlockApi } from '@/services/api/production'; import { useTableFilter } from '@/services/hooks/useTableFilter'; import { BaseApiResponse } from '@/types/api/api-general'; import { Kandang } from '@/types/api/master-data/kandang'; import { ProjectFlockKandang } from '@/types/api/production/project-flock-kandang'; import { Icon } from '@iconify/react'; import { useRouter, useSearchParams } from 'next/navigation'; import { useState } from 'react'; import useSWR from 'swr'; const AddChickin = () => { const router = useRouter(); const searchParams = useSearchParams(); const projectFlockId = searchParams.get('projectFlockId'); // Tables Props const { state: tableFilterState } = useTableFilter({ initial: { search: '' }, paramMap: { page: 'page', pageSize: 'limit' }, }); // States const [selectedKandang, setSelectedKandang] = useState( undefined ); const [projectFlockKandang, setProjectFlockKandang] = useState>(); const [isLoadingProjectFlockKandang, setIsLoadingProjectFlockKandang] = useState(false); const [searchProjectFlock, setSearchProjectFlock] = useState(''); // Fetch Data const { data: projectFlock, isLoading: isLoadingProjectFlock } = useSWR( projectFlockId, (id: number) => ProjectFlockApi.getSingle(id) ); const { data: listProjectFlock, isLoading: isLoadingListProjectFlock } = useSWR( `${ProjectFlockApi.basePath}?${new URLSearchParams({ search: searchProjectFlock, }).toString()}`, ProjectFlockApi.getAllFetcher ); const getProjectFlockKandangUrl = `/kandangs/lookup`; // Mapping Options const options = isResponseSuccess(listProjectFlock) ? listProjectFlock?.data.map((projectFlock) => { return { value: projectFlock.id, label: `${projectFlock?.flock?.name} - ${projectFlock?.category} - Periode ${projectFlock.period}`, }; }) : []; const chickinModal = useModal(); const alertModal = useModal(); if (!projectFlockId) { router.back(); return (
); } if ( !isLoadingProjectFlock && (!projectFlock || isResponseError(projectFlock)) ) { router.replace('/404'); return; } // Handle Function const handleChickinClick = async (kandang: Kandang) => { setIsLoadingProjectFlockKandang(true); setSelectedKandang(kandang); const ProjectFlockKandangRes = await ProjectFlockApi.customRequest< BaseApiResponse, 'GET' >(getProjectFlockKandangUrl, { method: 'GET', params: { project_flock_id: projectFlockId ?? 0, kandang_id: kandang.id, }, }); if (isResponseSuccess(ProjectFlockKandangRes)) { setProjectFlockKandang(ProjectFlockKandangRes); setIsLoadingProjectFlockKandang(false); if ( ProjectFlockKandangRes.data.available_quantity && ProjectFlockKandangRes.data.available_quantity > 0 ) { chickinModal.openModal(); } else { alertModal.openModal(); } } }; const handleAfterSubmit = () => { chickinModal.closeModal(); router.push('/production/chickin'); }; return ( <> {isResponseSuccess(projectFlock) && ( <>
router.push( `/production/chickin/add?projectFlockId=${ (val as OptionType | null)?.value }` ) } onInputChange={(val) => { setSearchProjectFlock(val); }} />
data={projectFlock.data?.kandangs} columns={[ { header: '#', cell: (props) => tableFilterState.pageSize * (tableFilterState.page - 1) + props.row.index + 1, }, { accessorKey: 'name', header: 'Nama Kandang', }, { header: 'Aksi', cell: (props) => { return ( <> ); }, }, ]} page={undefined} className={{ containerClassName: cn({ 'mb-20': isResponseSuccess(projectFlock) && projectFlock.data?.kandangs?.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', paginationClassName: 'hidden', }} />

Chickin Kandang - {selectedKandang?.name}

{isResponseSuccess(projectFlockKandang) && !isLoadingProjectFlockKandang && ( )}
{ alertModal.closeModal(); }, }} /> )} ); }; export default AddChickin;