training_data/apps/web/src/components/models/course/detail/CourseDetailTitle.tsx

53 lines
1.4 KiB
TypeScript
Raw Normal View History

2025-02-26 23:01:58 +08:00
import { useContext } from "react";
import { CourseDetailContext } from "./CourseDetailContext";
import { useNavigate } from "react-router-dom";
2025-02-27 09:05:29 +08:00
import {
BookOutlined,
CalendarOutlined,
EditTwoTone,
EyeOutlined,
ReloadOutlined,
} from "@ant-design/icons";
2025-02-26 23:01:58 +08:00
import dayjs from "dayjs";
2025-02-27 09:05:29 +08:00
import CourseOperationBtns from "./JoinLearingButton";
2025-02-26 23:01:58 +08:00
export default function CourseDetailTitle() {
const {
course,
isLoading,
canEdit,
lecture,
lectureIsLoading,
selectedLectureId,
} = useContext(CourseDetailContext);
const navigate = useNavigate();
return (
<div className="flex justify-center flex-col items-center gap-2 w-full my-2 px-6">
<div className="flex justify-start w-full text-2xl font-bold">
{course?.title}
</div>
2025-02-27 09:05:29 +08:00
<div className="text-gray-600 flex w-full justify-start items-center gap-5">
2025-02-26 23:01:58 +08:00
<div className="flex gap-1">
<CalendarOutlined></CalendarOutlined>
{"创建于:"}
{dayjs(course?.createdAt).format("YYYY年M月D日")}
</div>
<div className="flex gap-1">
2025-02-27 09:05:29 +08:00
<ReloadOutlined spin></ReloadOutlined>
2025-02-26 23:01:58 +08:00
{"更新于:"}
{dayjs(course?.updatedAt).format("YYYY年M月D日")}
</div>
<div className="flex gap-1">
<EyeOutlined></EyeOutlined>
<div>{`观看次数${course?.meta?.views || 0}`}</div>
</div>
<div className="flex gap-1">
<BookOutlined />
<div>{`学习人数${course?.studentIds?.length || 0}`}</div>
</div>
2025-02-27 09:05:29 +08:00
<CourseOperationBtns />
2025-02-26 23:01:58 +08:00
</div>
</div>
);
}