feat/course
Arik Chakma 1 month ago
parent 7d1880fd3c
commit 0b75bcee32
  1. 45
      src/components/CourseNotes/CourseNoteCard.tsx

@ -0,0 +1,45 @@
import { useMemo } from 'react';
import { markdownToHtml } from '../../lib/markdown';
type CourseNoteCardProps = {
courseId: string;
chapterId: string;
chapterTitle: string;
lessonId: string;
lessonTitle: string;
content: string;
};
export function CourseNoteCard(props: CourseNoteCardProps) {
const { chapterTitle, lessonTitle, content, courseId, chapterId, lessonId } =
props;
const markdownHTML = useMemo(() => {
const html = markdownToHtml(content, false);
// FIXME: Sanitize html before returning
return html;
}, [content]);
return (
<div className="flex flex-col gap-3 p-4">
<div className="flex max-w-max items-center gap-1 rounded-full border border-zinc-700 px-3 py-1 text-xs text-zinc-200">
<a className="underline-offset-2 hover:text-white hover:underline">
{chapterTitle}
</a>
<span className="text-zinc-400">/</span>
<a className="underline-offset-2 hover:text-white hover:underline">
{lessonTitle}
</a>
</div>
<div
className="course-content prose prose-sm prose-invert line-clamp-3"
// FIXME: Sanitize content before rendering
dangerouslySetInnerHTML={{ __html: markdownHTML }}
></div>
</div>
);
}
Loading…
Cancel
Save