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
Reference in a new issue