diff --git a/assets/css/biodata.css b/assets/css/biodata.css new file mode 100644 index 0000000000000000000000000000000000000000..e5bfd8e52ab9471622a1dc1a4699d9090f3477ea --- /dev/null +++ b/assets/css/biodata.css @@ -0,0 +1,45 @@ +.header { + background-color: rgb(20,50,180); + display: flex; + flex-direction: column; + align-items: center; +} + +.header > div { + color : blanchedalmond; + /* width: 100px; */ + text-align: center; + line-height: 75px; + font-size: 30px; +} + +.content { + font-size: 30px; + color: orangered; + font-family: 'Times New Roman'; +} + +ul { + list-style-position: inside; +} + +div.edit{ + align-self:flex-end; +} + +image.profile { + height: 50px; + width: 50px; + border-radius: 50%; +} + +img.edits { + border: 1px solid #ddd; + border-radius: 4px; + padding: 5px; + width: 150px; +} + +img.edits:hover { + box-shadow: 0 0 2px 1px rgba(0, 140, 186, 0.5); +} diff --git a/assets/css/edit_biodata.css b/assets/css/edit_biodata.css new file mode 100644 index 0000000000000000000000000000000000000000..0834d4da7b830bed2d5750b51fe95756c9b66cca --- /dev/null +++ b/assets/css/edit_biodata.css @@ -0,0 +1,46 @@ +h1 { + color: coral; +} + +img { + width: 100px; + height: 100px; +} + +button.back { + background-color: beige; + border: maroon 1px solid; + border-style: solid; + color: maroon; + text-align: center; + font-size: 20px; + cursor: pointer; + padding: 15px 25px; +} + +button.back:hover { + background-color: maroon; + border: whitesmoke 1px solid; + color: linen; + border-style: hidden; +} + +button.save { + background-color: royalblue; + border: none; + color: navajowhite; + text-align: center; + font-size: 20px; + cursor: pointer; + padding: 15px 25px; +} + +button.save:hover { + background-color: whitesmoke; + border: navy; + color: royalblue; +} + +textarea { + resize: none; +} \ No newline at end of file diff --git a/assets/js/edit.js b/assets/js/edit.js new file mode 100644 index 0000000000000000000000000000000000000000..f5ebe91d0820c9770b503f5fdeb0d610d46dd5cd --- /dev/null +++ b/assets/js/edit.js @@ -0,0 +1,51 @@ +window.onload = function() { + // Add validator for the fields below. + let name = document.getElementById('field_name'); + let address = document.getElementById('field_address'); + let phone = document.getElementById('field_phone'); + name.onkeyup = function(e) { + if (this.value !== "") { + name_ok = true; + } else { + name_ok = false; + } + } + address.onkeyup = function(e) { + if (this.value !== "") { + address_ok = true; + } else { + address_ok = false; + } + } + phone.onkeyup = function(e) { + if (this.value !== "") { + phone_ok = true; + } else { + phone_ok = false; + } + } + // Whether or not a field is okay. + var name_ok = false; + var address_ok = false; + var phone_ok = false; + // On save button clicked. + let button = document.getElementById('save_button'); + button.addEventListener("click", (e) => { + // let name = document.getElementById('field_name'); + // if (!name_ok) { + // name.focus(); + // return; + // } + // let address = document.getElementById('field_address'); + // if (!address_ok) { + // address.focus(); + // return; + // } + // let phone = document.getElementById('field_phone'); + // if (!phone_ok) { + // phone.focus(); + // return; + // } + document.getElementById("edit_form").submit(); + }); +} \ No newline at end of file diff --git a/controller/BiodataController.php b/controller/BiodataController.php new file mode 100644 index 0000000000000000000000000000000000000000..0269f2fe583a89d03789466054ac8e7edda57d3b --- /dev/null +++ b/controller/BiodataController.php @@ -0,0 +1,33 @@ +<?php +namespace JLAS\Book\Controller; +use \JLAS\Book\Controller\BaseController; +use \JLAS\Book\Model as Model; +use \JLAS\Book\Entity as Entity; + +class BiodataController extends BaseController { + + /** + * Get the data needed for this controller. + * @return array data passed to the view. + */ + protected function run($params) { + $username = $this->getUsername(); + if (isset($username)) { + $model_biodata = new Model\BiodataModel(); + $biodata = $model_biodata->findByID($username); + $this->setResponse(200, "Success"); + return $biodata->asArray(); + + // $this->setResponse(401, "Not logged in"); + // return $params; + + } + else { + $this->setResponse(400); + return $params; + } + } + +} + +?> \ No newline at end of file diff --git a/controller/EditController.php b/controller/EditController.php new file mode 100644 index 0000000000000000000000000000000000000000..515f2c8ddde3d33c114e56bc05c2dbb9e0f78088 --- /dev/null +++ b/controller/EditController.php @@ -0,0 +1,80 @@ +<?php +namespace JLAS\Book\Controller; +use \JLAS\Book\Controller\BaseController; +use \JLAS\Book\Model as Model; +use \JLAS\Book\Entity as Entity; + +class EditController extends BaseController { + + /** + * Get the data needed for this controller. + * @return array data passed to the view. + */ + protected function run($params) { + $username = $this->getUsername(); + if (isset($username)) { + $model_account = new Model\AccountModel(); + $model_biodata = new Model\BiodataModel(); + $user = $model_account->findByID($username); + if (isset($this->params["data"]["name"])) { + // User available. + $biodata = $model_biodata->findByID($username); + $arr_bio = $biodata->asArray(); + $biodatas = new Entity\GenericEntity(array( + "username" => $username, + "name" => $this->getArg('name'), + "email" => $arr_bio['email'], + "address" => $this->getArg('address'), + "phone" => $this->getArg('phone'), + )); + // $result = $model_biodata->update($biodatas); + + if ($model_biodata->update($biodatas)) { + // return to history page + header("Location: /book/profile"); + exit; + } + + // $model_token = new Model\TokenModel(); + // $token = $model_token->findByID($this->getArg('username')); + + // if (isset($token)) { + // // Update current token. + // $token->token = LoginController::generateAccessToken($user->username); + // $token->expiry = date('Y-m-d H:i:s', strtotime(date('Y-m-d H:i:s') . ' + ' . LoginController::$TokenDuration)); + // $model_token->update($token); + // } else { + // // Create a new token. + // $token = new Entity\TokenEntity(array( + // "username" => $user->username, + // "access-token" => LoginController::generateAccessToken($user->username), + // "expiry" => date('Y-m-d H:i:s', strtotime(date('Y-m-d H:i:s') . ' + ' . LoginController::$TokenDuration)) + // )); + // $model_token->create($token); + // } + $this->setResponse(200, "User $username updated"); + return $biodatas->asArray(); + // return $params; + } else { + $biodata = $model_biodata->findByID($username); + $arr_bio = $biodata->asArray(); + $biodatas = new Entity\GenericEntity(array( + "username" => $username, + "name" => $arr_bio['name'], + "email" => $arr_bio['email'], + "address" => $arr_bio['address'], + "phone" => $arr_bio['phone'], + )); + $this->setResponse(200, "Please edit"); + return $biodatas->asArray(); + // return $params; + } + } else { + $this->setResponse(400, "Please log in first"); + return $params; + } + } + +} + +?> \ No newline at end of file diff --git a/model/BiodataModel.php b/model/BiodataModel.php index c8f8c2da669ac917b34969d2b347f2e01856aec7..11f1c7163c23e43b7de78091be05154da1e701c5 100644 --- a/model/BiodataModel.php +++ b/model/BiodataModel.php @@ -65,7 +65,7 @@ class BiodataModel extends BaseModel { */ public function update($entity) { $result = $this->query( - "UPDATE $this->table SET `name`=:name, `email`=:email, `address`=:address, `phone`:=phone WHERE `username`=:username", + "UPDATE $this->table SET `name`=:name, `email`=:email, `address`=:address, `phone`=:phone WHERE `username`=:username", array( ":username" => $entity->username, ":name" => $entity->name, diff --git a/routing/profile.php b/routing/profile.php new file mode 100644 index 0000000000000000000000000000000000000000..c4464b410a314138990da962cdab666cdce8df3a --- /dev/null +++ b/routing/profile.php @@ -0,0 +1,8 @@ +<?php +namespace JLAS\Book; +use SuPHP\Routing as Routing; + +Routing\addRoute("^profile$", "GET", ["biodata.php"], "BiodataController"); +Routing\addRoute("^edit$", "GET", ["edit_biodata.php"], "EditController"); +Routing\addRoute("^edit$", "POST", ["edit_biodata.php"], "EditController"); +?> \ No newline at end of file diff --git a/view/biodata.php b/view/biodata.php new file mode 100644 index 0000000000000000000000000000000000000000..7e19c903aa7e4c77b8d95549ef05580e4846daf7 --- /dev/null +++ b/view/biodata.php @@ -0,0 +1,44 @@ +<!DOCTYPE html> +<?php + var_dump($response); + echo "<br>"; + var_dump($data); +?> +<html> +<head> + <meta charset="utf-8" /> + <meta http-equiv="X-UA-Compatible" content="IE=edge"> + <meta name="viewport" content="width=device-width, initial-scale=1"> + <title>Profile</title> + <link rel="stylesheet" href="assets/css/biodata.css"> +</head> +<body> + +<div class="header"> + <div class="edit"><a href="edit"> <img class="edits" alt="Edit button" src="https://us.123rf.com/450wm/briang77/briang771512/briang77151201745/49670730-pencil-vector-icon.jpg?ver=6"> </a></div> + <div><image class="profile" src="img/tayo.jpg" alt="Profile picture"> </div> + <div><?php echo $data["name"] ?></div> +</div> + +<h1 class="content"> My profile </h1> +<table> + <tr> + <td>Username</td> + <td><?php echo $data["username"] ?></td> + </tr> + <tr> + <td>Email </td> + <td><?php echo $data["email"] ?></td> + </tr> + <tr> + <td>Address </td> + <td><?php echo $data["address"] ?></textarea></td> + </tr> + <tr> + <td>Phone Number </td> + <td><?php echo $data["phone"] ?></td> + </tr> +</table> + +</body> +</html> \ No newline at end of file diff --git a/view/edit_biodata.php b/view/edit_biodata.php new file mode 100644 index 0000000000000000000000000000000000000000..d82367bea0be08f255e2ceaf7782ad31e35ef222 --- /dev/null +++ b/view/edit_biodata.php @@ -0,0 +1,56 @@ +<!DOCTYPE html> +<?php + var_dump($response); + echo "<br>"; + var_dump($data); +?> +<html> +<head> + <meta charset="utf-8" /> + <meta http-equiv="X-UA-Compatible" content="IE=edge"> + <meta name="viewport" content="width=device-width, initial-scale=1"> + <title>Edit Profile</title> + <link rel="stylesheet" href="assets/css/edit_biodata.css"> + <script src="assets/js/edit.js"></script> + <!-- <script src="assets/js/bootstrap.js"></script> --> +</head> +<body> + +<div> + <table> + <thead> + <tr> + <th colspan="3"><span>Edit Profile</span></th> + </tr> + </thead> + <body> + <form method="POST" action="" id="edit_form"> + <tr> + <td><img src="" alt="Profile Picture"> </td> + <td> + Update profile picture <br> + <input type="text" name="file_address"> <input type="file" name="new_profile" value="Browse ..."> + </td> + </tr> + <tr> + <td><label>Name </label></td> + <td><input type="text" id="field_name" name="name" value="<?php echo $data["name"] ?>"> </td> + </tr> + <tr> + <td>Address </td> + <td><textarea id="field_address" name="address" cols="30" rows="5"><?php echo $data["address"] ?></textarea></td> + </tr> + <tr> + <td>Phone Number </td> + <td><input type="text" id="field_phone" name="phone" maxlength="12" value="<?php echo $data["phone"] ?>"> </td> + </tr> + </form> + <tr> + <td><button class="back" onclick="window.location.href = 'profile';">Back</button></td> + <td align="right"><button class="save" id="save_button">Save </button></td> + </tr> + </table> +</div> + +</body> +</html> \ No newline at end of file