feat: integrate dialog close context in vendor select field and CRUD dialog components feat: enhance vendor general info to format status using utility function feat: implement form dialog context for managing dialog close actions feat: add async select field dialog close context for better form handling fix: update form mutation hook to close dialog on successful submission feat: extend document print types to include expense and credit note feat: add settings update payload type to include logo and other fields feat: create employee attendance and work history pages with resource management feat: implement payment made and received detail pages with actions feat: add quick shortcuts component for easy navigation in the dashboard feat: create actions for payment made and received with print and delete options feat: implement dialog close context for better dialog management feat: add error parsing utility for improved error handling in API responses
35 lines
1.2 KiB
TypeScript
35 lines
1.2 KiB
TypeScript
import { DashboardDetailsPage } from '@/base/components/layout/dashboard'
|
|
import { getServerApi } from '@garage/api/server'
|
|
import { PaymentReceivedActions } from '@/modules/payment-received/payment-received-actions'
|
|
import { BanknoteIcon } from 'lucide-react'
|
|
import React from 'react'
|
|
|
|
export default async function PaymentReceivedDetailLayout(props: {
|
|
params: Promise<{ id: string }>
|
|
children: React.ReactNode
|
|
}) {
|
|
const { id } = await props.params
|
|
const api = await getServerApi()
|
|
const payment = await api.paymentReceived.show(id)
|
|
const data = (payment as any)?.data ?? payment
|
|
const title = data?.payment_number || 'Payment Details'
|
|
|
|
return (
|
|
<DashboardDetailsPage
|
|
title={title}
|
|
description={data?.payment_number ? `Payment #: ${data.payment_number}` : undefined}
|
|
icon={<BanknoteIcon className="size-5" />}
|
|
backHref="/sales/payment-received"
|
|
actions={<PaymentReceivedActions paymentId={id} />}
|
|
tabs={[
|
|
{
|
|
href: `/sales/payment-received/${id}`,
|
|
label: 'Details',
|
|
},
|
|
]}
|
|
>
|
|
{props.children}
|
|
</DashboardDetailsPage>
|
|
)
|
|
}
|