Compare commits
	
		
			No commits in common. "3728701d77d13f24b5a334fa20076c1a51581afe" and "5a71f98a9a473e6d6c0059c18b3e93ae034ac097" have entirely different histories.
		
	
	
		
			3728701d77
			...
			5a71f98a9a
		
	
		
| @ -1,53 +0,0 @@ | ||||
| <!DOCTYPE html> | ||||
| <html lang="en"> | ||||
| <head> | ||||
|     <meta charset="UTF-8"> | ||||
|     <title>Add Fines</title> | ||||
|     <link rel="stylesheet" href="css/nav.css"> | ||||
| </head> | ||||
| <body> | ||||
|     <nav> | ||||
|         <ul> | ||||
|             <li><a href="search.html" class="btn">Search</a></li> | ||||
|             <li><a href="addVehicle.html" class="btn">Add new vehicle</a></li> | ||||
|             <li><a href="newReport.html" class="btn">Create new report</a></li> | ||||
|             <li class="admin"><a href="newUser.html" class="btn">Create new user</a></li> | ||||
|             <li class="admin"><a href="addFine.html" class="btn active">Add Fines</a></li> | ||||
|             <li class="admin"><a href="viewLog.html" class="btn">View log</a></li> | ||||
|             <li><a href="changePassword.html" class="btn">Change password</a></li> | ||||
|             <li><a id="logout" class="btn">Logout</a></li> | ||||
|         </ul> | ||||
|     </nav> | ||||
| 
 | ||||
|     <main> | ||||
|         <header id="title"> | ||||
|             <h1></h1> | ||||
|         </header> | ||||
| 
 | ||||
|         <form method="POST" id="addFineForm"> | ||||
|             <div class="formControl"> | ||||
|                 <label for="amount">Amount in £</label> | ||||
|                 <input type="number" name="amount" id="amount" required> | ||||
|             </div> | ||||
| 
 | ||||
|             <div class="formControl"> | ||||
|                 <label for="points">Points</label> | ||||
|                 <input type="number" name="points" id="points" required> | ||||
|             </div> | ||||
| 
 | ||||
|             <div class="formControl"><label for="incident">Incident</label> | ||||
|                 <div class="selectDiv"> | ||||
|                     <select id="incident" name="incident" required> | ||||
| 
 | ||||
|                     </select> | ||||
|                 </div> | ||||
|             </div> | ||||
| 
 | ||||
|             <input type="submit" value="Add Fines" class="btn btnPrimary" style="margin-top: 1em;"> | ||||
|         </form> | ||||
|     </main> | ||||
| 
 | ||||
|     <script src="js/checkUser.js"></script> | ||||
|     <script src="js/addFine.js"></script> | ||||
| </body> | ||||
| </html> | ||||
| @ -1,30 +0,0 @@ | ||||
| <?php | ||||
| session_start(); | ||||
| require_once 'config.php'; | ||||
| header('Content-Type: application/json'); | ||||
| 
 | ||||
| if (isset($_SESSION["username"]) && isset($_SESSION["admin"])) | ||||
| { | ||||
|     $conn = dbConn(); | ||||
|     $amount = $_POST["amount"]; | ||||
|     $points = $_POST["points"]; | ||||
|     $incident = $_POST["incident"]; | ||||
| 
 | ||||
|     $stmt = $conn->prepare("INSERT INTO Fines (Fine_amount, Fine_points, Incident_ID) VALUES (:amount, :points, :incident)"); | ||||
|     $stmt->bindParam(":amount", $amount); | ||||
|     $stmt->bindParam(":points", $points); | ||||
|     $stmt->bindParam(":incident", $incident); | ||||
|     $stmt->execute(); | ||||
| 
 | ||||
|     echo json_encode(array("message" => "ok")); | ||||
| } | ||||
| else if (isset($_SESSION["username"]) && !isset($_SESSION["admin"])) | ||||
| { | ||||
|     echo json_encode(array("message" => "not logged in as admin")); | ||||
| } | ||||
| else | ||||
| { | ||||
|     echo json_encode(array("message" => "Not logged in ")); | ||||
| } | ||||
| { | ||||
| } | ||||
| @ -0,0 +1,10 @@ | ||||
| <!DOCTYPE html> | ||||
| <html lang="en"> | ||||
| <head> | ||||
|     <meta charset="UTF-8"> | ||||
|     <title>Title</title> | ||||
| </head> | ||||
| <body> | ||||
| 
 | ||||
