diff --git a/client/node_modules/.cache/default-development/index.pack_ b/client/node_modules/.cache/default-development/index.pack_ deleted file mode 100644 index 33b6e1a4df..0000000000 Binary files a/client/node_modules/.cache/default-development/index.pack_ and /dev/null differ diff --git a/client/src/component/AddVideo.jsx b/client/src/component/AddVideo.jsx index 73c2965b80..ae356f1233 100644 --- a/client/src/component/AddVideo.jsx +++ b/client/src/component/AddVideo.jsx @@ -46,8 +46,7 @@ function Addvideo() { const videoToAdd = { ...newVideo, rating: 0, - id: idCounter, - timestamp: new Date().toISOString(), + timestamp: new Date().toISOString() }; try { @@ -63,10 +62,7 @@ function Addvideo() { ); if (response.ok) { - // const responseData = await response.json(); - // setVideos([...videos, responseData]); - setNewVideo({ title: "", url: "" }); - setIdCounter(idCounter + 1); + console.log("Video added."); } else { console.error("Failed to add video:", response.statusText); } diff --git a/client/src/component/ShowingVideos.jsx b/client/src/component/ShowingVideos.jsx index 84c9ea5856..48b1341cbd 100644 --- a/client/src/component/ShowingVideos.jsx +++ b/client/src/component/ShowingVideos.jsx @@ -1,49 +1,109 @@ -import React, { useState } from "react"; +import React, { useState, useEffect } from "react"; -function ShowingVideos(props) { - const [videos, setVideos] = useState(props.result); +function ShowingVideos() { + const [videos, setVideos] = useState([]); + const [orderBy, setOrderBy] = useState("desc"); - function convertToEmbedUrl(url) { + useEffect(() => { + fetch("https://node-js-full-stack-project-assessment.onrender.com/videos") + .then((response) => response.json()) + .then((data) => { + // setVideos([]) + setVideos(data); + console.log("lin 12,", data); + }) + .catch((error) => { + console.error("Error fetching data:", error); + }); + }, [videos]); + + const toggleOrder = () => { + setOrderBy(orderBy === "asc" ? "desc" : "asc"); + }; + + const convertToEmbedUrl = (url) => { const videoId = url.split("v=")[1]; return `https://www.youtube.com/embed/${videoId}`; - } - - function deleteVideo(id) { - const updatedVideos = videos.filter((video) => video.id !== id); - setVideos(updatedVideos); - } + }; - function handleRating(id, type) { - const updatedVideos = videos.map((video) => { - if (video.id === id) { - if (type === "thumbs-up") { - return { ...video, rating: video.rating + 1 }; - } else if (type === "thumbs-down") { - return { ...video, rating: video.rating - 1 }; - } + const deleteVideo = (id) => { + fetch( + `https://node-js-full-stack-project-assessment.onrender.com/videos/${id}`, + { + method: "DELETE", } - return video; - }); + ) + .then((response) => { + return response.json(); + }) + .then(() => { + setVideos((prevVideos) => + prevVideos.filter((video) => video.id !== id) + ); + }) + .catch((error) => { + console.error("Error deleting video:", error); + }); + }; - setVideos(updatedVideos); - } + const handleRating = (id, type) => { + fetch( + `https://node-js-full-stack-project-assessment.onrender.com/rate/${id}/${type}`, + { + method: "PUT", + } + ) + .then((response) => { + return response.json(); + }) + .then((updatedRating) => { + setVideos((prevVideos) => + prevVideos.map((video) => { + if (video.id === id) { + return { ...video, rating: updatedRating.rating }; + } + console.log("lin 65", video); + return video; + }) + ); + }) + .catch((error) => { + console.error("Error updating rating:", error); + }); + }; - const sortedVideos = [...videos].sort((a, b) => b.rating - a.rating); + const sortedVideos = [...videos].sort((a, b) => { + if (orderBy === "asc") { + return a.rating - b.rating; + } else { + return b.rating - a.rating; + } + }); + ///////////////////////////////// + console.log("line 79", videos); + console.log("lin 80", sortedVideos); + /////////////////////////////////// return (
+ + {sortedVideos.map((video) => (
+ {/* ///////////////////// */} +

{console.log("line 93", video)}

{video.title}

handleRating(video.id)} + onClick={() => handleRating(video.id, "up")} >

{video.rating}

handleRating(video.id)} + onClick={() => handleRating(video.id, "down")} >