Update CaseController add AJAX method for checking case and user levels

This commit is contained in:
Ryan Prather 2024-12-10 22:49:15 -05:00
parent 96933d2e01
commit 6454d3db47

View File

@ -2,6 +2,7 @@
namespace App\Controller; namespace App\Controller;
use Exception;
use App\Entity\MemberCase; use App\Entity\MemberCase;
use App\Entity\ReferralSource; use App\Entity\ReferralSource;
use App\Entity\User; use App\Entity\User;
@ -140,8 +141,8 @@ class CaseController extends AbstractController
$caseWorkers = $this->entityManager->getRepository(User::class)->getCaseWorkers(); $caseWorkers = $this->entityManager->getRepository(User::class)->getCaseWorkers();
$case = $this->entityManager->getRepository(MemberCase::class)->find($id); $case = $this->entityManager->getRepository(MemberCase::class)->find($id);
$prevUc = $this->entityManager->getRepository(UserCase::class)->findBy(['memberCase' => $case]); $prevUc = $this->entityManager->getRepository(UserCase::class)->findBy(['memberCase' => $case]);
$uc = new UserCase(); $uc = new UserCase();
$form = $this->createForm(UserCaseFormType::class, $uc); $form = $this->createForm(UserCaseFormType::class, $uc);
$form->handleRequest($request); $form->handleRequest($request);
@ -152,10 +153,6 @@ class CaseController extends AbstractController
$uc->setMemberCase($case); $uc->setMemberCase($case);
$uc->setUser($user); $uc->setUser($user);
if(!$uc->checkLevel()) {
throw new Exception('');
}
if (count($prevUc) > 0) { if (count($prevUc) > 0) {
$this->entityManager->remove($prevUc[0]); $this->entityManager->remove($prevUc[0]);
$this->entityManager->flush(); $this->entityManager->flush();
@ -177,7 +174,7 @@ class CaseController extends AbstractController
'title' => 'Assign Case', 'title' => 'Assign Case',
'breadcrumbs' => [ 'breadcrumbs' => [
new Breadcrumb($this->generateUrl('app_list_cases'), 'List Cases'), new Breadcrumb($this->generateUrl('app_list_cases'), 'List Cases'),
new Breadcrumb($this->generateUrl('app_assign_case', ['id' => $id]), 'Assign Case') new Breadcrumb($this->generateUrl('app_assign_case', ['id' => $id]), 'Assign User')
], ],
'notifications' => $admin->retrieveUnreadNotifications(), 'notifications' => $admin->retrieveUnreadNotifications(),
'form' => $form, 'form' => $form,
@ -189,6 +186,33 @@ class CaseController extends AbstractController
); );
} }
#[Route('/case-notes/{id}', name: 'app_case_notes')]
public function showCaseNotes(Request $request, string $id): Response
{
$case = $this->entityManager->getRepository(MemberCase::class)->find($id);
return new Response();
}
#[Route('/api/case/{caseId}/user/{userId}', name: 'ajax_case_user_level_check')]
public function checkUserCaseLevel(string $caseId, string $userId) : Response
{
$ret = true;
$user = $this->entityManager->getRepository(User::class)->find($userId);
$case = $this->entityManager->getRepository(MemberCase::class)->find($caseId);
$res = UserCase::checkLevel($user, $case);
if (!$res) {
$ret = [
'userLevel' => ucwords(str_replace('_', ' ', strtolower($user->getLevel()->name))),
'caseLevel' => ucwords(str_replace('_', ' ', strtolower($case->getLevel()->name))),
];
}
return $this->json($ret);
}
#[Route('/api/filter-cases-by-user', name: 'ajax_filter_cases_by_user')] #[Route('/api/filter-cases-by-user', name: 'ajax_filter_cases_by_user')]
public function filterCasesByUser(Request $request): Response public function filterCasesByUser(Request $request): Response
{ {