| </body> | ||||
| </html> | ||||
| @ -3,19 +3,19 @@ | ||||
| <head> | ||||
|     <meta charset="UTF-8"> | ||||
|     <title>Change Password</title> | ||||
|     <link rel="stylesheet" href="css/nav.css"> | ||||
|     <link rel="stylesheet" href="css/changePassword.css"> | ||||
| </head> | ||||
| <body> | ||||
|     <nav> | ||||
|         <ul> | ||||
|             <li><a href="search.html" class="btn">Search</a></li> | ||||
|             <li><a href="addVehicle.html" class="btn">Add new vehicle</a></li> | ||||
|             <li><a href="newVehicle.html" class="btn">Add new vehicle</a></li> | ||||
|             <li><a href="newReport.html" class="btn">Create new report</a></li> | ||||
|             <li class="admin"><a href="newUser.html" class="btn">Create new user</a></li> | ||||
|             <li class="admin"><a href="addFine.html" class="btn">Add Fines</a></li> | ||||
|             <li class="admin"><a href="viewLog.html" class="btn">View log</a></li> | ||||
|             <li><a href="newUser.html" class="btn">Create new user</a></li> | ||||
|             <li><a href="addFines.html" class="btn">Add fines</a></li> | ||||
|             <li><a href="viewLog.html" class="btn">View log</a></li> | ||||
|             <li><a href="changePassword.html" class="btn active">Change password</a></li> | ||||
|             <li><a id="logout" class="btn">Logout</a></li> | ||||
|             <li><a href="#" class="btn">Logout</a></li> | ||||
|         </ul> | ||||
|     </nav> | ||||
| 
 | ||||
|  | ||||
| @ -0,0 +1,18 @@ | ||||
| @import "nav.css"; | ||||
| 
 | ||||
| main { | ||||
|     padding-top: 2.5em; | ||||
|     display: flex; | ||||
|     flex-direction: column; | ||||
|     justify-content: center; | ||||
|     align-items: center; | ||||
| } | ||||
| 
 | ||||
| main form { | ||||
|     width: 15%; | ||||
|     display: flex; | ||||
|     flex-direction: column; | ||||
|     justify-content: center; | ||||
|     align-items: flex-start; | ||||
|     gap: 1em; | ||||
| } | ||||
| @ -24,7 +24,6 @@ div.login { | ||||
| } | ||||
| 
 | ||||
