Files
Frontend/src/app/(dashboard)/(private)/apps/ecommerce/referrals/page.tsx
T
2026-02-19 01:15:36 +03:30

73 lines
2.5 KiB
TypeScript

// MUI Imports
import Grid from '@mui/material/Grid2'
// Component Imports
import HorizontalStatisticsCard from '@views/apps/ecommerce/referrals/HorizontalStatisticsCard'
import IconStepsCard from '@views/apps/ecommerce/referrals/IconStepsCard'
import InviteAndShare from '@views/apps/ecommerce/referrals/InviteAndShare'
import ReferredUsersTable from '@views/apps/ecommerce/referrals/ReferredUsersTable'
// Data Imports
import { getEcommerceData, getStatisticsData } from '@/app/server/actions'
/**
* ! If you need data using an API call, uncomment the below API code, update the `process.env.API_URL` variable in the
* ! `.env` file found at root of your project and also update the API endpoints like `/pages/widget-examples` in below example.
* ! Also, remove the above server action import and the action itself from the `src/app/server/actions.ts` file to clean up unused code
* ! because we've used the server action for getting our static data.
*/
/* const getStatisticsData = async () => {
// Vars
const res = await fetch(`${process.env.API_URL}/pages/widget-examples`)
if (!res.ok) {
throw new Error('Failed to fetch statistics data')
}
return res.json()
} */
/**
* ! If you need data using an API call, uncomment the below API code, update the `process.env.API_URL` variable in the
* ! `.env` file found at root of your project and also update the API endpoints like `/apps/ecommerce` in below example.
* ! Also, remove the above server action import and the action itself from the `src/app/server/actions.ts` file to clean up unused code
* ! because we've used the server action for getting our static data.
*/
/* const getEcommerceData = async () => {
// Vars
const res = await fetch(`${process.env.API_URL}/apps/ecommerce`)
if (!res.ok) {
throw new Error('Failed to fetch ecommerce data')
}
return res.json()
} */
const eCommerceReferrals = async () => {
// Vars
const statsData = await getStatisticsData()
const ecommerceData = await getEcommerceData()
return (
<Grid container spacing={6}>
<Grid size={{ xs: 12 }}>
<HorizontalStatisticsCard data={statsData?.statsHorizontalWithAvatar} />
</Grid>
<Grid size={{ xs: 12, md: 8 }}>
<IconStepsCard />
</Grid>
<Grid size={{ xs: 12, md: 4 }}>
<InviteAndShare />
</Grid>
<Grid size={{ xs: 12 }}>
<ReferredUsersTable referralsData={ecommerceData?.referrals} />
</Grid>
</Grid>
)
}
export default eCommerceReferrals