From 2619f06c42f2457cabc6cc87f81c81f2a398d3af Mon Sep 17 00:00:00 2001 From: JeongHeum Byun <111037279+quswjdgma83@users.noreply.github.com> Date: Wed, 18 Oct 2023 00:09:40 +0900 Subject: [PATCH] feat: History page(Add dropdown function) (#250) * style: History)style.css - Add style for dropdown(#211) Signed-off-by: ByunJeongHeum Co-authored-by: Han Kyuhyun Co-authored-by: June Saehwan Co-authored-by: jongmin Lee * feat: History.jsx - Add function for flexible amount of Scan(#211) Signed-off-by: ByunJeongHeum Co-authored-by: Han Kyuhyun Co-authored-by: June Saehwan Co-authored-by: jongmin Lee * style: History)style.css - Add style for dropdown(#211) Signed-off-by: ByunJeongHeum Co-authored-by: Han Kyuhyun Co-authored-by: June Saehwan Co-authored-by: jongmin Lee * edit minor bug Signed-off-by: ByunJeongHeum Co-authored-by: Han Kyuhyun Co-authored-by: June Saehwan Co-authored-by: jongmin Lee * Include review, Correct navigation bar errors. Signed-off-by: Han Kyuhyun Co-authored-by: ByunJeongHeum Co-authored-by: June Saehwan Co-authored-by: jongmin Lee * Include Review, Move DropBox. Signed-off-by: Han Kyuhyun Co-authored-by: ByunJeongHeum Co-authored-by: June Saehwan Co-authored-by: jongmin Lee * Remove unnessary svg File. Signed-off-by: Han Kyuhyun Co-authored-by: ByunJeongHeum Co-authored-by: June Saehwan Co-authored-by: jongmin Lee * Remove unnessary empty space. Signed-off-by: Han Kyuhyun Co-authored-by: ByunJeongHeum Co-authored-by: June Saehwan Co-authored-by: jongmin Lee --------- Signed-off-by: ByunJeongHeum Signed-off-by: Han Kyuhyun Co-authored-by: Han Kyuhyun Co-authored-by: June Saehwan Co-authored-by: jongmin Lee --- frontend/public/image/svg/OptionBoxStroke.svg | 17 - frontend/src/css/History_style.css | 107 +++-- frontend/src/pages/History.jsx | 378 ++++++++---------- 3 files changed, 227 insertions(+), 275 deletions(-) delete mode 100644 frontend/public/image/svg/OptionBoxStroke.svg diff --git a/frontend/public/image/svg/OptionBoxStroke.svg b/frontend/public/image/svg/OptionBoxStroke.svg deleted file mode 100644 index 44a2b0ff..00000000 --- a/frontend/public/image/svg/OptionBoxStroke.svg +++ /dev/null @@ -1,17 +0,0 @@ - - - - - - - - - - - - - - - - - diff --git a/frontend/src/css/History_style.css b/frontend/src/css/History_style.css index 994af488..0d6d71da 100644 --- a/frontend/src/css/History_style.css +++ b/frontend/src/css/History_style.css @@ -10,29 +10,21 @@ display: flex; flex-direction: row; justify-content: center; - width: 100%; - position: relative; } .history-send .div { background-color: #ffffff; border: 1px none; - height: 1080px; position: relative; width: 1920px; } .history-send .overlap { - background-image: url(../../public/image/svg/OptionBoxStroke.svg); - background-size: 100% 100%; height: 882px; left: 34px; position: absolute; top: 133px; width: 572px; - border-radius: 30px; - box-shadow: 0px 4px 4px #00000040, 2px 2px 2px 1px gray; - border: 1px solid gray; } .history-send .option-menu { @@ -209,7 +201,6 @@ display: block; } - .history-send .text-wrapper-3 { color: #000000; font-family: "Inter-Bold", Helvetica; @@ -218,25 +209,24 @@ left: 10px; letter-spacing: 0; line-height: normal; - position: absolute; + position: relative; top: 0; white-space: nowrap; } .history-send .page-move-tool-bar { height: 30px; - left: 845px; + left: 900px; position: absolute; - top: 1027px; width: 286px; } .history-send .page-number { align-items: flex-start; + margin-top: 20px; display: inline-flex; gap: 33px; left: 35px; - position: absolute; top: 0; } @@ -311,11 +301,9 @@ } .history-send .overlap-2 { - height: 882px; - left: 635px; - position: absolute; - top: 134px; width: 1236px; + position: relative; + margin: 140px 0 0 630px; } .history-send .history-box { @@ -329,16 +317,15 @@ .history-send .history { height: 158px; left: 0; - position: absolute; top: 724px; width: 1242px; } .history-send .overlap-3 { + margin-top: 22px; background-image: url(../../public/image/png/Stroke.png); background-size: 100% 100%; height: 166px; - left: -4px; position: relative; width: 1244px; } @@ -371,8 +358,6 @@ position: absolute; top: 65px; white-space: nowrap; - - } .history-send .text-wrapper-8 ::after { @@ -755,7 +740,7 @@ letter-spacing: 0; line-height: normal; position: absolute; - top: 43px; + top: 42px; white-space: nowrap; width: 167px; } @@ -769,7 +754,7 @@ } .history-send .menu-line { - background-color: #0057b8; + background-color: #000000; height: 3px; left: 0; position: absolute; @@ -778,6 +763,7 @@ } .history-send .menu { + background-color: white; height: 96px; left: 0; position: absolute; @@ -812,7 +798,7 @@ letter-spacing: 0; line-height: normal; position: absolute; - top: 43px; + top: 42px; width: 115px; } @@ -855,6 +841,34 @@ width: 71px; } +.history-send .text-wrapper-24 { + color: #000000; + font-family: "Inter-Regular", Helvetica; + font-size: 30px; + font-weight: 400; + left: 1395px; + letter-spacing: 0; + line-height: normal; + position: absolute; + top: 43px; + white-space: nowrap; + width: 167px; +} + +.history-send .text-wrapper-25 { + color: #000000; + font-family: "Inter-Regular", Helvetica; + font-size: 30px; + font-weight: 400; + left: 1270px; + letter-spacing: 0; + line-height: normal; + position: absolute; + top: 43px; + white-space: nowrap; + width: 104px; +} + .history-send .LPVS { height: 96px; left: 0; @@ -874,23 +888,9 @@ top: 0px; white-space: nowrap; width: 100%; - margin-left: 10px; - position: static; - z-index: 1; -} - -.history-send .text-wrapper-998 { - color: #000000; - font-family: "Inter-Medium", Helvetica; - font-size: 20px; - font-weight: 500; - letter-spacing: 0; - line-height: normal; - top: 0; - width: 100%; margin-left: 10px; position: static; - right: 0; + z-index: 1; } .history-send .status-label { @@ -1003,3 +1003,32 @@ top: 3px; width: 100%; } + +.history-send .dropdown { + left: 53%; + margin-top: -25px; + position: absolute; + display: flex; + flex-direction: row; + align-items: center; +} + +.history-send .dropdown span { + justify-content: start; + width: 160px; + font-size: 20px; + font-weight: bold; + margin-right: -20px; +} + +.history-send .dropdown select { + padding: 5px; + width: 85px; + border: 0.1px solid black; + border-radius: 8px; + background-color: white; + font-size: 16px; + text-align: center; + outline: none; + transition: border-color 0.3s ease; +} diff --git a/frontend/src/pages/History.jsx b/frontend/src/pages/History.jsx index 8a35289c..c265b4db 100644 --- a/frontend/src/pages/History.jsx +++ b/frontend/src/pages/History.jsx @@ -5,16 +5,16 @@ * found in the LICENSE file. */ -import {React,useEffect, useState} from "react"; +import { React, useEffect, useState } from "react"; import axios from 'axios'; import { Link, useParams, useLocation } from "react-router-dom"; import { useNavigate } from "react-router-dom"; import "../css/History_style.css"; -export const History= () => { +export const History = () => { const { type, name } = useParams(); - const [ lpvsHistories, setlpvsHistories ] = useState(); + const [lpvsHistories, setlpvsHistories] = useState(); const navigate = useNavigate(); const location = useLocation(); @@ -25,6 +25,8 @@ export const History= () => { const [isLoggedIn, setIsLoggedIn] = useState(false); const [username, setUsername] = useState(""); + const [selectedSize, setSelectedSize] = useState(5); + useEffect(() => { axios.get("/user/login") .then((loginresponse) => { @@ -34,7 +36,7 @@ export const History= () => { .then((userInfoResponse) => { setUsername(userInfoResponse.data); }) - .catch(function(error) { + .catch(function (error) { console.log(error.toJSON()); navigate("/user/login"); }); @@ -42,7 +44,7 @@ export const History= () => { navigate("/user/login"); } }) - .catch(function(error) { + .catch(function (error) { console.log(error.toJSON()); navigate("/user/login"); }); @@ -50,12 +52,11 @@ export const History= () => { useEffect(() => { axios - .get(`/history/${type}/${name}?page=${page}`) + .get(`/history/${type}/${name}?page=${page}&size=${selectedSize}`) .then((response) => { - console.log(response.data) - setlpvsHistories(response.data); + setlpvsHistories(response.data); }) - .catch(function(error) { + .catch(function (error) { console.log(error.toJSON()); const userChoice = window.confirm("Please enter the GitHub ID on the User page."); if (userChoice) { @@ -64,7 +65,7 @@ export const History= () => { navigate(`/history/send/${username?.nickname}?page=0`); } }); - }, [type, name, page]); + }, [type, name, page, selectedSize]); const handlePageChange = (pageNumber) => { navigate(`/history/${type}/${name}?page=${pageNumber}`); @@ -79,8 +80,6 @@ export const History= () => { setIsHistoriesEmpty(false); } }, [lpvsHistories, page]); - - console.log(lpvsHistories) const navigateToOrg = () => { if (!username?.organization || username?.organization.trim() === "") { @@ -90,43 +89,40 @@ export const History= () => { } }; const navigateToOwn = () => { - navigate(`/history/own/${username?.nickname}?page=0`); + navigate(`/history/own/${username?.nickname}?page=0`); }; const navigateToSend = () => { - navigate(`/history/send/${username?.nickname}?page=0`); + navigate(`/history/send/${username?.nickname}?page=0`); }; - const [pageCount,setPageCount] = useState(1); - const [currentPage, setCurrentPage] = useState(1); - - useEffect(()=> { - setPageCount(Math.ceil(lpvsHistories?.count/5)) - }, [lpvsHistories?.count, currentPage]); + const [pageCount, setPageCount] = useState(1); + const [currentPage, setCurrentPage] = useState(1); - console.log(pageCount); + useEffect(() => { + setPageCount(Math.ceil(lpvsHistories?.count / selectedSize)); + }, [lpvsHistories?.count, selectedSize]); - const check_page_plus =()=> { - if(currentPage <= pageCount) { + const checkPagePlus = () => { + if (currentPage <= pageCount) { console.log(currentPage) - return setCurrentPage(currentPage+5); + return setCurrentPage(currentPage + 5); } else { - return + return } - } - console.log(page); - console.log(currentPage); - const check_page_minus =(page)=> { - if(page <=4) { + } + + const checkPageMinus = (page) => { + if (page <= 4) { return setCurrentPage(currentPage) } else { - return setCurrentPage(currentPage-5); + return setCurrentPage(currentPage - 5); } - } + } - const trueOrFalse =(a)=> { - if(a <= pageCount) { + const trueOrFalse = (a) => { + if (a <= pageCount) { return true; } else { @@ -134,34 +130,95 @@ export const History= () => { } } - const status_check=(a)=> { - if(a) { + const statusCheck = (a) => { + if (a) { return 'Issue-Detected'; } else { return 'Scan-completed'; } - } - console.log(lpvsHistories?.lpvsHistories[0]?.status) + } if (!lpvsHistories) { return
Loading...
; } function truncateName(name) { - if (/[\u3131-\u314e\u314f-\u3163\uac00-\ud7a3]/g.test(name)) { - return name.length > 3 ? `${name.substring(0, 3)}.` : name; - } else { - return name.length > 5 ? `${name.substring(0, 5)}.` : name; - } - } - - const pageArrow=(page)=> { - if(page<=5) { - return false; + if (/[\u3131-\u314e\u314f-\u3163\uac00-\ud7a3]/g.test(name)) { + return name.length > 3 ? `${name.substring(0, 3)}.` : name; + } else { + return name.length > 5 ? `${name.substring(0, 5)}.` : name; } } - console.log(isHistoriesEmpty) + + const renderHistories = (size) => { + return Array.from({ length: size }).map((_, index) => { + const history = lpvsHistories.lpvsHistories[index]; + if (history?.status !== undefined) { + return ( + +
+
+
+ {history?.repositoryName} +
+
+
+ {statusCheck(history?.hasIssue)} +
+
+
+
+
{history?.pullNumber}
+
+
+
+
+
{history?.url}
+
{history?.scanDate}
+
+
+
+ + ); + } + return null; + }); + }; + + const SIZE_DATA = [ + { id: null, value: 'Choose view Size.' }, + { id: '5', value: '5' }, + { id: '10', value: '10' }, + { id: '20', value: '20' }, + { id: '50', value: '50' }, + ]; + + const SizeDropdown = () => { + const handleChange = (e) => { + setSelectedSize(e.target.value); + setCurrentPage(1); + }; + + return ( +
+ {selectedSize && View Items {selectedSize}} + +
+ ); + }; + + return (
@@ -170,27 +227,27 @@ export const History= () => {
-
- {type === "send" ? -
My Pull Request
- : -
My Pull Request
} +
+ {type === "send" ? +
My Pull Request
+ : +
My Pull Request
}
-
- {type === "own" ? -
My Repo PR
- : -
My Repo PR
} +
+ {type === "own" ? +
My Repo PR
+ : +
My Repo PR
}
-
- {type === "org" ? -
My Org PR
- : -
My Org PR
} +
+ {type === "org" ? +
My Org PR
+ : +
My Org PR
}
@@ -198,155 +255,34 @@ export const History= () => {
My option line
My Option
+
+ +
+ {renderHistories(selectedSize ?? 5)} +
+
- { - if (page > 4) { - check_page_minus(); - handlePageChange(currentPage - 2); - }}} style={{ cursor: "pointer" }} /> - {trueOrFalse(currentPage) &&
handlePageChange(currentPage-1)}>{currentPage}
} - {trueOrFalse(currentPage+1) &&
handlePageChange(currentPage)}>{currentPage+1}
} - {trueOrFalse(currentPage+2) &&
handlePageChange(currentPage+1)}>{currentPage+2}
} - {trueOrFalse(currentPage+3) &&
handlePageChange(currentPage+2)}>{currentPage+3}
} - {trueOrFalse(currentPage+4) &&
handlePageChange(currentPage+3)}>{currentPage+4}
} - {trueOrFalse(currentPage+5) ? {check_page_plus(); handlePageChange(currentPage + 4); }}style={{ cursor: "pointer" }}/> - : - } + { + if (page > 4) { + checkPageMinus(); + handlePageChange(currentPage - 2); + } + }} style={{ cursor: "pointer" }} /> + {trueOrFalse(currentPage) &&
handlePageChange(currentPage - 1)}>{currentPage}
} + {trueOrFalse(currentPage + 1) &&
handlePageChange(currentPage)}>{currentPage + 1}
} + {trueOrFalse(currentPage + 2) &&
handlePageChange(currentPage + 1)}>{currentPage + 2}
} + {trueOrFalse(currentPage + 3) &&
handlePageChange(currentPage + 2)}>{currentPage + 3}
} + {trueOrFalse(currentPage + 4) &&
handlePageChange(currentPage + 3)}>{currentPage + 4}
} + {trueOrFalse(currentPage + 5) ? { checkPagePlus(); handlePageChange(currentPage + 4); }} style={{ cursor: "pointer" }} /> + : + }
-
-
- {lpvsHistories.lpvsHistories[4]?.status !== undefined ? ( - -
-
- -
- {lpvsHistories.lpvsHistories[4]?.repositoryName} -
-
-
- {status_check(lpvsHistories.lpvsHistories[4]?.hasIssue)} -
-
-
-
-
{lpvsHistories.lpvsHistories[4]?.pullNumber}
-
-
-
-
-
-
{lpvsHistories.lpvsHistories[4]?.url}
-
{lpvsHistories.lpvsHistories[4]?.scanDate}
-
-
): null} - - {lpvsHistories.lpvsHistories[3]?.status !== undefined ? ( - -
-
-
- {lpvsHistories.lpvsHistories[3]?.repositoryName} -
-
-
{status_check(lpvsHistories.lpvsHistories[3]?.hasIssue)}
-
-
-
-
-
{lpvsHistories.lpvsHistories[3]?.pullNumber}
-
-
- -
-
-
{lpvsHistories.lpvsHistories[3]?.url}
-
{lpvsHistories.lpvsHistories[3]?.scanDate}
-
-
- ): null} - - {lpvsHistories.lpvsHistories[2]?.status !== undefined ? ( - -
-
-
- {lpvsHistories.lpvsHistories[2]?.repositoryName} -
-
-
{status_check(lpvsHistories.lpvsHistories[2]?.hasIssue)}
-
-
-
-
-
{lpvsHistories.lpvsHistories[2]?.pullNumber}
-
-
-
-
-
{lpvsHistories.lpvsHistories[2]?.url}
-
{lpvsHistories.lpvsHistories[2]?.scanDate}
-
-
- - ): null} - - {lpvsHistories.lpvsHistories[1]?.status !== undefined ? ( - -
-
-
- {lpvsHistories.lpvsHistories[1]?.repositoryName} -
-
-
{status_check(lpvsHistories.lpvsHistories[1]?.hasIssue)}
-
-
-
-
-
{lpvsHistories.lpvsHistories[1]?.pullNumber}
-
-
-
-
-
{lpvsHistories.lpvsHistories[1]?.url}
-
{lpvsHistories.lpvsHistories[1]?.scanDate}
-
-
- - ) : null} - {lpvsHistories.lpvsHistories[0]?.status !== undefined ? ( - -
-
-
- {lpvsHistories.lpvsHistories[0]?.repositoryName} -
-
-
{status_check(lpvsHistories.lpvsHistories[0]?.hasIssue)}
-
-
-
-
-
{lpvsHistories.lpvsHistories[0]?.pullNumber}
-
-
-
-
-
{lpvsHistories.lpvsHistories[0]?.url}
-
{lpvsHistories.lpvsHistories[0]?.scanDate}
-
-
- - ): null} -
-
@@ -355,26 +291,30 @@ export const History= () => {
Image -
{username.name ? ( -
{truncateName(username.name)}
+
{username.name ? ( +
{truncateName(username.name)}
) : ( -
Loading...
+
Loading...
)}
-
Dashboard
-
- History - -
- - img - +
+ Dashboard +
+
+ History + +
+ + img +