| form.loginForm { | ||||
|     width: 100%; | ||||
|     display: flex; | ||||
|     flex-direction: column; | ||||
|     justify-content: center; | ||||
|  | ||||
| @ -37,7 +37,3 @@ nav ul li a:hover { | ||||
| nav ul li a.active { | ||||
|     background-color: var(--hover); | ||||
| } | ||||
| 
 | ||||
| nav ul li.admin { | ||||
|     display: none; | ||||
| } | ||||
| @ -1,5 +1,13 @@ | ||||
| @import "nav.css"; | ||||
| 
 | ||||
| main { | ||||
|     padding-top: 2.5em; | ||||
|     display: flex; | ||||
|     flex-direction: column; | ||||
|     justify-content: center; | ||||
|     align-items: center; | ||||
| } | ||||
| 
 | ||||
| main .formGroup { | ||||
|     width: 30%; | ||||
|     display: flex; | ||||
| @ -12,7 +20,11 @@ main .formGroup { | ||||
| 
 | ||||
| main form { | ||||
|     width: 100%; | ||||
|     display: flex; | ||||
|     flex-direction: column; | ||||
|     justify-content: center; | ||||
|     align-items: center; | ||||
|     gap: 1em; | ||||
|     flex: 1; | ||||
| } | ||||
| 
 | ||||
|  | ||||
| @ -1,5 +1,13 @@ | ||||
| @import "nav.css"; | ||||
| 
 | ||||
| main { | ||||
|     padding-top: 2.5em; | ||||
|     display: flex; | ||||
|     flex-direction: column; | ||||
|     justify-content: center; | ||||
|     align-items: center; | ||||
| } | ||||
| 
 | ||||
| div.searchContainer { | ||||
|     display: flex; | ||||
|     flex-direction: column; | ||||
| @ -10,8 +18,11 @@ div.searchContainer { | ||||
| 
 | ||||
| main form { | ||||
|     width: 100%; | ||||
|     display: flex; | ||||
|     flex-direction: row; | ||||
|     justify-content: center; | ||||
|     align-items: center; | ||||
|     gap: 1em; | ||||
| } | ||||
| 
 | ||||
| main#search form input:not([type="submit"]) { | ||||
|  | ||||
| @ -7,7 +7,7 @@ | ||||
|     --secondary: hsl(210, 100%, 95%, 1); | ||||
|     --accent: hsla(15, 99%, 57%, 1); | ||||
|     --light: hsla(90, 8%, 85%, 1); | ||||
|     --mutedBlack: hsla(0, 0%, 0%, 0.25); | ||||
|     --mutedBlack: hsla(0, 0%, 0%, 0.25) | ||||
| } | ||||
| 
 | ||||
| * { | ||||
| @ -74,68 +74,6 @@ input:not([type="submit"]):hover, form .formControl textarea:hover { | ||||
|     border: 4px solid var(--hover); | ||||
| } | ||||
| 
 | ||||
| .checkContainer { | ||||
|     display: block; | ||||
|     position: relative; | ||||
|     margin-bottom: 0.75em; | ||||
|     cursor: pointer; | ||||
|     -webkit-user-select: none; | ||||
|     -moz-user-select: none; | ||||
|     -ms-user-select: none; | ||||
|     user-select: none; | ||||
| } | ||||
| 
 | ||||
| .checkContainer input[type="checkbox"] { | ||||
|     position: absolute; | ||||
|     opacity: 0; | ||||
|     cursor: pointer; | ||||
|     height: 0; | ||||
|     width: 0; | ||||
| } | ||||
| 
 | ||||
| .checkmark { | ||||
|     position: absolute; | ||||
|     top: 1.25em; | ||||
|     left: 0; | ||||
|     height: 1.5em; | ||||
|     width: 1.5em; | ||||
|     background-color: #eee; | ||||
| } | ||||
| 
 | ||||
| .checkContainer:hover input ~ .checkmark { | ||||
|     background-color: #ccc; | ||||
| } | ||||
| 
 | ||||
| .checkContainer input:checked ~ .checkmark { | ||||
|     background-color: var(--primary); | ||||
| } | ||||
| 
 | ||||
| .checkContainer:hover input:checked ~ .checkmark { | ||||
|     background-color: var(--hover); | ||||
| } | ||||
| 
 | ||||
| .checkmark:after { | ||||
|     content: ""; | ||||
|     position: absolute; | ||||
|     display: none; | ||||
| } | ||||
| 
 | ||||
| .checkContainer input:checked ~ .checkmark:after { | ||||
|     display: block; | ||||
| } | ||||
| 
 | ||||
| .checkContainer .checkmark:after { | ||||
|     left: 9px; | ||||
|     top: 5px; | ||||
|     width: 0.35em; | ||||
|     height: 0.6em; | ||||
|     border: solid white; | ||||
|     border-width: 0 3px 3px 0; | ||||
|     -webkit-transform: rotate(45deg); | ||||
|     -ms-transform: rotate(45deg); | ||||
|     transform: rotate(45deg); | ||||
| } | ||||
| 
 | ||||
| .selectDiv { | ||||
|     position: relative; | ||||
|     min-width: 300px; | ||||
| @ -226,24 +164,6 @@ table th { | ||||
|     color: #FFFFFF; | ||||
| } | ||||
| 
 | ||||
| main { | ||||
|     padding-top: 2.5em; | ||||
|     display: flex; | ||||
|     flex-direction: column; | ||||
|     justify-content: center; | ||||
|     align-items: center; | ||||
| } | ||||
| 
 | ||||
| main form { | ||||
|     width: 15%; | ||||
|     display: flex; | ||||
|     flex-direction: column; | ||||
|     justify-content: center; | ||||
|     align-items: flex-start; | ||||
|     gap: 1em; | ||||
| } | ||||
| 
 | ||||
| main #title { | ||||
|     align-self: flex-start; | ||||
|     margin-left: 1em; | ||||
| } | ||||
|  | ||||
| @ -1,21 +0,0 @@ | ||||
| <?php | ||||
| session_start(); | ||||
| require_once 'config.php'; | ||||
| header('Content-Type: application/json'); | ||||
| 
 | ||||
| if (isset($_SESSION["username"]) && isset($_SESSION["admin"])) | ||||
| { | ||||
|     $conn = dbConn(); | ||||
|     $stmt = $conn->prepare("SELECT * FROM Incident"); | ||||
|     $stmt->execute(); | ||||
|     $result = $stmt->fetchAll(PDO::FETCH_ASSOC); | ||||
|     echo json_encode(array("message" => "ok", "incidents" => $result)); | ||||
| } | ||||
| else if (isset($_SESSION["username"]) && !isset($_SESSION["admin"])) | ||||
| { | ||||
|     echo json_encode(array("message" => "not logged in as admin")); | ||||
| } | ||||
| else | ||||
| { | ||||
|     echo json_encode(array("message" => "Not logged in ")); | ||||
| } | ||||
| @ -6,7 +6,7 @@ header('Content-Type: application/json'); | ||||
| if (isset($_SESSION["username"])) | ||||
| { | ||||
|     $conn = dbConn(); | ||||
|     $stmt = $conn->prepare("SELECT People_ID, People_name, People_licence FROM People"); | ||||
|     $stmt = $conn->prepare("SELECT People_ID, People_name FROM People"); | ||||
|     $stmt->execute(); | ||||
|     $result = $stmt->fetchAll(PDO::FETCH_ASSOC); | ||||
|     echo json_encode(array("message" => "ok", "owners" => $result)); | ||||
|  | ||||
| @ -1,11 +0,0 @@ | ||||
| <?php | ||||
| session_start(); | ||||
| header('Content-Type: application/json'); | ||||
| if ($_SESSION["admin"]) | ||||
| { | ||||
|     echo json_encode(array("message" => "ok", "admin" => $_SESSION["admin"])); | ||||
| } | ||||
| else | ||||
| { | ||||
|     echo json_encode(array("message" => "not logged in as admin")); | ||||
| } | ||||
| @ -3,7 +3,7 @@ session_start(); | ||||
| header('Content-Type: application/json'); | ||||
| if (isset($_SESSION["username"])) | ||||
| { | ||||
|     echo json_encode(array("message" => "ok", "username" => $_SESSION["username"], "admin" => $_SESSION["admin"])); | ||||
|     echo json_encode(array("message" => "ok")); | ||||
| } | ||||
| else | ||||
| { | ||||
|  | ||||
| @ -1,41 +0,0 @@ | ||||
| 
 | ||||
| document.addEventListener("DOMContentLoaded", () => | ||||
| { | ||||
|     fetch("getIncidents.php").then(res => res.json().then(json => | ||||
|     { | ||||
|         if(json.message === "ok") | ||||
|         { | ||||
|             let body = ""; | ||||
|             for (const incident of json.incidents) | ||||
|             { | ||||
|                 body += `<option value="${incident.Incident_ID}">${incident.Incident_Report} — ${incident.Incident_Date}</option>`; | ||||
|             } | ||||
|             document.querySelector("#incident").innerHTML = body; | ||||
|         } | ||||
|     })); | ||||
| 
 | ||||
| }); | ||||
| 
 | ||||
| document.querySelector("#addFineForm").addEventListener("submit", e => | ||||
| { | ||||
|     e.preventDefault(); | ||||
|     let formData = new FormData(); | ||||
|     formData.append("amount", document.querySelector("#amount").value); | ||||
|     formData.append("points", document.querySelector("#points").value); | ||||
|     formData.append("incident", document.querySelector("#incident").value) | ||||
| 
 | ||||
|     fetch("addFine.php", { | ||||
|         method: "POST", | ||||
|         body: formData | ||||
|     }).then(res => res.json().then(json => { | ||||
|         if(json.message === "ok") | ||||
|         { | ||||
|             alert("Fine added successfully"); | ||||
|         } | ||||
|         else | ||||
|         { | ||||
|             alert("Error adding fine"); | ||||
|         } | ||||
| 
 | ||||
|     })); | ||||
| }); | ||||
| @ -1,35 +1,15 @@ | ||||
| document.addEventListener("DOMContentLoaded", () => | ||||
| { | ||||
|    fetch("isLoggedIn.php").then(res => res.json().then(json => | ||||
|    { | ||||
|        if (json.message !== "ok") | ||||
|        { | ||||
|            window.location.href = "./"; | ||||
|        } | ||||
|        else | ||||
|        { | ||||
|            document.querySelector("#title h1").innerText = "Logged in as: " + json.username; | ||||
|            let adminLinks = document.querySelectorAll(".admin"); | ||||
|            for (let adminLink of adminLinks) | ||||
|            { | ||||
|                if (json.admin === true) | ||||
|                { | ||||
|                    adminLink.style.display = "block"; | ||||
|                } | ||||
|            } | ||||
| // document.addEventListener("DOMContentLoaded", () =>
 | ||||
| // {
 | ||||
| //    fetch("isLoggedIn.php").then(res => res.json().then(json =>
 | ||||
| //    {
 | ||||
| //        if (json.message !== "ok")
 | ||||
| //        {
 | ||||
| //            window.location.href = "index.html";
 | ||||
| //        }
 | ||||
| //        else
 | ||||
| //        {
 | ||||
| //            document.querySelector("#title h1").innerText = "Logged in as: " + json.username;
 | ||||
| //        }
 | ||||
| //    }));
 | ||||
| // });
 | ||||
| 
 | ||||
|        } | ||||
|    })); | ||||
| }); | ||||
| 
 | ||||
| document.querySelector("#logout").addEventListener("click", e => | ||||
| { | ||||
|     e.preventDefault(); | ||||
|     fetch("logout.php").then(res => res.json().then(json => | ||||
|     { | ||||
|         if (json.message === "ok") | ||||
|         { | ||||
|            window.location.href = "./"; | ||||
|         } | ||||
|     })); | ||||
| }); | ||||
| @ -1,16 +1,5 @@ | ||||
| // Login stuff
 | ||||
| 
 | ||||
| document.addEventListener("DOMContentLoaded", () => | ||||
| { | ||||
|     fetch("isLoggedIn.php").then(res => res.json().then(json => | ||||
|     { | ||||
|             if (json.message === "ok") | ||||
|         { | ||||
|             window.location.href = "./search.html"; | ||||
|         } | ||||
|     })); | ||||
| }); | ||||
| 
 | ||||
| document.querySelector("#login").addEventListener("submit", e => | ||||
| { | ||||
|     e.preventDefault(); | ||||
|  | ||||
| @ -1,51 +0,0 @@ | ||||
| // create new a user stuff
 | ||||
| 
 | ||||
| document.addEventListener("DOMContentLoaded", () => | ||||
| { | ||||
|     fetch("isAdmin.php").then(res => res.json().then(json => | ||||
|     { | ||||
|         if (json.message !== "ok") | ||||
|         { | ||||
|             window.location.href = "./search.html"; | ||||
|         } | ||||
|     })); | ||||
| }); | ||||
| 
 | ||||
| document.querySelector("#createUser").addEventListener("submit", e => | ||||
| { | ||||
|     e.preventDefault(); | ||||
|     let username = document.querySelector("#username").value; | ||||
|     let password = document.querySelector("#pass").value; | ||||
|     let rePass = document.querySelector("#rePass").value; | ||||
|     let admin = document.querySelector("#isAdmin").checked; | ||||
|     if (password === "" || rePass === "" || username === "") | ||||
|     { | ||||
|         alert("Please fill in all fields"); | ||||
|     } | ||||
|     else if (password !== rePass) | ||||
|     { | ||||
|         alert("Passwords do not match"); | ||||
|     } | ||||
|     else | ||||
|     { | ||||
|         let data = new FormData(); | ||||
|         data.append("username", username); | ||||
|         data.append("password", password); | ||||
|         data.append("admin", admin); | ||||
| 
 | ||||
|         fetch("newUser.php", { | ||||
|             method: "POST", | ||||
|             body: data | ||||
|         }).then(res => res.json().then(json => | ||||
|         { | ||||
|             if (json.message === "ok") | ||||
|             { | ||||
|                 alert("User created"); | ||||
|             } | ||||
|             else | ||||
|             { | ||||
|                 alert("Error creating user"); | ||||
|             } | ||||
|         })); | ||||
|     } | ||||
| }); | ||||
| @ -8,7 +8,7 @@ document.addEventListener("DOMContentLoaded", () => | ||||
|             let body = ""; | ||||
|             for (const owner of json.owners) | ||||
|             { | ||||
|                 body += `<option value="${owner.People_ID}">${owner.People_name} - ${owner.People_licence}</option>`; | ||||
|                 body += `<option value="${owner.People_ID}">${owner.People_name}</option>`; | ||||
|             } | ||||
|             body += `<option value="new">New Owner</option>`; | ||||
|             document.querySelector("#owner").innerHTML = body; | ||||
|  | ||||
| @ -28,25 +28,23 @@ document.querySelector("#searchForm").addEventListener("submit", e => | ||||
|         { | ||||
|             document.querySelector("#searchResults thead tr").innerHTML = ""; | ||||
|             document.querySelector("#searchResults tbody").innerHTML = ""; | ||||
| 
 | ||||
|             for (const key of Object.keys(json.data[0])) | ||||
|             console.log(Object.keys(json.data[0])); | ||||
|             Object.keys(json.data[0]).forEach(key => | ||||
|             { | ||||
|                 let header = key.substring(key.indexOf("_") + 1) | ||||
|                 header = header.charAt(0).toUpperCase() + header.slice(1); | ||||
|                 document.querySelector("#searchResults thead tr").innerHTML += `<th>${header}</th>`; | ||||
|             } | ||||
| 
 | ||||
|             }); | ||||
|             let body = ""; | ||||
|             for (const row of json.data) | ||||
|             json.data.forEach(row => | ||||
|             { | ||||
|                 body += "<tr>"; | ||||
|                 for (const key of Object.keys(row)) | ||||
|                 Object.keys(row).forEach(key => | ||||
|                 { | ||||
|                     body += `<td>${(row[key] === "null" || row[key] === null) ? "N/A" : row[key]}</td>`; | ||||
|                 } | ||||
|                 }); | ||||
|                 body += "</tr>"; | ||||
|             } | ||||
| 
 | ||||
|             }); | ||||
|             document.querySelector("#searchResults tbody").innerHTML = body; | ||||
| 
 | ||||
|         } | ||||
|  | ||||
| @ -11,12 +11,10 @@ $stmt = $conn->prepare("SELECT * FROM Users WHERE Users_username = :username AND | ||||
| $stmt->bindParam(":username", $username); | ||||
| $stmt->bindParam(":password", $password); | ||||
| $stmt->execute(); | ||||
| $result = $stmt->fetchAll(PDO::FETCH_ASSOC); | ||||
| 
 | ||||
| if (count($result) > 0) | ||||
| if (count($stmt->fetchAll(PDO::FETCH_ASSOC)) > 0) | ||||
| { | ||||
|     $_SESSION["username"] = $username; | ||||
|     $_SESSION["admin"] = $result[0]["Users_admin"] === "1"; | ||||
|     echo json_encode(array("message" => "ok")); | ||||
| } | ||||
| else | ||||
|  | ||||
| @ -1,4 +0,0 @@ | ||||
| <?php | ||||
| session_start(); | ||||
| session_destroy(); | ||||
| echo json_encode(array("message" => "ok")); | ||||
| @ -2,56 +2,9 @@ | ||||
| <html lang="en"> | ||||
| <head> | ||||
|     <meta charset="UTF-8"> | ||||
|     <title>Create New User</title> | ||||
|     <link rel="stylesheet" href="css/nav.css"> | ||||
|     <title>Title</title> | ||||
| </head> | ||||
| <body> | ||||
|     <nav> | ||||
|         <ul> | ||||
|             <li><a href="search.html" class="btn">Search</a></li> | ||||
|             <li><a href="addVehicle.html" class="btn">Add new vehicle</a></li> | ||||
|             <li><a href="newReport.html" class="btn">Create new report</a></li> | ||||
|             <li class="admin"><a href="newUser.html" class="btn active">Create new user</a></li> | ||||
|             <li class="admin"><a href="addFine.html" class="btn">Add Fines</a></li> | ||||
|             <li class="admin"><a href="viewLog.html" class="btn">View log</a></li> | ||||
|             <li><a href="changePassword.html" class="btn">Change password</a></li> | ||||
|             <li><a id="logout" class="btn">Logout</a></li> | ||||
|         </ul> | ||||
|     </nav> | ||||
| 
 | ||||
|     <main> | ||||
|         <header id="title"> | ||||
|             <h1></h1> | ||||
|         </header> | ||||
| 
 | ||||
|         <form method="POST" id="createUser"> | ||||
|             <div class="formControl"> | ||||
|                 <label for="username">Username</label> | ||||
|                 <input type="text" name="username" id="username"> | ||||
|             </div> | ||||
| 
 | ||||
|             <div class="formControl"> | ||||
|                 <label for="pass">Password</label> | ||||
|                 <input type="password" name="pass" id="pass"> | ||||
|             </div> | ||||
| 
 | ||||
|             <div class="formControl"> | ||||
|                 <label for="rePass">Retype Password</label> | ||||
|                 <input type="password" name="rePass" id="rePass"> | ||||
|             </div> | ||||
| 
 | ||||
|             <div class="formControl"> | ||||
|                 <label for="isAdmin" class="checkContainer">Is Admin | ||||
|                     <input type="checkbox" name="isAdmin" id="isAdmin"> | ||||
|                     <span class="checkmark"></span> | ||||
|                 </label> | ||||
|             </div> | ||||
| 
 | ||||
|             <input type="submit" value="Create New User" class="btn btnPrimary" style="margin-top: 1em;"> | ||||
|         </form> | ||||
|     </main> | ||||
| 
 | ||||
|     <script src="js/checkUser.js"></script> | ||||
|     <script src="js/newUser.js"></script> | ||||
| </body> | ||||
| </html> | ||||
| @ -1,29 +0,0 @@ | ||||
| <?php | ||||
| session_start(); | ||||
| require_once 'config.php'; | ||||
| header('Content-Type: application/json'); | ||||
| 
 | ||||
| if (isset($_SESSION["username"]) && isset($_SESSION["admin"])) | ||||
| { | ||||
|     $username = $_POST["username"]; | ||||
|     $password = $_POST["password"]; | ||||
|     $admin = $_POST["admin"]; | ||||
| 
 | ||||
|     $conn = dbConn(); | ||||
|     $stmt = $conn->prepare("INSERT INTO Users (Users_username, Users_password, Users_admin) VALUES (:username, :password, :admin)"); | ||||
|     $stmt->bindParam(":username", $username); | ||||
|     $stmt->bindParam(":password", $password); | ||||
|     $isAdmin = $admin ? 1 : 0; | ||||
|     $stmt->bindParam(":admin", $isAdmin); | ||||
|     $stmt->execute(); | ||||
| 
 | ||||
|     echo json_encode(array("message" => "ok", "admin" => $admin)); | ||||
| } | ||||
| else if (isset($_SESSION["username"]) && !isset($_SESSION["admin"])) | ||||
| { | ||||
|     echo json_encode(array("message" => "not logged in as admin")); | ||||
| } | ||||
| else | ||||
| { | ||||
|     echo json_encode(array("message" => "Not logged in ")); | ||||
| } | ||||
| @ -9,13 +9,13 @@ | ||||
|     <nav> | ||||
|         <ul> | ||||
|             <li><a href="search.html" class="btn">Search</a></li> | ||||
|             <li><a href="addVehicle.html" class="btn active">Add new vehicle</a></li> | ||||
|             <li><a href="newVehicle.html" class="btn active">Add new vehicle</a></li> | ||||
|             <li><a href="newReport.html" class="btn">Create new report</a></li> | ||||
|             <li class="admin"><a href="newUser.html" class="btn">Create new user</a></li> | ||||
|             <li class="admin"><a href="addFine.html" class="btn">Add Fines</a></li> | ||||
|             <li class="admin"><a href="viewLog.html" class="btn">View log</a></li> | ||||
|             <li><a href="newUser.html" class="btn">Create new user</a></li> | ||||
|             <li><a href="addFines.html" class="btn">Add fines</a></li> | ||||
|             <li><a href="viewLog.html" class="btn">View log</a></li> | ||||
|             <li><a href="changePassword.html" class="btn">Change password</a></li> | ||||
|             <li><a id="logout" class="btn">Logout</a></li> | ||||
|             <li><a href="#" class="btn">Logout</a></li> | ||||
|         </ul> | ||||
|     </nav> | ||||
| 
 | ||||
| @ -58,7 +58,7 @@ | ||||
|                 <div class="formSpace" id="addOwner"> | ||||
|                     <div class="formControl"> | ||||
|                         <label for="name">Name</label> | ||||
|                         <input type="text" name="name" id="name"    > | ||||
|                         <input type="text" name="name" id="name"> | ||||
|                     </div> | ||||
|                     <div class="formControl"> | ||||
|                         <label for="address">Address</label> | ||||
| @ -74,7 +74,6 @@ | ||||
|         </form> | ||||
|     </main> | ||||
| 
 | ||||
|     <script src="js/checkUser.js"></script> | ||||
|     <script src="js/newVehicle.js"></script> | ||||
| </body> | ||||
| </html> | ||||
| @ -0,0 +1,81 @@ | ||||
| <!DOCTYPE html> | ||||
| <html lang="en"> | ||||
| <head> | ||||
|     <meta charset="UTF-8"> | ||||
|     <title>Add New Vehicle</title> | ||||
|     <link rel="stylesheet" href="css/newVehicle.css"> | ||||
| </head> | ||||
| <body> | ||||
|     <nav> | ||||
|         <ul> | ||||
|             <li><a href="search.html" class="btn">Search</a></li> | ||||
|             <li><a href="newVehicle.html" class="btn active">Add new vehicle</a></li> | ||||
|             <li><a href="newReport.html" class="btn">Create new report</a></li> | ||||
|             <li><a href="newUser.html" class="btn">Create new user</a></li> | ||||
|             <li><a href="addFines.html" class="btn">Add fines</a></li> | ||||
|             <li><a href="viewLog.html" class="btn">View log</a></li> | ||||
|             <li><a href="changePassword.html" class="btn">Change password</a></li> | ||||
|             <li><a href="#" class="btn">Logout</a></li> | ||||
|         </ul> | ||||
|     </nav> | ||||
| 
 | ||||
|     <main> | ||||
|         <header id="title"> | ||||
|             <h1></h1> | ||||
|         </header> | ||||
| 
 | ||||
|         <div class="formGroup"> | ||||
|             <form method="post" id="vehicleForm"> | ||||
|                 <div class="formControl"> | ||||
|                     <label for="plateNum">Plate Number</label> | ||||
|                     <input type="text" name="plateNum" id="plateNum"> | ||||
|                 </div> | ||||
| 
 | ||||
|                 <div class="formControl"> | ||||
|                     <label for="make">Make</label> | ||||
|                     <input type="text" name="make" id="make"> | ||||
|                 </div> | ||||
| 
 | ||||
|                 <div class="formControl"> | ||||
|                     <label for="model">Model</label> | ||||
|                     <input type="text" name="model" id="model"> | ||||
|                 </div> | ||||
| 
 | ||||
|                 <div class="formControl"> | ||||
|                     <label for="owner">Owner</label> | ||||
|                     <div class="selectDiv"> | ||||
|                         <select name="owner" id="owner"> | ||||
|                             <option value="james-smith">James Smith</option> | ||||
|                         </select> | ||||
|                     </div> | ||||
|                 </div> | ||||
| 
 | ||||
|                 <input type="submit" value="Add new vehicle" class="btn btnPrimary"> | ||||
|             </form> | ||||
| 
 | ||||
|             <form method="post" id="ownerForm"> | ||||
|                 <div class="formSpace"> | ||||
|                     <div class="formControl"> | ||||
|                         <label for="name">Name</label> | ||||
|                         <input type="text" name="name" id="name"> | ||||
|                     </div> | ||||
|                     <div class="formControl"> | ||||
|                         <label for="address">Address</label> | ||||
|                         <input type="text" name="address" id="address"> | ||||
|                     </div> | ||||
|                     <div class="formControl"> | ||||
|                         <label for="licence">Licence number</label> | ||||
|                         <input type="text" name="licence" id="licence"> | ||||
|                     </div> | ||||
|                 </div> | ||||
| 
 | ||||
|                 <div class="formSpace"> | ||||
|                     <input type="submit" value="Add new Owner" class="btn btnPrimary"> | ||||
|                 </div> | ||||
|             </form> | ||||
|         </div> | ||||
|     </main> | ||||
| 
 | ||||
|     <script src=""></script> | ||||
| </body> | ||||
| </html> | ||||
| @ -7,18 +7,18 @@ | ||||
|     <script src="https://kit.fontawesome.com/ed3c25598e.js" crossorigin="anonymous"></script> | ||||
| </head> | ||||
| <body> | ||||
|     <nav> | ||||
| <nav> | ||||
|     <ul> | ||||
|         <li><a href="search.html" class="btn active">Search</a></li> | ||||
|             <li><a href="addVehicle.html" class="btn">Add new vehicle</a></li> | ||||
|         <li><a href="newVehicle.html" class="btn">Add new vehicle</a></li> | ||||
|         <li><a href="newReport.html" class="btn">Create new report</a></li> | ||||
|             <li class="admin"><a href="newUser.html" class="btn">Create new user</a></li> | ||||
|             <li class="admin"><a href="addFine.html" class="btn">Add Fines</a></li> | ||||
|             <li class="admin"><a href="viewLog.html" class="btn">View log</a></li> | ||||
|         <li><a href="newUser.html" class="btn">Create new user</a></li> | ||||
|         <li><a href="addFines.html" class="btn">Add Fines</a></li> | ||||
|         <li><a href="viewLog.html" class="btn">View log</a></li> | ||||
|         <li><a href="changePassword.html" class="btn">Change password</a></li> | ||||
|             <li><a id="logout" class="btn">Logout</a></li> | ||||
|         <li><a href="#" class="btn">Logout</a></li> | ||||
|     </ul> | ||||
|     </nav> | ||||
| </nav> | ||||
|     <main id="search"> | ||||
|         <header id="title"> | ||||
|             <h1></h1> | ||||
| @ -34,7 +34,7 @@ | ||||
|                 </div> | ||||
| 
 | ||||
|                 <div class="searchBtnContainer"> | ||||
|                     <input type="text" id="searchField" name="searchField" placeholder="Find owner" required> | ||||
|                     <input type="text" id="searchField" name="searchField" placeholder="Find owner"> | ||||
|                     <button type="submit"><i class="fa-solid fa-magnifying-glass"></i></button> | ||||
|                 </div> | ||||
|             </form> | ||||
|  | ||||
		Loading…
	
		Reference in New Issue
	
	Block a user