Compare commits
	
		
			2 Commits
		
	
	
		
			17704a52a0
			...
			2fd2f4806d
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| 2fd2f4806d | |||
| 108cf7586d | 
| @ -0,0 +1,52 @@ | |||||||
|  | @import "nav.css"; | ||||||
|  | 
 | ||||||
|  | main .formGroup { | ||||||
|  |     width: 40%; | ||||||
|  |     display: flex; | ||||||
|  |     flex-direction: row; | ||||||
|  |     justify-content: flex-start; | ||||||
|  |     align-items: flex-start; | ||||||
|  |     flex-wrap: wrap; | ||||||
|  |     gap: 2em; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | main form { | ||||||
|  |     width: 100%; | ||||||
|  |     align-items: center; | ||||||
|  |     flex: 1; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | main form .formControl .selectDiv { | ||||||
|  |     width: 100%; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | .formSpace { | ||||||
|  |     width: 100%; | ||||||
|  |     display: flex; | ||||||
|  |     flex-direction: column; | ||||||
|  |     justify-content: flex-start; | ||||||
|  |     align-items: flex-start; | ||||||
|  |     gap: 1em; | ||||||
|  |     flex: 1; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | #addOwner, #addVehicle { | ||||||
|  |     visibility: hidden; | ||||||
|  |     opacity: 0; | ||||||
|  |     -webkit-transition: visibility 0s linear 300ms, opacity 300ms; | ||||||
|  |     -moz-transition: visibility 0s linear 300ms, opacity 300ms; | ||||||
|  |     -ms-transition: visibility 0s linear 300ms, opacity 300ms; | ||||||
|  |     -o-transition: visibility 0s linear 300ms, opacity 300ms; | ||||||
|  |     transition: visibility 0s linear 300ms, opacity 300ms; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | #addOwner.shown, #addVehicle.shown { | ||||||
|  |     visibility: visible; | ||||||
|  |     opacity: 1; | ||||||
|  |     -webkit-transition: visibility 0s linear 0s, opacity 300ms; | ||||||
|  |     -moz-transition: visibility 0s linear 0s, opacity 300ms; | ||||||
|  |     -ms-transition: visibility 0s linear 0s, opacity 300ms; | ||||||
|  |     -o-transition: visibility 0s linear 0s, opacity 300ms; | ||||||
|  |     transition: visibility 0s linear 0s, opacity 300ms; | ||||||
|  | } | ||||||
| @ -0,0 +1,17 @@ | |||||||
|  | <?php | ||||||
|  | session_start(); | ||||||
|  | require_once 'config.php'; | ||||||
|  | header('Content-Type: application/json'); | ||||||
|  | 
 | ||||||
|  | if (isset($_SESSION["username"])) | ||||||
|  | { | ||||||
|  |     $conn = dbConn(); | ||||||
|  |     $stmt = $conn->prepare("SELECT Offence_ID, Offence_description, Offence_maxFine FROM Offence"); | ||||||
|  |     $stmt->execute(); | ||||||
|  |     $result = $stmt->fetchAll(PDO::FETCH_ASSOC); | ||||||
|  |     echo json_encode(array("message" => "ok", "offences" => $result)); | ||||||
|  | } | ||||||
|  | else | ||||||
|  | { | ||||||
|  |     echo json_encode(array("message" => "Not logged in ")); | ||||||
|  | } | ||||||
| @ -0,0 +1,17 @@ | |||||||
|  | <?php | ||||||
|  | session_start(); | ||||||
|  | require_once 'config.php'; | ||||||
|  | header('Content-Type: application/json'); | ||||||
|  | 
 | ||||||
|  | if (isset($_SESSION["username"])) | ||||||
|  | { | ||||||
|  |     $conn = dbConn(); | ||||||
|  |     $stmt = $conn->prepare("SELECT Vehicle_ID, Vehicle_type, Vehicle_licence FROM Vehicle"); | ||||||
|  |     $stmt->execute(); | ||||||
|  |     $result = $stmt->fetchAll(PDO::FETCH_ASSOC); | ||||||
|  |     echo json_encode(array("message" => "ok", "vehicles" => $result)); | ||||||
|  | } | ||||||
|  | else | ||||||
|  | { | ||||||
|  |     echo json_encode(array("message" => "Not logged in ")); | ||||||
|  | } | ||||||
| @ -0,0 +1,136 @@ | |||||||
|  | 
 | ||||||
|  | document.addEventListener("DOMContentLoaded", () => | ||||||
|  | { | ||||||
|  |     fetch("getOwners.php").then(res => res.json().then(json => | ||||||
|  |     { | ||||||
|  |         if(json.message === "ok") | ||||||
|  |         { | ||||||
|  |             let body = ""; | ||||||
|  |             for (const owner of json.owners) | ||||||
|  |             { | ||||||
|  |                 body += `<option value="${owner.People_ID}">${owner.People_name} - ${owner.People_licence}</option>`; | ||||||
|  |             } | ||||||
|  |             body += `<option value="new">New Owner</option>`; | ||||||
|  |             document.querySelector("#owner").innerHTML = body; | ||||||
|  |         } | ||||||
|  |     })); | ||||||
|  | 
 | ||||||
|  |     fetch("getVehicles.php").then(res => res.json().then(json => | ||||||
|  |     { | ||||||
|  |         if (json.message === "ok") | ||||||
|  |         { | ||||||
|  |             let body = ""; | ||||||
|  |             for (const owner of json.vehicles) | ||||||
|  |             { | ||||||
|  |                 body += `<option value="${owner.Vehicle_ID}">${owner.Vehicle_type} - ${owner.Vehicle_licence}</option>`; | ||||||
|  |             } | ||||||
|  |             body += `<option value="new">New Vehicle</option>`; | ||||||
|  |             document.querySelector("#vehicle").innerHTML = body; | ||||||
|  |         } | ||||||
|  |     })); | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  |     fetch("getOffences.php").then(res => res.json().then(json => | ||||||
|  |     { | ||||||
|  |         if (json.message === "ok") | ||||||
|  |         { | ||||||
|  |             let body = ""; | ||||||
|  |             for (const owner of json.offences) | ||||||
|  |             { | ||||||
|  |                 body += `<option value="${owner.Offence_ID}">${owner.Offence_description} - ${owner.Offence_maxFine}</option>`; | ||||||
|  |             } | ||||||
|  |             body += `<option value="new">New Vehicle</option>`; | ||||||
|  |             document.querySelector("#offence").innerHTML = body; | ||||||
|  |         } | ||||||
|  |     })); | ||||||
|  | 
 | ||||||
|  | }); | ||||||
|  | 
 | ||||||
|  | document.querySelector("#owner").addEventListener("change", e => | ||||||
|  | { | ||||||
|  |     let inputs = document.querySelectorAll("#addOwner input"); | ||||||
|  |     if (e.target.value === "new") | ||||||
|  |     { | ||||||
|  |         document.querySelector("#addOwner").classList.add("shown"); | ||||||
|  |         for (const input of inputs) | ||||||
|  |         { | ||||||
|  |             input.setAttribute("required", ""); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |     else | ||||||
|  |     { | ||||||
|  |         document.querySelector("#addOwner").classList.remove("shown"); | ||||||
|  |         for (const input of inputs) | ||||||
|  |         { | ||||||
|  |             input.removeAttribute("required"); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | }); | ||||||
|  | 
 | ||||||
|  | document.querySelector("#vehicle").addEventListener("change", e => | ||||||
|  | { | ||||||
|  |     let inputs = document.querySelectorAll("#addVehicle input"); | ||||||
|  |     if (e.target.value === "new") | ||||||
|  |     { | ||||||
|  |         document.querySelector("#addVehicle").classList.add("shown"); | ||||||
|  |         for (const input of inputs) | ||||||
|  |         { | ||||||
|  |             input.setAttribute("required", ""); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |     else | ||||||
|  |     { | ||||||
|  |         document.querySelector("#addVehicle").classList.remove("shown"); | ||||||
|  |         for (const input of inputs) | ||||||
|  |         { | ||||||
|  |             input.removeAttribute("required"); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | }); | ||||||
|  | 
 | ||||||
|  | document.querySelector("#reports").addEventListener("click", e => | ||||||
|  | { | ||||||
|  |     e.preventDefault(); | ||||||
|  |     let formData = new FormData(); | ||||||
|  |     formData.append("incidentReport", document.querySelector("#incidentReport").value); | ||||||
|  |     formData.append("incidentDate", document.querySelector("#incidentDate").value); | ||||||
|  |     if (document.querySelector("#owner").value === "new") | ||||||
|  |     { | ||||||
|  |         formData.append("name", document.querySelector("#name").value); | ||||||
|  |         formData.append("address", document.querySelector("#address").value); | ||||||
|  |         formData.append("licence", document.querySelector("#licence").value); | ||||||
|  |     } | ||||||
|  |     else | ||||||
|  |     { | ||||||
|  |         formData.append("peopleID", document.querySelector("#owner").value); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     if (document.querySelector("#vehicle").value === "new") | ||||||
|  |     { | ||||||
|  |         formData.append("type", document.querySelector("#type").value); | ||||||
|  |         formData.append("colour", document.querySelector("#colour").value); | ||||||
|  |         formData.append("plateNumber", document.querySelector("#plateNum").value); | ||||||
|  |     } | ||||||
|  |     else | ||||||
|  |     { | ||||||
|  |         formData.append("vehicleID", document.querySelector("#vehicle").value); | ||||||
|  |     } | ||||||
|  |     formData.append("offenceID", document.querySelector("#offence").value); | ||||||
|  | 
 | ||||||
|  |     fetch("newReport.php",{ | ||||||
|  |         method: "POST", | ||||||
|  |         body: formData | ||||||
|  |     }).then(res => res.json().then(json => | ||||||
|  |     { | ||||||
|  |         if (json.message === "ok") | ||||||
|  |         { | ||||||
|  |             alert("Report added"); | ||||||
|  |         } | ||||||
|  |         else | ||||||
|  |         { | ||||||
|  |             alert("Error adding report"); | ||||||
|  |         } | ||||||
|  |     })); | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | }); | ||||||
| @ -1,10 +0,0 @@ | |||||||
| <!DOCTYPE html> |  | ||||||
| <html lang="en"> |  | ||||||
| <head> |  | ||||||
|     <meta charset="UTF-8"> |  | ||||||
|     <title>Title</title> |  | ||||||
| </head> |  | ||||||
| <body> |  | ||||||
| 
 |  | ||||||
| </body> |  | ||||||
| </html> |  | ||||||
| @ -0,0 +1,57 @@ | |||||||
|  | <?php | ||||||
|  | session_start(); | ||||||
|  | require_once 'config.php'; | ||||||
|  | header('Content-Type: application/json'); | ||||||
|  | if (isset($_SESSION["username"])) | ||||||
|  | { | ||||||
|  |     $conn = dbConn(); | ||||||
|  |     $incidentReport = $_POST["incidentReport"]; | ||||||
|  |     $incidentDate = $_POST["incidentDate"]; | ||||||
|  |     $peopleID = $_POST["peopleID"]; | ||||||
|  |     $vehicleID = $_POST["vehicleID"]; | ||||||
|  |     $offenceID = $_POST["offenceID"]; | ||||||
|  | 
 | ||||||
|  |     if (isset($_POST["type"]) && isset($_POST["colour"]) && isset($_POST["plateNum"])) | ||||||
|  |     { | ||||||
|  |         $stmt = $conn->prepare("INSERT INTO Vehicle (Vehicle_type, Vehicle_colour, Vehicle_licence) VALUES (:type, :colour, :plateNum)"); | ||||||
|  |         $stmt->bindParam(":type", $_POST["type"]); | ||||||
|  |         $stmt->bindParam(":colour", $_POST["colour"]); | ||||||
|  |         $stmt->bindParam(":plateNum", $_POST["plateNum"]); | ||||||
|  |         $stmt->execute(); | ||||||
|  |         $vehicleID = $conn->lastInsertId(); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     if (isset($_POST["name"]) && isset($_POST["address"]) && isset($_POST["licence"])) | ||||||
|  |     { | ||||||
|  |         $stmtPeople = $conn->prepare("INSERT INTO People (People_name, People_address, People_licence) VALUES (:name, :address, :licence)"); | ||||||
|  |         $stmtPeople->bindParam(":name", $_POST["name"]); | ||||||
|  |         $stmtPeople->bindParam(":address", $_POST["address"]); | ||||||
|  |         $stmtPeople->bindParam(":licence", $_POST["licence"]); | ||||||
|  |         $stmtPeople->execute(); | ||||||
|  |         $peopleID = $conn->lastInsertId(); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     $stmtOwner = $conn->prepare("INSERT INTO Ownership (Vehicle_ID, People_ID) VALUES (:vehicleID, :peopleID)"); | ||||||
|  |     $stmtOwner->bindParam(":vehicleID", $vehicleID); | ||||||
|  |     $stmtOwner->bindParam(":peopleID", $peopleID); | ||||||
|  |     $stmtOwner->execute(); | ||||||
|  | 
 | ||||||
|  |     $stmt = $conn->prepare("INSERT INTO Incident (Incident_report, Incident_date, People_ID, Vehicle_ID, Offence_ID) VALUES (:incidentReport, :incidentDate, :peopleID, :vehicleID, :offenceID)"); | ||||||
|  |     $stmt->bindParam(":incidentReport", $incidentReport); | ||||||
|  |     $stmt->bindParam(":incidentDate", $incidentDate); | ||||||
|  |     $stmt->bindParam(":peopleID", $peopleID); | ||||||
|  |     $stmt->bindParam(":vehicleID", $vehicleID); | ||||||
|  |     $stmt->bindParam(":offenceID", $offenceID); | ||||||
|  |     $stmt->execute(); | ||||||
|  | 
 | ||||||
|  |     $logSQL = "INSERT INTO Logs (Logs_type, Users_username, Logs_date) VALUES ('Add Report', :username, NOW())"; | ||||||
|  |     $logStmt = $conn->prepare($logSQL); | ||||||
|  |     $logStmt->bindParam(":username", $_SESSION["username"]); | ||||||
|  |     $logStmt->execute(); | ||||||
|  | 
 | ||||||
|  |     echo json_encode(array("message" => "ok")); | ||||||
|  | } | ||||||
|  | else | ||||||
|  | { | ||||||
|  |     echo json_encode(array("message" => "Not logged in")); | ||||||
|  | } | ||||||
| @ -0,0 +1,112 @@ | |||||||
|  | <!DOCTYPE html> | ||||||
|  | <html lang="en"> | ||||||
|  | <head> | ||||||
|  |     <meta charset="UTF-8"> | ||||||
|  |     <title>Reports</title> | ||||||
|  |     <link rel="stylesheet" href="css/reports.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="reports.html" class="btn active">Reports</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="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> | ||||||
|  |             <div class="formGroup"> | ||||||
|  |                 <div class="formSpace"> | ||||||
|  | 
 | ||||||
|  |                     <div class="formControl"> | ||||||
|  |                         <label for="type">Incident Report</label> | ||||||
|  |                         <input type="text" name="type" id="incidentReport" required> | ||||||
|  |                     </div> | ||||||
|  | 
 | ||||||
|  |                     <div class="formControl"> | ||||||
|  |                         <label for="colour">Incident Date</label> | ||||||
|  |                         <input type="date" name="colour" id="incidentDate" required> | ||||||
|  |                     </div> | ||||||
|  | 
 | ||||||
|  |                     <div class="formControl"> | ||||||
|  |                         <label for="owner">Owner</label> | ||||||
|  |                         <div class="selectDiv"> | ||||||
|  |                             <select name="owner" id="owner" required> | ||||||
|  | 
 | ||||||
|  |                             </select> | ||||||
|  |                         </div> | ||||||
|  |                     </div> | ||||||
|  | 
 | ||||||
|  |                     <div class="formControl"> | ||||||
|  |                         <label for="vehicle">Vehicle</label> | ||||||
|  |                         <div class="selectDiv"> | ||||||
|  |                             <select name="owner" id="vehicle" required> | ||||||
|  | 
 | ||||||
|  |                             </select> | ||||||
|  |                         </div> | ||||||
|  |                     </div> | ||||||
|  | 
 | ||||||
|  |                     <div class="formControl"> | ||||||
|  |                         <label for="offence">Offence</label> | ||||||
|  |                         <div class="selectDiv"> | ||||||
|  |                             <select name="owner" id="offence" required> | ||||||
|  | 
 | ||||||
|  |                             </select> | ||||||
|  |                         </div> | ||||||
|  |                     </div> | ||||||
|  | 
 | ||||||
|  |                     <input type="submit" id="reports" value="Add new report" class="btn btnPrimary"> | ||||||
|  |                 </div> | ||||||
|  | 
 | ||||||
|  |                 <div class="formSpace" id="addOwner"> | ||||||
|  |                     <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" maxlength="16" max="16"> | ||||||
|  |                     </div> | ||||||
|  |                 </div> | ||||||
|  | 
 | ||||||
|  |                 <div class="formSpace" id="addVehicle"> | ||||||
|  | 
 | ||||||
|  |                     <div class="formControl"> | ||||||
|  |                         <label for="type">Type</label> | ||||||
|  |                         <input type="text" name="type" id="type" required> | ||||||
|  |                     </div> | ||||||
|  | 
 | ||||||
|  |                     <div class="formControl"> | ||||||
|  |                         <label for="colour">Colour</label> | ||||||
|  |                         <input type="text" name="colour" id="colour" required> | ||||||
|  |                     </div> | ||||||
|  | 
 | ||||||
|  |                     <div class="formControl"> | ||||||
|  |                         <label for="plateNum">Plate Number</label> | ||||||
|  |                         <input type="text" name="plateNum" id="plateNum" required> | ||||||
|  |                     </div> | ||||||
|  | 
 | ||||||
|  |                 </div> | ||||||
|  | 
 | ||||||
|  |             </div> | ||||||
|  |         </form> | ||||||
|  | </main> | ||||||
|  | 
 | ||||||
|  | <script src="js/checkUser.js"></script> | ||||||
|  | <script src="js/reports.js"></script> | ||||||
|  | </body> | ||||||
|  | </html> | ||||||
		Loading…
	
		Reference in New Issue
	
	Block a user