1
0
mirror of https://koodu.h-i.works/projects/thebadspace synced 2025-06-25 16:04:37 -05:00

Added Front listings and member editing

Added the template for to display locations on the front end. Still need
to add template for individual locations.

Also added member editing. Still need to wire up the avatar uploading
but adding and editing member information is possible. Still need to
fine tune it according to roles
This commit is contained in:
Ro
2023-01-16 20:17:22 -08:00
parent e897453664
commit c5d1ab0266
13 changed files with 291 additions and 104 deletions

View File

@ -9,58 +9,66 @@ use Symfony\Component\HttpFoundation\Response;
use Symfony\Component\HttpFoundation\Request;
use Symfony\Component\Routing\Annotation\Route;
use Symfony\Bundle\FrameworkBundle\Controller\AbstractController;
use Doctrine\Persistence\ManagerRegistry;
//use App\Utils\PageRender;
//use App\Utils\StringTools;
use App\Service\Auth;
use App\Service\HandleMembers;
use App\Service\Render;
use App\Service\Auth;
class Members extends AbstractController
{
/**
* @Route("/dashboard/members", name="dash-members")
* @Route("/den/members/page/{pageNum}", name="den-locations")
*/
public function showMembers(
Request $request,
Auth $auth
): Response {
Auth $auth,
Render $render,
HandleMembers $members,
int $pageNum = 1
) {
$result = $auth->status();
if ($result["status"]) {
/*
return $render->renderPage(
["bgImage" => "", "mode" => "index"],
"The Nile List | Members",
"dash/members.html.twig"
);
*/
$self = $members->getYou();
$you = $self->getId();
$list = $members->getMemberPage($pageNum);
return $render->page([
"mode" => "index",
"you" => $you,
"list" => $list], "Bad Space | Members", "back/members.twig");
} else {
//back to index to login
header("Location:/knockknock");
return new Response("<html><body>LOGGED IN</body></html>");
}
}
/**
* @Route("/den/members/add", name="members-add")
*/
public function addMembers(
* @Route("/den/members/{action}/{id}", name="den-members")
*/
public function handleMemberActions(
Request $request,
Auth $auth,
Render $render,
HandleMembers $members,
ManagerRegistry $doctrine
string $action = "index",
int $id = 0
): Response {
$result = $auth->status();
if ($result["status"]) {
if ($request->getMethod() == "GET") {
return $this->render("back/members.twig", [
"title" => "Get a class from the cupboard",
"mode" => "add"
]);
$self = $members->getYou();
$you = $self->getId();
$member = [];
if ($id != 0) {
$member = $members->getMemberById($id);
}
return $render->page([
"mode" => $action,
"you" => $you,
"currentMember" => $member], "Bad Space | Members", "back/members.twig");
} else {
//add new member
$token = $request->get("token");
$notice = "";
$entityManager = $doctrine->getManager();
$token = $request->get("token");
$notice = "";
$mode = $request->get("mode");
$id = $request->get("member_id");
//token check
if (!$this->isCsrfTokenValid("upload", $token)) {
@ -74,7 +82,12 @@ class Members extends AbstractController
]
);
}
$self = $members->getYou();
$you = $self->getId();
$member = [];
if ($id != 0) {
$member = $members->getMemberById($id);
}
if (
$request->request->get("handle") == "" ||
$request->request->get("role") == "" ||
@ -82,48 +95,44 @@ class Members extends AbstractController
$request->request->get("email") == "" ||
$request->request->get("pronoun") == ""
) {
return new Response("<html><body>All fields required</body></html>");
/*
$notice = "All fields are required, champ.";
return $render->renderPage(
["bgImage" => "", "mode" => "add", "notice" => $notice],
"The Nile List | Add Member Error",
"dash/members.html.twig"
);
*/
return $render->page([
"notice" => $notice,
"mode" => $mode,
"you" => $you,
"currentMember" => $member], "Bad Space | Members", "back/members.twig");
}
//empty valid email check
if (
!filter_var($request->request->get("email"), FILTER_VALIDATE_EMAIL)
) {
return new Response("<html><body>BOGUS EMAIL</body></html>");
/*
$notice = "Need a valid email, slick.";
return $render->renderPage(
["bgImage" => "", "mode" => "add", "notice" => $notice],
"The Nile List | Add Member Error",
"dash/members.html.twig"
);
*/
return $render->page([
"notice" => $notice,
"mode" => $mode,
"you" => $you,
"currentMember" => $member], "Bad Space | Members", "back/members.twig");
}
// password confirm check
if ($request->request->get("new_pass") != "") {
if ($request->request->get("new_pass") != $request->request->get("new_pass_confirm")) {
$notice = "New password must be confirmed";
return $render->page([
"notice" => $notice,
"mode" => $mode,
"you" => $you,
"currentMember" => $member], "Bad Space | Members", "back/members.twig");
}
}
//check clear, call add method
$response = $members->addMember($request);
$response = $members->modifyMember($request, $id, $mode);
if ($response["status"]) {
/*
return $render->renderPage(
[
"bgImage" => "",
"mode" => "add",
"notice" => $response["message"],
],
"The Nile List | Add Members",
"dash/members.html.twig"
);
*/
return new Response("<html><body>MEMBER ADDED</body></html>");
return $render->page([
"notice" => $response["message"],
"mode" => $mode,
"you" => $you,
"currentMember" => $member], "Bad Space | Members", "back/members.twig");
} else {
return new Response("<html><body>" . $response["message"] . "</body></html>");
/*
@ -138,7 +147,7 @@ class Members extends AbstractController
} else {
//back to index to login
header("Location:/den");
return new Response("<html><body>LOGGED IN</body></html>");
return new Response("<html><body>TO THE FRONT</body></html>");
}
}
}

View File

@ -24,6 +24,7 @@ class HandleMembers
{
private $session;
private $entityManager;
private $limit = 5;
public function __construct(
EntityManagerInterface $entityManager,
@ -38,22 +39,63 @@ class HandleMembers
*
* @return MEMBERS data object
*/
public function getMember()
public function getYou()
{
$member = $this->session->get("member");
return $member;
}
public function getMemberById(int $id)
{
$member = $this->entityManager->getRepository(Member::class)->find($id);
return $member;
}
public function getMemberPage(int $page, string $active = "all")
{
$members = $this->entityManager->getRepository(Member::class);
if ($active == "true" || $active == "false") {
$list = $members->findBy(["active" => $active], ["id" => "ASC"]);
} else {
$list = $members->findBy([], ["id" => "ASC"]);
}
$count = ceil(count($list) / $this->limit);
$totalCount = count($list);
$shelf = [];
$range = $page * $this->limit - $this->limit;
for ($i = 0; $i <= $this->limit; $i++) {
try {
array_push($shelf, $list[$i + $range]);
} catch (Exception $error) {
}
}
return [
"members" => $shelf,
"total" => $count,
"totalMembers" => $totalCount,
];
}
/**
* Add new member to db
* Add or edit new member
*
* @param Request $request object containing posted data
* @return JSON
* @param int $memberId member identifier
* @param string $action request task
* @return Object
*/
public function addMember($request)
public function modifyMember($request, $memberId, $action)
{
$errorMessage = null;
$member = new Member();
if ($action == "add") {
$member = new Member();
} else {
$member = $this->entityManager->getRepository(Member::class)->find($memberId);
}
//submitted values
$handle = $request->request->get("handle");
@ -69,15 +111,23 @@ class HandleMembers
//set defaults
//$utils = new StringTools();
$uuid = $hash = password_hash("passw0rd!", PASSWORD_DEFAULT);
$member->setPassword($hash);
$member->setAvatar("default-member-avatar");
$member->setUuid(Uuid::v4());
$member->setActive(false);
$member->setCreatedAt(new \DateTimeImmutable());
$member->setLastLogin(new \DateTimeImmutable());
$this->entityManager->persist($member);
if ($action == "add") {
$hash = password_hash("passw0rd!", PASSWORD_DEFAULT);
$member->setPassword($hash);
$member->setActive(false);
$member->setAvatar("default-member-avatar");
$member->setUuid(Uuid::v4());
$this->entityManager->persist($member);
$member->setCreatedAt(new \DateTimeImmutable());
$member->setLastLogin(new \DateTimeImmutable());
} else {
$active = ($request->request->get("active") == "true" ? true : false);
$member->setActive($active);
if ($request->request->get("new_pass") != "") {
$hash = password_hash($request->request->get("new_pass"), PASSWORD_DEFAULT);
$member->setPassword($hash);
}
}
try {
$this->entityManager->flush();
@ -93,10 +143,16 @@ class HandleMembers
$errorMessage = $error->getMessage();
}
// return result status
$message = "";
if ($action == "add") {
$message = "New member added. Woohoo!";
} else {
$message = "Member Info Edited";
}
if ($errorMessage == null) {
return $response = [
"status" => true,
"message" => "New member added. Woohoo!",
"message" => $message,
];
} else {
return $response = ["status" => false, "message" => $errorMessage];
@ -111,11 +167,10 @@ class HandleMembers
*/
public function updateMember($request)
{
$errorMessage = null;
$currentMember = $this->getMember();
$id = $currentMember->getMemberId();
$member = $this->entityManager->getRepository(Members::class)->find($id);
$image = $request->files->get("avi");
$errorMessage = null;
$id = $request->request->get("member_id");
$member = $this->entityManager->getRepository(Members::class)->find($id);
$image = $request->files->get("avi");
if (!empty($image)) {
$name = $image->getClientOriginalName();
$member->setAvatar($name);