mirror of
https://gitlab.com/mbugroup/lti-web-client.git
synced 2026-05-20 13:32:00 +00:00
77 lines
2.0 KiB
TypeScript
77 lines
2.0 KiB
TypeScript
'use client';
|
|
|
|
import { useMemo, useState } from 'react';
|
|
|
|
import { Icon } from '@iconify/react';
|
|
import Button from '@/components/Button';
|
|
import Tabs from '@/components/Tabs';
|
|
import ExpenseRequestContent from '@/components/pages/expense/ExpenseRequestContent';
|
|
import ExpenseRealizationContent from '@/components/pages/expense/ExpenseRealizationContent';
|
|
|
|
import { Expense } from '@/types/api/expense';
|
|
|
|
interface ExpenseDetailProps {
|
|
initialValues?: Expense;
|
|
}
|
|
|
|
const ExpenseDetail: React.FC<ExpenseDetailProps> = ({ initialValues }) => {
|
|
const [activeTab, setActiveTab] = useState<string>('request');
|
|
|
|
const expenseDetailTabs = useMemo(() => {
|
|
const validTabs = [
|
|
{
|
|
id: 'request',
|
|
label: 'Pengajuan',
|
|
content: <ExpenseRequestContent initialValues={initialValues} />,
|
|
},
|
|
];
|
|
|
|
if (
|
|
initialValues?.latest_approval &&
|
|
initialValues?.latest_approval.step_number >= 4 &&
|
|
initialValues.latest_approval.action !== 'REJECTED'
|
|
) {
|
|
validTabs.push({
|
|
id: 'realization',
|
|
label: 'Realisasi',
|
|
content: <ExpenseRealizationContent initialValues={initialValues} />,
|
|
});
|
|
}
|
|
|
|
return validTabs;
|
|
}, [initialValues]);
|
|
|
|
return (
|
|
<>
|
|
<section className='w-full max-w-7xl pb-16'>
|
|
<header className='flex flex-col gap-4'>
|
|
<Button
|
|
href='/expense'
|
|
variant='link'
|
|
className='w-fit p-0 text-primary'
|
|
>
|
|
<Icon icon='uil:arrow-left' width={24} height={24} />
|
|
Kembali
|
|
</Button>
|
|
|
|
<h1 className='text-2xl font-bold text-center'>
|
|
Detail Biaya Operasional
|
|
</h1>
|
|
</header>
|
|
|
|
<Tabs
|
|
activeTabId={activeTab}
|
|
onTabChange={setActiveTab}
|
|
tabs={expenseDetailTabs}
|
|
variant='lifted'
|
|
className={{
|
|
wrapper: 'max-w-5xl mx-auto mt-4',
|
|
}}
|
|
/>
|
|
</section>
|
|
</>
|
|
);
|
|
};
|
|
|
|
export default ExpenseDetail;
|