Compare commits
	
		
			No commits in common. "2da40e1f54df8edbf085e8b0f117213a3013d894" and "ef28e1743eae06df54f7937703f7cfbbd040e690" have entirely different histories.
		
	
	
		
			2da40e1f54
			...
			ef28e1743e
		
	
		
					 8 changed files with 57 additions and 96 deletions
				
			
		|  | @ -1,18 +0,0 @@ | ||||||
| import { useNavigate } from "react-router-dom"; |  | ||||||
| 
 |  | ||||||
| function BackButton(): JSX.Element { |  | ||||||
|   const navigate = useNavigate(); |  | ||||||
|   const goBack = (): void => { |  | ||||||
|     navigate(-1); |  | ||||||
|   }; |  | ||||||
|   return ( |  | ||||||
|     <button |  | ||||||
|       onClick={goBack} |  | ||||||
|       className="inline-block py-1 px-8 font-bold bg-orange-500 text-white border-2 border-black rounded-full cursor-pointer mt-5 mb-5 transition-colors duration-10 hover:bg-orange-600 hover:text-gray-300 font-family: 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif; font-size: 4vh;" |  | ||||||
|     > |  | ||||||
|       Back |  | ||||||
|     </button> |  | ||||||
|   ); |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| export default BackButton; |  | ||||||
|  | @ -1,6 +1,5 @@ | ||||||
| import BasicWindow from "../../Components/BasicWindow"; | import BasicWindow from "../../Components/BasicWindow"; | ||||||
| import Button from "../../Components/Button"; | import Button from "../../Components/Button"; | ||||||
| import BackButton from "../../Components/BackButton"; |  | ||||||
| 
 | 
 | ||||||
| function AdminManageUsers(): JSX.Element { | function AdminManageUsers(): JSX.Element { | ||||||
|   const content = <></>; |   const content = <></>; | ||||||
|  | @ -13,7 +12,12 @@ function AdminManageUsers(): JSX.Element { | ||||||
|           return; |           return; | ||||||
|         }} |         }} | ||||||
|       /> |       /> | ||||||
|       <BackButton /> |       <Button | ||||||
|  |         text="Back" | ||||||
|  |         onClick={(): void => { | ||||||
|  |           return; | ||||||
|  |         }} | ||||||
|  |       /> | ||||||
|     </> |     </> | ||||||
|   ); |   ); | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -6,12 +6,12 @@ function AdminMenuPage(): JSX.Element { | ||||||
|     <> |     <> | ||||||
|       <h1 className="font-bold text-[30px] mb-[20px]">Administrator Menu</h1> |       <h1 className="font-bold text-[30px] mb-[20px]">Administrator Menu</h1> | ||||||
|       <div className="border-4 border-black bg-white flex flex-col items-center justify-center min-h-[65vh] h-fit w-[50vw] rounded-3xl content-center overflow-scroll space-y-[10vh] p-[30px]"> |       <div className="border-4 border-black bg-white flex flex-col items-center justify-center min-h-[65vh] h-fit w-[50vw] rounded-3xl content-center overflow-scroll space-y-[10vh] p-[30px]"> | ||||||
|         <Link to="/admin-manage-users"> |         <Link to="/admin-users-page"> | ||||||
|           <h1 className="font-bold underline text-[30px] cursor-pointer"> |           <h1 className="font-bold underline text-[30px] cursor-pointer"> | ||||||
|             Manage Users |             Manage Users | ||||||
|           </h1> |           </h1> | ||||||
|         </Link> |         </Link> | ||||||
|         <Link to="/admin-manage-projects"> |         <Link to="/admin-projects-page"> | ||||||
|           <h1 className="font-bold underline text-[30px] cursor-pointer"> |           <h1 className="font-bold underline text-[30px] cursor-pointer"> | ||||||
|             Manage Projects |             Manage Projects | ||||||
|           </h1> |           </h1> | ||||||
|  |  | ||||||
|  | @ -1,9 +1,8 @@ | ||||||
| import Button from "../Components/Button"; | import Button from "../Components/Button"; | ||||||
| import Logo from "/src/assets/Logo.svg"; | import Logo from "/src/assets/Logo.svg"; | ||||||
| import "./LoginPage.css"; | import "./LoginPage.css"; | ||||||
| import { FormEvent, useEffect, useState } from "react"; | import { useEffect } from "react"; | ||||||
| import { NewUser } from "../Types/Users"; | import { Link } from "react-router-dom"; | ||||||
| import { useNavigate } from "react-router-dom"; |  | ||||||
| 
 | 
 | ||||||
| const PreloadBackgroundAnimation = (): JSX.Element => { | const PreloadBackgroundAnimation = (): JSX.Element => { | ||||||
|   useEffect(() => { |   useEffect(() => { | ||||||
|  | @ -27,39 +26,6 @@ const PreloadBackgroundAnimation = (): JSX.Element => { | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| function LoginPage(): JSX.Element { | function LoginPage(): JSX.Element { | ||||||
|   //Example users for testing without backend, remove when using backend
 |  | ||||||
|   const admin: NewUser = { |  | ||||||
|     name: "admin", |  | ||||||
|     password: "123", |  | ||||||
|   }; |  | ||||||
|   const pmanager: NewUser = { |  | ||||||
|     name: "pmanager", |  | ||||||
|     password: "123", |  | ||||||
|   }; |  | ||||||
|   const user: NewUser = { |  | ||||||
|     name: "user", |  | ||||||
|     password: "123", |  | ||||||
|   }; |  | ||||||
| 
 |  | ||||||
|   const navigate = useNavigate(); |  | ||||||
| 
 |  | ||||||
|   /* On submit (enter or button click) check if username and password match any user |  | ||||||
|    and if so, redirect to correct page */ |  | ||||||
|   function handleSubmit(event: FormEvent<HTMLFormElement>): void { |  | ||||||
|     event.preventDefault(); |  | ||||||
|     //TODO: Compare with db instead when finished
 |  | ||||||
|     if (username === admin.name && password === admin.password) { |  | ||||||
|       navigate("/admin-menu"); |  | ||||||
|     } else if (username === pmanager.name && password === pmanager.password) { |  | ||||||
|       navigate("/PM-project-page"); |  | ||||||
|     } else if (username === user.name && password === user.password) { |  | ||||||
|       navigate("/your-projects"); |  | ||||||
|     } |  | ||||||
|   } |  | ||||||
| 
 |  | ||||||
|   const [username, setUsername] = useState(""); |  | ||||||
|   const [password, setPassword] = useState(""); |  | ||||||
| 
 |  | ||||||
|   return ( |   return ( | ||||||
|     <> |     <> | ||||||
|       <PreloadBackgroundAnimation /> |       <PreloadBackgroundAnimation /> | ||||||
|  | @ -85,30 +51,24 @@ function LoginPage(): JSX.Element { | ||||||
|             {" "} |             {" "} | ||||||
|             Please log in to continue{" "} |             Please log in to continue{" "} | ||||||
|           </h2> |           </h2> | ||||||
|           <form className="flex flex-col items-center" onSubmit={handleSubmit}> |           <input | ||||||
|             <input |             className="border-2 border-black mb-3 rounded-lg w-[20vw] p-1" | ||||||
|               className="border-2 border-black mb-3 rounded-lg w-[20vw] p-1" |             type="text" | ||||||
|               type="text" |             placeholder="Username" | ||||||
|               placeholder="Username" |           /> | ||||||
|               onChange={(e) => { |           <input | ||||||
|                 setUsername(e.target.value); |             className="border-2 border-black mb-3 rounded-lg w-[20vw] p-1" | ||||||
|               }} |             type="password" | ||||||
|             /> |             placeholder="Password" | ||||||
|             <input |           /> | ||||||
|               className="border-2 border-black mb-3 rounded-lg w-[20vw] p-1" |           <Link to="/your-projects"> | ||||||
|               type="password" |  | ||||||
|               placeholder="Password" |  | ||||||
|               onChange={(e) => { |  | ||||||
|                 setPassword(e.target.value); |  | ||||||
|               }} |  | ||||||
|             /> |  | ||||||
|             <Button |             <Button | ||||||
|               text="Login" |               text="Login" | ||||||
|               onClick={(): void => { |               onClick={(): void => { | ||||||
|                 return; |                 return; | ||||||
|               }} |               }} | ||||||
|             /> |             /> | ||||||
|           </form> |           </Link> | ||||||
|         </div> |         </div> | ||||||
|       </div> |       </div> | ||||||
|     </> |     </> | ||||||
|  |  | ||||||
|  | @ -1,7 +1,6 @@ | ||||||
| import BasicWindow from "../../Components/BasicWindow"; | import BasicWindow from "../../Components/BasicWindow"; | ||||||
| import Button from "../../Components/Button"; | import Button from "../../Components/Button"; | ||||||
| import NewTimeReport from "../../Components/TimeReport"; | import NewTimeReport from "../../Components/TimeReport"; | ||||||
| import BackButton from "../../Components/BackButton"; |  | ||||||
| 
 | 
 | ||||||
| function UserEditTimeReportPage(): JSX.Element { | function UserEditTimeReportPage(): JSX.Element { | ||||||
|   const content = ( |   const content = ( | ||||||
|  | @ -19,7 +18,12 @@ function UserEditTimeReportPage(): JSX.Element { | ||||||
|           return; |           return; | ||||||
|         }} |         }} | ||||||
|       /> |       /> | ||||||
|       <BackButton /> |       <Button | ||||||
|  |         text="Back" | ||||||
|  |         onClick={(): void => { | ||||||
|  |           return; | ||||||
|  |         }} | ||||||
|  |       /> | ||||||
|     </> |     </> | ||||||
|   ); |   ); | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -1,8 +1,7 @@ | ||||||
| import BasicWindow from "../../Components/BasicWindow"; | import BasicWindow from "../../Components/BasicWindow"; | ||||||
| import Button from "../../Components/Button"; | import Button from "../../Components/Button"; | ||||||
| import NewTimeReport from "../../Components/TimeReport"; | import NewTimeReport from "../../Components/TimeReport"; | ||||||
| //import { Link } from "react-router-dom";
 | import { Link } from "react-router-dom"; | ||||||
| import BackButton from "../../Components/BackButton"; |  | ||||||
| 
 | 
 | ||||||
| function UserNewTimeReportPage(): JSX.Element { | function UserNewTimeReportPage(): JSX.Element { | ||||||
|   const content = ( |   const content = ( | ||||||
|  | @ -20,7 +19,14 @@ function UserNewTimeReportPage(): JSX.Element { | ||||||
|           return; |           return; | ||||||
|         }} |         }} | ||||||
|       /> |       /> | ||||||
|       <BackButton /> |       <Link to="/project"> | ||||||
|  |         <Button | ||||||
|  |           text="Back" | ||||||
|  |           onClick={(): void => { | ||||||
|  |             return; | ||||||
|  |           }} | ||||||
|  |         /> | ||||||
|  |       </Link> | ||||||
|     </> |     </> | ||||||
|   ); |   ); | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -1,17 +1,15 @@ | ||||||
| import { Link } from "react-router-dom"; | import { Link } from "react-router-dom"; | ||||||
| import BasicWindow from "../../Components/BasicWindow"; | import BasicWindow from "../../Components/BasicWindow"; | ||||||
| import BackButton from "../../Components/BackButton"; | import Button from "../../Components/Button"; | ||||||
| 
 | 
 | ||||||
| function UserProjectPage(): JSX.Element { | function UserProjectPage(): JSX.Element { | ||||||
|   const content = ( |   const content = ( | ||||||
|     <> |     <> | ||||||
|       <h1 className="font-bold text-[30px] mb-[20px]">ProjectNameExample</h1> |       <h1 className="font-bold text-[30px] mb-[20px]">ProjectNameExample</h1> | ||||||
|       <div className="border-4 border-black bg-white flex flex-col items-center justify-center min-h-[65vh] h-fit w-[50vw] rounded-3xl content-center overflow-scroll space-y-[10vh] p-[30px]"> |       <div className="border-4 border-black bg-white flex flex-col items-center justify-center min-h-[65vh] h-fit w-[50vw] rounded-3xl content-center overflow-scroll space-y-[10vh] p-[30px]"> | ||||||
|         <Link to="/project-page"> |         <h1 className="font-bold underline text-[30px] cursor-pointer"> | ||||||
|           <h1 className="font-bold underline text-[30px] cursor-pointer"> |           Your Time Reports | ||||||
|             Your Time Reports |         </h1> | ||||||
|           </h1> |  | ||||||
|         </Link> |  | ||||||
|         <Link to="/new-time-report"> |         <Link to="/new-time-report"> | ||||||
|           <h1 className="font-bold underline text-[30px] cursor-pointer"> |           <h1 className="font-bold underline text-[30px] cursor-pointer"> | ||||||
|             New Time Report |             New Time Report | ||||||
|  | @ -23,7 +21,14 @@ function UserProjectPage(): JSX.Element { | ||||||
| 
 | 
 | ||||||
|   const buttons = ( |   const buttons = ( | ||||||
|     <> |     <> | ||||||
|       <BackButton /> |       <Link to="/your-projects"> | ||||||
|  |         <Button | ||||||
|  |           text="Back" | ||||||
|  |           onClick={(): void => { | ||||||
|  |             return; | ||||||
|  |           }} | ||||||
|  |         /> | ||||||
|  |       </Link> | ||||||
|     </> |     </> | ||||||
|   ); |   ); | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -1,17 +1,17 @@ | ||||||
| import BasicWindow from "../../Components/BasicWindow"; | import BasicWindow from "../../Components/BasicWindow"; | ||||||
| import BackButton from "../../Components/BackButton"; | import Button from "../../Components/Button"; | ||||||
| 
 | 
 | ||||||
| function UserViewTimeReportsPage(): JSX.Element { | function UserViewTimeReportsPage(): JSX.Element { | ||||||
|   const content = ( |   const content = <></>; | ||||||
|     <> |  | ||||||
|       <h1 className="font-bold text-[30px] mb-[20px]">Your Time Reports</h1> |  | ||||||
|       {/* Här kan du inkludera logiken för att visa användarens tidrapporter */} |  | ||||||
|     </> |  | ||||||
|   ); |  | ||||||
| 
 | 
 | ||||||
|   const buttons = ( |   const buttons = ( | ||||||
|     <> |     <> | ||||||
|       <BackButton /> |       <Button | ||||||
|  |         text="Back" | ||||||
|  |         onClick={(): void => { | ||||||
|  |           return; | ||||||
|  |         }} | ||||||
|  |       /> | ||||||
|     </> |     </> | ||||||
|   ); |   ); | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue