|
1 | | -import { getCourseDetail, getCourseId, listAvailableCourses } from "@/data/course" |
| 1 | +import { |
| 2 | + getCourseDetail, |
| 3 | + getCourseId, |
| 4 | + listAvailableCourses, |
| 5 | +} from '@/data/course' |
| 6 | +import ModuleCard from './module-card' |
2 | 7 |
|
3 | 8 | export async function generateStaticParams() { |
4 | | - const courses = await listAvailableCourses() |
| 9 | + const courses = await listAvailableCourses() |
5 | 10 |
|
6 | | - return courses.map((course) => ({ |
7 | | - sourceLanguageCode: course.uiLanguage, |
8 | | - targetLanguageCode: course.languageCode, |
9 | | - })) |
| 11 | + return courses.map((course) => ({ |
| 12 | + sourceLanguageCode: course.uiLanguage, |
| 13 | + targetLanguageCode: course.languageCode, |
| 14 | + })) |
10 | 15 | } |
11 | 16 |
|
12 | 17 | type Props = { |
13 | | - params: { |
14 | | - sourceLanguageCode: string |
15 | | - targetLanguageCode: string |
16 | | - } |
| 18 | + params: { |
| 19 | + sourceLanguageCode: string |
| 20 | + targetLanguageCode: string |
| 21 | + } |
17 | 22 | } |
18 | 23 |
|
19 | | -export default async function CourseHomePage({params}: Props) { |
20 | | - const courseId = await getCourseId(params) |
21 | | - const detail = await getCourseDetail(courseId) |
| 24 | +export default async function CourseHomePage({ params }: Props) { |
| 25 | + const courseId = await getCourseId(params) |
| 26 | + const detail = await getCourseDetail(courseId) |
22 | 27 |
|
23 | | - return <h1>{detail.targetLanguage.name}</h1> |
| 28 | + return ( |
| 29 | + <> |
| 30 | + <h1>{detail.targetLanguage.name}</h1> |
| 31 | + <ul className="flex space-y-6 flex-col p-6"> |
| 32 | + {detail.modules.map((module) => ( |
| 33 | + <li key={module.slug}> |
| 34 | + <ModuleCard course={detail} module={module} /> |
| 35 | + </li> |
| 36 | + ))} |
| 37 | + </ul> |
| 38 | + </> |
| 39 | + ) |
24 | 40 | } |
0 commit comments