Add: get reviews and fix bug

This commit is contained in:
2021-12-13 04:47:00 +08:00
parent 6b8bfedb9b
commit 12739be2f5
6 changed files with 151 additions and 10 deletions

View File

@@ -1,9 +1,36 @@
import { useState } from "react";
import { useState, useEffect } from "react";
import { useParams } from "react-router";
import { Link } from "react-router-dom";
import { convertIntToDateTime } from "./Common";
function ReviewPage() {
let params = useParams();
const [newReview, setNewReview] = useState("");
const [reviews, setReviews] = useState([]);
function refresh() {
fetch("/api/v1/get_reviews_on_file", {
method: "POST",
headers: {
"Content-Type": "application/json",
},
body: JSON.stringify({
id: parseInt(params.id),
}),
})
.then((response) => response.json())
.then((data) => {
if (data.error) {
alert(data.error);
} else {
setReviews(data.reviews);
}
});
}
useEffect(() => {
refresh();
}, []);
function submitReview() {
fetch("/api/v1/insert_review", {
@@ -22,6 +49,7 @@ function ReviewPage() {
alert(data.error);
} else {
setNewReview("");
refresh();
}
});
}
@@ -29,6 +57,17 @@ function ReviewPage() {
return (
<div className="page">
<h3>Review Page</h3>
<div>
{reviews.map((review) => (
<div key={review.id}>
<h4>
<Link to={`/manage/users/${review.user.id}`}>@{review.user.username}</Link> wrote on{" "}
{convertIntToDateTime(review.created_at)}{" "}
</h4>
<p>{review.content}</p>
</div>
))}
</div>
<div>
<textarea
value={newReview}