-
Notifications
You must be signed in to change notification settings - Fork 14
/
Copy pathreviewCard.tsx
79 lines (74 loc) · 2.07 KB
/
reviewCard.tsx
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
'use client'
import { Rating, User } from "@/db/schema";
import { getUser } from "@/db/utils";
import { useEffect, useState } from "react";
import Image from "next/image";
import { Star } from "lucide-react";
/*
This ReviewCard component is loaded on the client side and is responsible for displaying a single
review.
*/
export default function ReviewCard(
{ review }: { review: Rating }
) {
const [author, setAuthor] = useState<User | null>(null); // The author of the review
/*
On page load and whenever the review changes, get the author of the review.
*/
useEffect(() => {
/*
TODO: Get the author of the review and update the author state.
*/
}, [review]);
return (
<div className="flex flex-col w-full">
{
author != null && (
<a href={`/seller/${author.username}`} className="flex flex-row items-center justify-start gap-4">
{
author.profilePic !== "" ? (
<Image
src={author.profilePic}
alt=""
height={40}
width={40}
className="w-[40px] h-[40px] rounded-full"
/>
) : (
<div className="w-[40px] h-[40px] rounded-full bg-yellow-500"></div>
)
}
<span className="">{author?.username}</span>
</a>
)
}
<div className="text-md flex flex-row">
{
[1, 2, 3, 4, 5].map((i) => {
return (
<Star key={i} className={i <= Math.round(review.stars) ? "text-orange-500 fill-orange-500" : "text-orange-500"} />
);
})
}
</div>
<span className="text-gray-500">
Reviewed on {
/*
TODO: Display the formatted date the review was created.
*/
"PLACEHOLDER"
}
</span>
<div>
<span>
{
/*
TODO: Display the review comment.
*/
"PLACEHOLDER"
}
</span>
</div>
</div>
)
}