2025-08-08 17:59:39 +07:00
|
|
|
'use client'
|
|
|
|
|
|
|
|
|
|
// MUI Imports
|
|
|
|
|
import Grid from '@mui/material/Grid2'
|
|
|
|
|
|
|
|
|
|
// Component Imports
|
|
|
|
|
import DistributedBarChartOrder from '@views/dashboards/crm/DistributedBarChartOrder'
|
|
|
|
|
|
|
|
|
|
// Server Action Imports
|
|
|
|
|
import Loading from '../../../../../../components/layout/shared/Loading'
|
|
|
|
|
import { useSalesAnalytics } from '../../../../../../services/queries/analytics'
|
2025-08-10 22:56:04 +07:00
|
|
|
import { RecentSale } from '../../../../../../types/services/analytic'
|
|
|
|
|
import OrdersReport from '../../../../../../views/dashboards/orders/OrdersReport'
|
2025-08-08 17:59:39 +07:00
|
|
|
|
|
|
|
|
const DashboardOrder = () => {
|
|
|
|
|
const { data, isLoading } = useSalesAnalytics()
|
|
|
|
|
|
|
|
|
|
if (isLoading) return <Loading />
|
|
|
|
|
|
|
|
|
|
return (
|
|
|
|
|
<Grid container spacing={6}>
|
|
|
|
|
<Grid size={{ xs: 12, sm: 6, md: 4, lg: 3 }}>
|
|
|
|
|
<DistributedBarChartOrder
|
|
|
|
|
isLoading={isLoading}
|
|
|
|
|
title='Total Items'
|
2025-08-12 21:29:24 +07:00
|
|
|
isCurrency={false}
|
2025-08-08 17:59:39 +07:00
|
|
|
value={data?.summary.total_items as number}
|
|
|
|
|
avatarIcon={'tabler-package'}
|
|
|
|
|
avatarColor='primary'
|
|
|
|
|
avatarSkin='light'
|
|
|
|
|
/>
|
|
|
|
|
</Grid>
|
|
|
|
|
<Grid size={{ xs: 12, sm: 6, md: 4, lg: 3 }}>
|
|
|
|
|
<DistributedBarChartOrder
|
|
|
|
|
isLoading={isLoading}
|
|
|
|
|
title='Total Orders'
|
2025-08-12 21:29:24 +07:00
|
|
|
isCurrency={false}
|
2025-08-08 17:59:39 +07:00
|
|
|
value={data?.summary.total_orders as number}
|
|
|
|
|
avatarIcon={'tabler-shopping-cart'}
|
|
|
|
|
avatarColor='info'
|
|
|
|
|
avatarSkin='light'
|
|
|
|
|
/>
|
|
|
|
|
</Grid>
|
|
|
|
|
<Grid size={{ xs: 12, sm: 6, md: 4, lg: 3 }}>
|
|
|
|
|
<DistributedBarChartOrder
|
|
|
|
|
isLoading={isLoading}
|
|
|
|
|
title='Average Orders'
|
2025-08-12 21:29:24 +07:00
|
|
|
isCurrency={true}
|
2025-08-08 17:59:39 +07:00
|
|
|
value={data?.summary.average_order_value as number}
|
|
|
|
|
avatarIcon={'tabler-trending-up'}
|
|
|
|
|
avatarColor='warning'
|
|
|
|
|
avatarSkin='light'
|
|
|
|
|
/>
|
|
|
|
|
</Grid>
|
|
|
|
|
<Grid size={{ xs: 12, sm: 6, md: 4, lg: 3 }}>
|
|
|
|
|
<DistributedBarChartOrder
|
|
|
|
|
isLoading={isLoading}
|
|
|
|
|
title='Total Sales'
|
2025-08-12 21:29:24 +07:00
|
|
|
isCurrency={true}
|
2025-08-08 17:59:39 +07:00
|
|
|
value={data?.summary.total_sales as number}
|
|
|
|
|
avatarIcon={'tabler-currency-dollar'}
|
|
|
|
|
avatarColor='success'
|
|
|
|
|
avatarSkin='light'
|
|
|
|
|
/>
|
|
|
|
|
</Grid>
|
|
|
|
|
<Grid size={{ xs: 12, lg: 12 }}>
|
2025-08-10 22:56:04 +07:00
|
|
|
<OrdersReport title='Sales Report' orderData={data?.data as RecentSale[]} />
|
2025-08-08 17:59:39 +07:00
|
|
|
</Grid>
|
|
|
|
|
</Grid>
|
|
|
|
|
)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
export default DashboardOrder
|