Compare commits
No commits in common. "9decc18f424f4ace94b013221704e9b1dd4545bc" and "2b8682bcbb70a5ff4643a707a0df7db2f16c8b14" have entirely different histories.
9decc18f42
...
2b8682bcbb
assets/styles
config
src
Controller
AdminController.phpCaseController.phpCommunityResourceController.phpDefaultController.phpMemberController.phpMessageController.phpNoteController.phpReferralController.phpReferralSourceController.phpStaffController.php
Entity
Enums
Factory
Form
Libs
Repository
templates/internal
admin
cases/members
community_resource
libs
staff
@ -1,10 +0,0 @@
|
|||||||
.notification .badge {
|
|
||||||
position: absolute;
|
|
||||||
top: -8px;
|
|
||||||
right: 5px;
|
|
||||||
padding: 5px 9px;
|
|
||||||
border-radius: 50%;
|
|
||||||
background-color: red;
|
|
||||||
color: white;
|
|
||||||
font-size: 6pt;
|
|
||||||
}
|
|
@ -11,5 +11,4 @@ return [
|
|||||||
Symfony\Bundle\SecurityBundle\SecurityBundle::class => ['all' => true],
|
Symfony\Bundle\SecurityBundle\SecurityBundle::class => ['all' => true],
|
||||||
Symfony\Bundle\MonologBundle\MonologBundle::class => ['all' => true],
|
Symfony\Bundle\MonologBundle\MonologBundle::class => ['all' => true],
|
||||||
Symfony\Bundle\MakerBundle\MakerBundle::class => ['dev' => true],
|
Symfony\Bundle\MakerBundle\MakerBundle::class => ['dev' => true],
|
||||||
Doctrine\Bundle\FixturesBundle\DoctrineFixturesBundle::class => ['dev' => true, 'test' => true],
|
|
||||||
];
|
];
|
||||||
|
@ -2,10 +2,8 @@
|
|||||||
|
|
||||||
namespace App\Controller;
|
namespace App\Controller;
|
||||||
|
|
||||||
use App\Entity\Messages;
|
|
||||||
use App\Entity\Supervision;
|
use App\Entity\Supervision;
|
||||||
use App\Entity\User;
|
use App\Entity\User;
|
||||||
use App\Factory\MessageFactory;
|
|
||||||
use App\Form\EditUserFormType;
|
use App\Form\EditUserFormType;
|
||||||
use App\Form\SupervisorFormType;
|
use App\Form\SupervisorFormType;
|
||||||
use App\Form\UserFormType;
|
use App\Form\UserFormType;
|
||||||
@ -24,10 +22,6 @@ use Symfony\Component\Security\Http\Attribute\IsGranted;
|
|||||||
#[IsGranted('ROLE_ADMIN')]
|
#[IsGranted('ROLE_ADMIN')]
|
||||||
class AdminController extends AbstractController
|
class AdminController extends AbstractController
|
||||||
{
|
{
|
||||||
private array $msgs;
|
|
||||||
|
|
||||||
private int $notificationCount = 0;
|
|
||||||
|
|
||||||
public function __construct(
|
public function __construct(
|
||||||
private readonly EntityManagerInterface $entityManager,
|
private readonly EntityManagerInterface $entityManager,
|
||||||
private readonly UserPasswordHasherInterface $userPasswordHasher,
|
private readonly UserPasswordHasherInterface $userPasswordHasher,
|
||||||
@ -41,8 +35,6 @@ class AdminController extends AbstractController
|
|||||||
{
|
{
|
||||||
$this->denyAccessUnlessGranted('ROLE_ADMIN');
|
$this->denyAccessUnlessGranted('ROLE_ADMIN');
|
||||||
$this->navLinks['admin_dashboard'] = NavList::PRESENT_LINK;
|
$this->navLinks['admin_dashboard'] = NavList::PRESENT_LINK;
|
||||||
$this->msgs = $this->entityManager->getRepository(Messages::class)->getUnreadMessages($user);
|
|
||||||
$this->notificationCount = $this->entityManager->getRepository(Messages::class)->getUnreadMessageCount($user);
|
|
||||||
|
|
||||||
return $this->render(
|
return $this->render(
|
||||||
'internal/admin/admin-dashboard.html.twig',
|
'internal/admin/admin-dashboard.html.twig',
|
||||||
@ -52,8 +44,7 @@ class AdminController extends AbstractController
|
|||||||
'breadcrumbs' => [
|
'breadcrumbs' => [
|
||||||
new Breadcrumb($this->generateUrl('app_admin_dashboard'), 'Admin Dashboard')
|
new Breadcrumb($this->generateUrl('app_admin_dashboard'), 'Admin Dashboard')
|
||||||
],
|
],
|
||||||
'notifications' => $this->msgs,
|
'notifications' => $user->retrieveUnreadNotifications(),
|
||||||
'notificationCount' => $this->notificationCount,
|
|
||||||
]
|
]
|
||||||
)
|
)
|
||||||
);
|
);
|
||||||
@ -63,8 +54,6 @@ class AdminController extends AbstractController
|
|||||||
public function listUsers(#[CurrentUser()] User $user): Response
|
public function listUsers(#[CurrentUser()] User $user): Response
|
||||||
{
|
{
|
||||||
$this->denyAccessUnlessGranted('ROLE_ADMIN');
|
$this->denyAccessUnlessGranted('ROLE_ADMIN');
|
||||||
$this->msgs = $this->entityManager->getRepository(Messages::class)->getUnreadMessages($user);
|
|
||||||
$this->notificationCount = $this->entityManager->getRepository(Messages::class)->getUnreadMessageCount($user);
|
|
||||||
|
|
||||||
/** @var UserRepository $repo */
|
/** @var UserRepository $repo */
|
||||||
$repo = $this->entityManager->getRepository(User::class);
|
$repo = $this->entityManager->getRepository(User::class);
|
||||||
@ -88,8 +77,7 @@ class AdminController extends AbstractController
|
|||||||
new Breadcrumb($this->generateUrl('app_list_users'), 'List Users')
|
new Breadcrumb($this->generateUrl('app_list_users'), 'List Users')
|
||||||
],
|
],
|
||||||
'users' => $users,
|
'users' => $users,
|
||||||
'notifications' => $this->msgs,
|
'notifications' => $user->retrieveUnreadNotifications(),
|
||||||
'notificationCount' => $this->notificationCount,
|
|
||||||
]
|
]
|
||||||
)
|
)
|
||||||
);
|
);
|
||||||
@ -99,8 +87,6 @@ class AdminController extends AbstractController
|
|||||||
public function addUser(Request $request, #[CurrentUser()] User $admin): Response
|
public function addUser(Request $request, #[CurrentUser()] User $admin): Response
|
||||||
{
|
{
|
||||||
$this->denyAccessUnlessGranted('ROLE_ADMIN');
|
$this->denyAccessUnlessGranted('ROLE_ADMIN');
|
||||||
$this->msgs = $this->entityManager->getRepository(Messages::class)->getUnreadMessages($admin);
|
|
||||||
$this->notificationCount = $this->entityManager->getRepository(Messages::class)->getUnreadMessageCount($admin);
|
|
||||||
|
|
||||||
$user = new User();
|
$user = new User();
|
||||||
$form = $this->createForm(UserFormType::class, $user);
|
$form = $this->createForm(UserFormType::class, $user);
|
||||||
@ -142,10 +128,6 @@ class AdminController extends AbstractController
|
|||||||
->setLevel($form->get('level')->getData())
|
->setLevel($form->get('level')->getData())
|
||||||
->setCompany($admin->getCompany());
|
->setCompany($admin->getCompany());
|
||||||
|
|
||||||
|
|
||||||
$msg = MessageFactory::createUser($admin, $user, 'Welcome', "Welcome to CM Tracker");
|
|
||||||
|
|
||||||
$this->entityManager->persist($msg);
|
|
||||||
$this->entityManager->persist($user);
|
$this->entityManager->persist($user);
|
||||||
$this->entityManager->flush();
|
$this->entityManager->flush();
|
||||||
|
|
||||||
@ -166,8 +148,7 @@ class AdminController extends AbstractController
|
|||||||
new Breadcrumb($this->generateUrl('app_add_user'), 'Add User')
|
new Breadcrumb($this->generateUrl('app_add_user'), 'Add User')
|
||||||
],
|
],
|
||||||
'form' => $form,
|
'form' => $form,
|
||||||
'notifications' => $this->msgs,
|
'notifications' => $admin->retrieveUnreadNotifications(),
|
||||||
'notificationCount' => $this->notificationCount,
|
|
||||||
]
|
]
|
||||||
)
|
)
|
||||||
);
|
);
|
||||||
@ -178,8 +159,6 @@ class AdminController extends AbstractController
|
|||||||
{
|
{
|
||||||
/** @var UserRepository $userRepo */
|
/** @var UserRepository $userRepo */
|
||||||
$userRepo = $this->entityManager->getRepository(User::class);
|
$userRepo = $this->entityManager->getRepository(User::class);
|
||||||
$this->msgs = $this->entityManager->getRepository(Messages::class)->getUnreadMessages($admin);
|
|
||||||
$this->notificationCount = $this->entityManager->getRepository(Messages::class)->getUnreadMessageCount($admin);
|
|
||||||
|
|
||||||
/** @var User $user */
|
/** @var User $user */
|
||||||
$user = $userRepo->find($id);
|
$user = $userRepo->find($id);
|
||||||
@ -216,8 +195,7 @@ class AdminController extends AbstractController
|
|||||||
],
|
],
|
||||||
'data' => $user,
|
'data' => $user,
|
||||||
'form' => $form,
|
'form' => $form,
|
||||||
'notifications' => $this->msgs,
|
'notifications' => $admin->retrieveUnreadNotifications(),
|
||||||
'notificationCount' => $this->notificationCount,
|
|
||||||
]
|
]
|
||||||
)
|
)
|
||||||
);
|
);
|
||||||
@ -228,8 +206,6 @@ class AdminController extends AbstractController
|
|||||||
{
|
{
|
||||||
/** @var UserRepository $userRepo */
|
/** @var UserRepository $userRepo */
|
||||||
$userRepo = $this->entityManager->getRepository(User::class);
|
$userRepo = $this->entityManager->getRepository(User::class);
|
||||||
$this->msgs = $this->entityManager->getRepository(Messages::class)->getUnreadMessages($admin);
|
|
||||||
$this->notificationCount = $this->entityManager->getRepository(Messages::class)->getUnreadMessageCount($admin);
|
|
||||||
|
|
||||||
/** @var User $user */
|
/** @var User $user */
|
||||||
$user = $userRepo->find($id);
|
$user = $userRepo->find($id);
|
||||||
@ -250,12 +226,7 @@ class AdminController extends AbstractController
|
|||||||
$sup->setSupervisor($supervisor);
|
$sup->setSupervisor($supervisor);
|
||||||
$sup->setWorker($user);
|
$sup->setWorker($user);
|
||||||
|
|
||||||
$supMsg = MessageFactory::createUser($admin, $supervisor, 'New Case Worker', "You've been assigned a new case worker, {$user->getName()}");
|
|
||||||
$userMsg = MessageFactory::createUser($admin, $user, 'New Staff Supervisor', "You've been assigned a new staff supervisor {$supervisor->getName()}");
|
|
||||||
|
|
||||||
$this->entityManager->persist($sup);
|
$this->entityManager->persist($sup);
|
||||||
$this->entityManager->persist($userMsg);
|
|
||||||
$this->entityManager->persist($supMsg);
|
|
||||||
$this->entityManager->flush();
|
$this->entityManager->flush();
|
||||||
|
|
||||||
return $this->redirectToRoute('app_list_users');
|
return $this->redirectToRoute('app_list_users');
|
||||||
@ -273,8 +244,7 @@ class AdminController extends AbstractController
|
|||||||
'user' => $user,
|
'user' => $user,
|
||||||
'form' => $form,
|
'form' => $form,
|
||||||
'supervisors' => $userRepo->getCaseManagers($admin->getCompany()),
|
'supervisors' => $userRepo->getCaseManagers($admin->getCompany()),
|
||||||
'notifications' => $this->msgs,
|
'notifications' => $admin->retrieveUnreadNotifications(),
|
||||||
'notificationCount' => $this->notificationCount,
|
|
||||||
]
|
]
|
||||||
)
|
)
|
||||||
);
|
);
|
||||||
|
@ -3,11 +3,9 @@
|
|||||||
namespace App\Controller;
|
namespace App\Controller;
|
||||||
|
|
||||||
use App\Entity\MemberCase;
|
use App\Entity\MemberCase;
|
||||||
use App\Entity\Messages;
|
|
||||||
use App\Entity\ReferralSource;
|
use App\Entity\ReferralSource;
|
||||||
use App\Entity\User;
|
use App\Entity\User;
|
||||||
use App\Entity\UserCase;
|
use App\Entity\UserCase;
|
||||||
use App\Factory\MessageFactory;
|
|
||||||
use App\Form\MemberCaseFormType;
|
use App\Form\MemberCaseFormType;
|
||||||
use App\Form\UserCaseFormType;
|
use App\Form\UserCaseFormType;
|
||||||
use App\Libs\Breadcrumb;
|
use App\Libs\Breadcrumb;
|
||||||
@ -21,15 +19,6 @@ use Symfony\Component\Security\Http\Attribute\CurrentUser;
|
|||||||
|
|
||||||
class CaseController extends AbstractController
|
class CaseController extends AbstractController
|
||||||
{
|
{
|
||||||
/**
|
|
||||||
* Variable to store unread notification messages
|
|
||||||
*
|
|
||||||
* @var array
|
|
||||||
*/
|
|
||||||
private array $msgs;
|
|
||||||
|
|
||||||
private int $notificationCount;
|
|
||||||
|
|
||||||
public function __construct(
|
public function __construct(
|
||||||
private EntityManagerInterface $entityManager,
|
private EntityManagerInterface $entityManager,
|
||||||
private array $navLinks = []
|
private array $navLinks = []
|
||||||
@ -38,59 +27,32 @@ class CaseController extends AbstractController
|
|||||||
$this->navLinks['case_list'] = NavList::PRESENT_LINK;
|
$this->navLinks['case_list'] = NavList::PRESENT_LINK;
|
||||||
}
|
}
|
||||||
|
|
||||||
#[Route('/my-cases', name: 'app_my_cases')]
|
|
||||||
public function myCases(#[CurrentUser()] User $user): Response
|
|
||||||
{
|
|
||||||
$this->navLinks['my_cases'] = NavList::PRESENT_LINK;
|
|
||||||
$this->navLinks['case_list'] = 'nav-link text-dark';
|
|
||||||
$ucs = $this->entityManager->getRepository(UserCase::class)->findBy(['user' => $user]);
|
|
||||||
$this->msgs = $this->entityManager->getRepository(Messages::class)->getUnreadMessages($user);
|
|
||||||
$this->notificationCount = $this->entityManager->getRepository(Messages::class)->getUnreadMessageCount($user);
|
|
||||||
|
|
||||||
$cases = [];
|
|
||||||
foreach ($ucs as $uc) {
|
|
||||||
/** @var UserCase $uc */
|
|
||||||
$cases[] = $uc->getMemberCase();
|
|
||||||
}
|
|
||||||
|
|
||||||
return $this->render(
|
|
||||||
'internal/cases/my-cases.html.twig',
|
|
||||||
array_merge(
|
|
||||||
$this->navLinks,
|
|
||||||
[
|
|
||||||
'breadcrumbs' => [
|
|
||||||
new Breadcrumb($this->generateUrl('app_my_cases'), 'List Cases')
|
|
||||||
],
|
|
||||||
'notifications' => $this->msgs,
|
|
||||||
'cases' => $cases,
|
|
||||||
'notificationCount' => $this->notificationCount,
|
|
||||||
]
|
|
||||||
)
|
|
||||||
);
|
|
||||||
}
|
|
||||||
|
|
||||||
#[Route('/list-cases', name: 'app_list_cases')]
|
#[Route('/list-cases', name: 'app_list_cases')]
|
||||||
public function listCases(#[CurrentUser()] User $user): Response
|
public function listCases(#[CurrentUser()] User $user): Response
|
||||||
{
|
{
|
||||||
$this->denyAccessUnlessGranted('ROLE_ADMIN');
|
if($this->isGranted('ROLE_ADMIN')) {
|
||||||
|
$cases = $this->entityManager->getRepository(MemberCase::class)->findAll();
|
||||||
$cases = $this->entityManager->getRepository(MemberCase::class)->findAll();
|
} else {
|
||||||
|
$ucs = $this->entityManager->getRepository(UserCase::class)->findBy(['user' => $user]);
|
||||||
|
$cases = [];
|
||||||
|
foreach ($ucs as $uc) {
|
||||||
|
/** @var UserCase $uc */
|
||||||
|
$cases[] = $uc->getMemberCase();
|
||||||
|
}
|
||||||
|
}
|
||||||
$workers = $this->entityManager->getRepository(User::class)->getCaseWorkers();
|
$workers = $this->entityManager->getRepository(User::class)->getCaseWorkers();
|
||||||
$this->msgs = $this->entityManager->getRepository(Messages::class)->getUnreadMessages($user);
|
|
||||||
$this->notificationCount = $this->entityManager->getRepository(Messages::class)->getUnreadMessageCount($user);
|
|
||||||
|
|
||||||
return $this->render(
|
return $this->render(
|
||||||
'internal/admin/cases/list-cases.html.twig',
|
'internal/cases/list-cases.html.twig',
|
||||||
array_merge(
|
array_merge(
|
||||||
$this->navLinks,
|
$this->navLinks,
|
||||||
[
|
[
|
||||||
'breadcrumbs' => [
|
'breadcrumbs' => [
|
||||||
new Breadcrumb($this->generateUrl('app_list_cases'), 'List Cases')
|
new Breadcrumb($this->generateUrl('app_list_cases'), 'List Cases')
|
||||||
],
|
],
|
||||||
'notifications' => $this->msgs,
|
'notifications' => $user->retrieveUnreadNotifications(),
|
||||||
'cases' => $cases,
|
'cases' => $cases,
|
||||||
'workers' => $workers,
|
'workers' => $workers,
|
||||||
'notificationCount' => $this->notificationCount,
|
|
||||||
]
|
]
|
||||||
)
|
)
|
||||||
);
|
);
|
||||||
@ -100,8 +62,6 @@ class CaseController extends AbstractController
|
|||||||
public function addCase(Request $request, #[CurrentUser()] User $admin): Response
|
public function addCase(Request $request, #[CurrentUser()] User $admin): Response
|
||||||
{
|
{
|
||||||
$this->denyAccessUnlessGranted('ROLE_ADMIN');
|
$this->denyAccessUnlessGranted('ROLE_ADMIN');
|
||||||
$this->msgs = $this->entityManager->getRepository(Messages::class)->getUnreadMessages($admin);
|
|
||||||
$this->notificationCount = $this->entityManager->getRepository(Messages::class)->getUnreadMessageCount($admin);
|
|
||||||
|
|
||||||
$case = new MemberCase();
|
$case = new MemberCase();
|
||||||
$form = $this->createForm(MemberCaseFormType::class, $case);
|
$form = $this->createForm(MemberCaseFormType::class, $case);
|
||||||
@ -129,8 +89,7 @@ class CaseController extends AbstractController
|
|||||||
new Breadcrumb($this->generateUrl('app_list_cases'), 'List Cases'),
|
new Breadcrumb($this->generateUrl('app_list_cases'), 'List Cases'),
|
||||||
new Breadcrumb($this->generateUrl('app_add_case'), 'Add Case')
|
new Breadcrumb($this->generateUrl('app_add_case'), 'Add Case')
|
||||||
],
|
],
|
||||||
'notifications' => $this->msgs,
|
'notifications' => $admin->retrieveUnreadNotifications(),
|
||||||
'notificationCount' => $this->notificationCount,
|
|
||||||
'form' => $form,
|
'form' => $form,
|
||||||
'sources' => $this->entityManager->getRepository(ReferralSource::class)->retrieveOrderedList(),
|
'sources' => $this->entityManager->getRepository(ReferralSource::class)->retrieveOrderedList(),
|
||||||
]
|
]
|
||||||
@ -142,8 +101,6 @@ class CaseController extends AbstractController
|
|||||||
public function editCase(Request $request, #[CurrentUser()] User $admin, string $id): Response
|
public function editCase(Request $request, #[CurrentUser()] User $admin, string $id): Response
|
||||||
{
|
{
|
||||||
$this->denyAccessUnlessGranted('ROLE_ADMIN');
|
$this->denyAccessUnlessGranted('ROLE_ADMIN');
|
||||||
$this->msgs = $this->entityManager->getRepository(Messages::class)->getUnreadMessages($admin);
|
|
||||||
$this->notificationCount = $this->entityManager->getRepository(Messages::class)->getUnreadMessageCount($admin);
|
|
||||||
|
|
||||||
$case = $this->entityManager->getRepository(MemberCase::class)->find($id);
|
$case = $this->entityManager->getRepository(MemberCase::class)->find($id);
|
||||||
$form = $this->createForm(MemberCaseFormType::class, $case);
|
$form = $this->createForm(MemberCaseFormType::class, $case);
|
||||||
@ -169,8 +126,7 @@ class CaseController extends AbstractController
|
|||||||
new Breadcrumb($this->generateUrl('app_list_cases'), 'List Cases'),
|
new Breadcrumb($this->generateUrl('app_list_cases'), 'List Cases'),
|
||||||
new Breadcrumb($this->generateUrl('app_edit_case', ['id' => $id]), 'Edit Case')
|
new Breadcrumb($this->generateUrl('app_edit_case', ['id' => $id]), 'Edit Case')
|
||||||
],
|
],
|
||||||
'notifications' => $this->msgs,
|
'notifications' => $admin->retrieveUnreadNotifications(),
|
||||||
'notificationCount' => $this->notificationCount,
|
|
||||||
'form' => $form,
|
'form' => $form,
|
||||||
'case' => $case,
|
'case' => $case,
|
||||||
'sources' => $this->entityManager->getRepository(ReferralSource::class)->retrieveOrderedList(),
|
'sources' => $this->entityManager->getRepository(ReferralSource::class)->retrieveOrderedList(),
|
||||||
@ -183,8 +139,6 @@ class CaseController extends AbstractController
|
|||||||
public function assignCase(string $id, Request $request, #[CurrentUser()] User $admin): Response
|
public function assignCase(string $id, Request $request, #[CurrentUser()] User $admin): Response
|
||||||
{
|
{
|
||||||
$this->denyAccessUnlessGranted('ROLE_ADMIN');
|
$this->denyAccessUnlessGranted('ROLE_ADMIN');
|
||||||
$this->msgs = $this->entityManager->getRepository(Messages::class)->getUnreadMessages($admin);
|
|
||||||
$this->notificationCount = $this->entityManager->getRepository(Messages::class)->getUnreadMessageCount($admin);
|
|
||||||
|
|
||||||
$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);
|
||||||
@ -205,10 +159,7 @@ class CaseController extends AbstractController
|
|||||||
$this->entityManager->flush();
|
$this->entityManager->flush();
|
||||||
}
|
}
|
||||||
|
|
||||||
$msg = MessageFactory::createNewCase($admin, $user);
|
|
||||||
|
|
||||||
$this->entityManager->persist($uc);
|
$this->entityManager->persist($uc);
|
||||||
$this->entityManager->persist($msg);
|
|
||||||
$this->entityManager->flush();
|
$this->entityManager->flush();
|
||||||
|
|
||||||
$this->addFlash('success', 'Case assigned successfully');
|
$this->addFlash('success', 'Case assigned successfully');
|
||||||
@ -226,9 +177,7 @@ class CaseController extends AbstractController
|
|||||||
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 User')
|
new Breadcrumb($this->generateUrl('app_assign_case', ['id' => $id]), 'Assign User')
|
||||||
],
|
],
|
||||||
'notifications' => $this->msgs,
|
'notifications' => $admin->retrieveUnreadNotifications(),
|
||||||
'notificationCount' => $this->notificationCount,
|
|
||||||
'case' => $case,
|
|
||||||
'form' => $form,
|
'form' => $form,
|
||||||
'id' => $id,
|
'id' => $id,
|
||||||
'caseWorkers' => $caseWorkers,
|
'caseWorkers' => $caseWorkers,
|
||||||
|
@ -3,7 +3,6 @@
|
|||||||
namespace App\Controller;
|
namespace App\Controller;
|
||||||
|
|
||||||
use App\Entity\CommunityResource;
|
use App\Entity\CommunityResource;
|
||||||
use App\Entity\Messages;
|
|
||||||
use App\Entity\User;
|
use App\Entity\User;
|
||||||
use App\Form\ResourceFormType;
|
use App\Form\ResourceFormType;
|
||||||
use App\Libs\Breadcrumb;
|
use App\Libs\Breadcrumb;
|
||||||
@ -18,15 +17,6 @@ use Symfony\Component\Validator\Constraints\Regex;
|
|||||||
|
|
||||||
class CommunityResourceController extends AbstractController
|
class CommunityResourceController extends AbstractController
|
||||||
{
|
{
|
||||||
/**
|
|
||||||
* Variable to store unread notification messages
|
|
||||||
*
|
|
||||||
* @var array
|
|
||||||
*/
|
|
||||||
private array $msgs;
|
|
||||||
|
|
||||||
private int $notificationCount;
|
|
||||||
|
|
||||||
public function __construct(
|
public function __construct(
|
||||||
private readonly EntityManagerInterface $entityManager,
|
private readonly EntityManagerInterface $entityManager,
|
||||||
private array $navLinks = []
|
private array $navLinks = []
|
||||||
@ -39,8 +29,6 @@ class CommunityResourceController extends AbstractController
|
|||||||
public function list(#[CurrentUser()] User $user): Response
|
public function list(#[CurrentUser()] User $user): Response
|
||||||
{
|
{
|
||||||
$rsc = $this->entityManager->getRepository(CommunityResource::class)->findAll();
|
$rsc = $this->entityManager->getRepository(CommunityResource::class)->findAll();
|
||||||
$this->msgs = $this->entityManager->getRepository(Messages::class)->getUnreadMessages($user);
|
|
||||||
$this->notificationCount = $this->entityManager->getRepository(Messages::class)->getUnreadMessageCount($user);
|
|
||||||
|
|
||||||
return $this->render(
|
return $this->render(
|
||||||
'internal/community_resource/list.html.twig',
|
'internal/community_resource/list.html.twig',
|
||||||
@ -51,8 +39,7 @@ class CommunityResourceController extends AbstractController
|
|||||||
new Breadcrumb('#', 'Community Resources')
|
new Breadcrumb('#', 'Community Resources')
|
||||||
],
|
],
|
||||||
'resources' => $rsc,
|
'resources' => $rsc,
|
||||||
'notifications' => $this->msgs,
|
'notifications' => $user->retrieveUnreadNotifications(),
|
||||||
'notificationCount' => $this->notificationCount,
|
|
||||||
]
|
]
|
||||||
)
|
)
|
||||||
);
|
);
|
||||||
@ -68,9 +55,6 @@ class CommunityResourceController extends AbstractController
|
|||||||
#[Route('/resource/add', name: 'app_community_resource_add')]
|
#[Route('/resource/add', name: 'app_community_resource_add')]
|
||||||
public function add(#[CurrentUser()] User $user, Request $request): Response
|
public function add(#[CurrentUser()] User $user, Request $request): Response
|
||||||
{
|
{
|
||||||
$this->msgs = $this->entityManager->getRepository(Messages::class)->getUnreadMessages($user);
|
|
||||||
$this->notificationCount = $this->entityManager->getRepository(Messages::class)->getUnreadMessageCount($user);
|
|
||||||
|
|
||||||
$form = $this->createForm(ResourceFormType::class);
|
$form = $this->createForm(ResourceFormType::class);
|
||||||
$form->handleRequest($request);
|
$form->handleRequest($request);
|
||||||
|
|
||||||
@ -79,8 +63,6 @@ class CommunityResourceController extends AbstractController
|
|||||||
$this->entityManager->persist($rsc);
|
$this->entityManager->persist($rsc);
|
||||||
$this->entityManager->flush();
|
$this->entityManager->flush();
|
||||||
|
|
||||||
$this->addFlash('success', 'Resource added successfully');
|
|
||||||
|
|
||||||
return $this->redirectToRoute('app_community_resource');
|
return $this->redirectToRoute('app_community_resource');
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -94,8 +76,7 @@ class CommunityResourceController extends AbstractController
|
|||||||
new Breadcrumb($this->generateUrl('app_community_resource'), 'List Resources'),
|
new Breadcrumb($this->generateUrl('app_community_resource'), 'List Resources'),
|
||||||
new Breadcrumb('#', 'Add Resource')
|
new Breadcrumb('#', 'Add Resource')
|
||||||
],
|
],
|
||||||
'notifications' => $this->msgs,
|
'notifications' => $user->retrieveUnreadNotifications(),
|
||||||
'notificationCount' => $this->notificationCount,
|
|
||||||
]
|
]
|
||||||
)
|
)
|
||||||
);
|
);
|
||||||
@ -105,9 +86,6 @@ class CommunityResourceController extends AbstractController
|
|||||||
#[Route('/resource/edit/{id}', name: 'app_community_resource_edit')]
|
#[Route('/resource/edit/{id}', name: 'app_community_resource_edit')]
|
||||||
public function edit(string $id, #[CurrentUser()] User $user, Request $request): Response
|
public function edit(string $id, #[CurrentUser()] User $user, Request $request): Response
|
||||||
{
|
{
|
||||||
$this->msgs = $this->entityManager->getRepository(Messages::class)->getUnreadMessages($user);
|
|
||||||
$this->notificationCount = $this->entityManager->getRepository(Messages::class)->getUnreadMessageCount($user);
|
|
||||||
|
|
||||||
$rsc = $this->entityManager->getRepository(CommunityResource::class)->find($id);
|
$rsc = $this->entityManager->getRepository(CommunityResource::class)->find($id);
|
||||||
$form = $this->createForm(ResourceFormType::class, $rsc);
|
$form = $this->createForm(ResourceFormType::class, $rsc);
|
||||||
|
|
||||||
@ -116,8 +94,6 @@ class CommunityResourceController extends AbstractController
|
|||||||
if ($form->isSubmitted() && $form->isValid()) {
|
if ($form->isSubmitted() && $form->isValid()) {
|
||||||
$this->entityManager->flush();
|
$this->entityManager->flush();
|
||||||
|
|
||||||
$this->addFlash('success', 'Resource updated successfully');
|
|
||||||
|
|
||||||
return $this->redirectToRoute('app_community_resource');
|
return $this->redirectToRoute('app_community_resource');
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -131,8 +107,7 @@ class CommunityResourceController extends AbstractController
|
|||||||
new Breadcrumb($this->generateUrl('app_community_resource'), 'List Resources'),
|
new Breadcrumb($this->generateUrl('app_community_resource'), 'List Resources'),
|
||||||
new Breadcrumb('#', 'Edit Resource')
|
new Breadcrumb('#', 'Edit Resource')
|
||||||
],
|
],
|
||||||
'notifications' => $this->msgs,
|
'notifications' => $user->retrieveUnreadNotifications(),
|
||||||
'notificationCount' => $this->notificationCount,
|
|
||||||
]
|
]
|
||||||
)
|
)
|
||||||
);
|
);
|
||||||
|
@ -2,9 +2,7 @@
|
|||||||
|
|
||||||
namespace App\Controller;
|
namespace App\Controller;
|
||||||
|
|
||||||
use App\Entity\Messages;
|
|
||||||
use App\Entity\User;
|
use App\Entity\User;
|
||||||
use App\Libs\Breadcrumb;
|
|
||||||
use App\Libs\NavList;
|
use App\Libs\NavList;
|
||||||
use Doctrine\ORM\EntityManagerInterface;
|
use Doctrine\ORM\EntityManagerInterface;
|
||||||
use Symfony\Bundle\FrameworkBundle\Controller\AbstractController;
|
use Symfony\Bundle\FrameworkBundle\Controller\AbstractController;
|
||||||
@ -16,14 +14,6 @@ use Symfony\Component\Security\Http\Attribute\CurrentUser;
|
|||||||
|
|
||||||
class DefaultController extends AbstractController
|
class DefaultController extends AbstractController
|
||||||
{
|
{
|
||||||
/**
|
|
||||||
* Variable to store unread notification messages
|
|
||||||
*
|
|
||||||
* @var array
|
|
||||||
*/
|
|
||||||
private array $msgs;
|
|
||||||
|
|
||||||
private int $notificationCount = 0;
|
|
||||||
|
|
||||||
public function __construct(
|
public function __construct(
|
||||||
private readonly EntityManagerInterface $entityManager,
|
private readonly EntityManagerInterface $entityManager,
|
||||||
@ -37,8 +27,6 @@ class DefaultController extends AbstractController
|
|||||||
public function dashboard(Request $request, #[CurrentUser()] ?User $user): Response
|
public function dashboard(Request $request, #[CurrentUser()] ?User $user): Response
|
||||||
{
|
{
|
||||||
$this->denyAccessUnlessGranted('IS_AUTHENTICATED_FULLY');
|
$this->denyAccessUnlessGranted('IS_AUTHENTICATED_FULLY');
|
||||||
$this->msgs = $this->entityManager->getRepository(Messages::class)->getUnreadMessages($user);
|
|
||||||
$this->notificationCount = $this->entityManager->getRepository(Messages::class)->getUnreadMessageCount($user);
|
|
||||||
|
|
||||||
if (!$user->getCompany()) {
|
if (!$user->getCompany()) {
|
||||||
return $this->redirectToRoute('app_register_step', ['step' => RegistrationController::REGISTER_STEP_TWO]);
|
return $this->redirectToRoute('app_register_step', ['step' => RegistrationController::REGISTER_STEP_TWO]);
|
||||||
@ -52,10 +40,9 @@ class DefaultController extends AbstractController
|
|||||||
$this->navLinks,
|
$this->navLinks,
|
||||||
[
|
[
|
||||||
'breadcrumbs' => [
|
'breadcrumbs' => [
|
||||||
new Breadcrumb('', 'Dashboard')
|
'Dashboard'
|
||||||
],
|
],
|
||||||
'notifications' => $this->msgs,
|
'notifications' => $user->retrieveUnreadNotifications(),
|
||||||
'notificationCount' => $this->notificationCount,
|
|
||||||
]
|
]
|
||||||
)
|
)
|
||||||
);
|
);
|
||||||
@ -65,8 +52,6 @@ class DefaultController extends AbstractController
|
|||||||
public function profile(#[CurrentUser()] User $user): Response
|
public function profile(#[CurrentUser()] User $user): Response
|
||||||
{
|
{
|
||||||
$this->denyAccessUnlessGranted('IS_AUTHENTICATED_FULLY');
|
$this->denyAccessUnlessGranted('IS_AUTHENTICATED_FULLY');
|
||||||
$this->msgs = $this->entityManager->getRepository(Messages::class)->getUnreadMessages($user);
|
|
||||||
$this->notificationCount = $this->entityManager->getRepository(Messages::class)->getUnreadMessageCount($user);
|
|
||||||
|
|
||||||
$this->navLinks['profile'] = NavList::PRESENT_LINK;
|
$this->navLinks['profile'] = NavList::PRESENT_LINK;
|
||||||
|
|
||||||
@ -76,10 +61,9 @@ class DefaultController extends AbstractController
|
|||||||
$this->navLinks,
|
$this->navLinks,
|
||||||
[
|
[
|
||||||
'breadcrumbs' => [
|
'breadcrumbs' => [
|
||||||
new Breadcrumb('', 'Profile')
|
'Profile'
|
||||||
],
|
],
|
||||||
'notifications' => $this->msgs,
|
'notifications' => $user->retrieveUnreadNotifications(),
|
||||||
'notificationCount' => $this->notificationCount,
|
|
||||||
]
|
]
|
||||||
)
|
)
|
||||||
);
|
);
|
||||||
|
@ -5,7 +5,6 @@ namespace App\Controller;
|
|||||||
use App\Entity\Member;
|
use App\Entity\Member;
|
||||||
use App\Entity\User;
|
use App\Entity\User;
|
||||||
use App\Entity\MemberCase;
|
use App\Entity\MemberCase;
|
||||||
use App\Entity\Messages;
|
|
||||||
use App\Form\MemberFormType;
|
use App\Form\MemberFormType;
|
||||||
use App\Libs\Breadcrumb;
|
use App\Libs\Breadcrumb;
|
||||||
use App\Libs\NavList;
|
use App\Libs\NavList;
|
||||||
@ -18,15 +17,6 @@ use Symfony\Component\Security\Http\Attribute\CurrentUser;
|
|||||||
|
|
||||||
class MemberController extends AbstractController
|
class MemberController extends AbstractController
|
||||||
{
|
{
|
||||||
/**
|
|
||||||
* Variable to store unread notification messages
|
|
||||||
*
|
|
||||||
* @var array
|
|
||||||
*/
|
|
||||||
private array $msgs;
|
|
||||||
|
|
||||||
private int $notificationCount;
|
|
||||||
|
|
||||||
public function __construct(
|
public function __construct(
|
||||||
private EntityManagerInterface $entityManager,
|
private EntityManagerInterface $entityManager,
|
||||||
private array $navLinks = [],
|
private array $navLinks = [],
|
||||||
@ -38,9 +28,6 @@ class MemberController extends AbstractController
|
|||||||
#[Route('/list-members/{id}', name: 'app_case_members')]
|
#[Route('/list-members/{id}', name: 'app_case_members')]
|
||||||
public function listMembers(Request $request, #[CurrentUser()] User $user, string $id): Response
|
public function listMembers(Request $request, #[CurrentUser()] User $user, string $id): Response
|
||||||
{
|
{
|
||||||
$this->msgs = $this->entityManager->getRepository(Messages::class)->getUnreadMessages($user);
|
|
||||||
$this->notificationCount = $this->entityManager->getRepository(Messages::class)->getUnreadMessageCount($user);
|
|
||||||
|
|
||||||
$case = $this->entityManager->getRepository(MemberCase::class)->find($id);
|
$case = $this->entityManager->getRepository(MemberCase::class)->find($id);
|
||||||
$members = $this->entityManager->getRepository(Member::class)->getCaseMembersByName($case);
|
$members = $this->entityManager->getRepository(Member::class)->getCaseMembersByName($case);
|
||||||
|
|
||||||
@ -53,10 +40,9 @@ class MemberController extends AbstractController
|
|||||||
new Breadcrumb($this->generateUrl('app_list_cases'), 'List Cases'),
|
new Breadcrumb($this->generateUrl('app_list_cases'), 'List Cases'),
|
||||||
new Breadcrumb($this->generateUrl('app_case_members', ['id' => $id]), 'List Members'),
|
new Breadcrumb($this->generateUrl('app_case_members', ['id' => $id]), 'List Members'),
|
||||||
],
|
],
|
||||||
'notifications' => $this->msgs,
|
'notifications' => $user->retrieveUnreadNotifications(),
|
||||||
'case' => $case,
|
'case' => $case,
|
||||||
'members' => $members,
|
'members' => $members,
|
||||||
'notificationCount' => $this->notificationCount,
|
|
||||||
]
|
]
|
||||||
)
|
)
|
||||||
);
|
);
|
||||||
@ -65,9 +51,6 @@ class MemberController extends AbstractController
|
|||||||
#[Route('/add-member/{id}', name: 'app_case_add_member')]
|
#[Route('/add-member/{id}', name: 'app_case_add_member')]
|
||||||
public function addMember(Request $request, #[CurrentUser()] User $user, string $id): Response
|
public function addMember(Request $request, #[CurrentUser()] User $user, string $id): Response
|
||||||
{
|
{
|
||||||
$this->msgs = $this->entityManager->getRepository(Messages::class)->getUnreadMessages($user);
|
|
||||||
$this->notificationCount = $this->entityManager->getRepository(Messages::class)->getUnreadMessageCount($user);
|
|
||||||
|
|
||||||
/** @var MemberCase $case */
|
/** @var MemberCase $case */
|
||||||
$case = $this->entityManager->getRepository(MemberCase::class)->find($id);
|
$case = $this->entityManager->getRepository(MemberCase::class)->find($id);
|
||||||
|
|
||||||
@ -127,10 +110,9 @@ class MemberController extends AbstractController
|
|||||||
new Breadcrumb($this->generateUrl('app_case_members', ['id' => $id]), 'List Members'),
|
new Breadcrumb($this->generateUrl('app_case_members', ['id' => $id]), 'List Members'),
|
||||||
new Breadcrumb($this->generateUrl('app_case_add_member', ['id' => $id]), 'Add Member'),
|
new Breadcrumb($this->generateUrl('app_case_add_member', ['id' => $id]), 'Add Member'),
|
||||||
],
|
],
|
||||||
'notifications' => $this->msgs,
|
'notifications' => $user->retrieveUnreadNotifications(),
|
||||||
'case' => $case,
|
'case' => $case,
|
||||||
'form' => $form->createView(),
|
'form' => $form->createView(),
|
||||||
'notificationCount' => $this->notificationCount,
|
|
||||||
]
|
]
|
||||||
)
|
)
|
||||||
);
|
);
|
||||||
@ -139,9 +121,6 @@ class MemberController extends AbstractController
|
|||||||
#[Route('/case/{caseId}/edit-member/{memberId}', name: 'app_case_edit_member')]
|
#[Route('/case/{caseId}/edit-member/{memberId}', name: 'app_case_edit_member')]
|
||||||
public function editMember(Request $request, #[CurrentUser()] User $user, string $caseId, string $memberId): Response
|
public function editMember(Request $request, #[CurrentUser()] User $user, string $caseId, string $memberId): Response
|
||||||
{
|
{
|
||||||
$this->msgs = $this->entityManager->getRepository(Messages::class)->getUnreadMessages($user);
|
|
||||||
$this->notificationCount = $this->entityManager->getRepository(Messages::class)->getUnreadMessageCount($user);
|
|
||||||
|
|
||||||
$member = $this->entityManager->getRepository(Member::class)->find($memberId);
|
$member = $this->entityManager->getRepository(Member::class)->find($memberId);
|
||||||
|
|
||||||
$form = $this->createForm(MemberFormType::class, $member);
|
$form = $this->createForm(MemberFormType::class, $member);
|
||||||
@ -196,8 +175,7 @@ class MemberController extends AbstractController
|
|||||||
new Breadcrumb($this->generateUrl('app_case_members', ['id' => $caseId]), 'List Members'),
|
new Breadcrumb($this->generateUrl('app_case_members', ['id' => $caseId]), 'List Members'),
|
||||||
new Breadcrumb($this->generateUrl('app_case_edit_member', ['caseId' => $caseId, 'memberId' => $memberId]), 'Edit Member'),
|
new Breadcrumb($this->generateUrl('app_case_edit_member', ['caseId' => $caseId, 'memberId' => $memberId]), 'Edit Member'),
|
||||||
],
|
],
|
||||||
'notifications' => $this->msgs,
|
'notifications' => $user->retrieveUnreadNotifications(),
|
||||||
'notificationCount' => $this->notificationCount,
|
|
||||||
'member' => $member,
|
'member' => $member,
|
||||||
'form' => $form->createView(),
|
'form' => $form->createView(),
|
||||||
'caseId' => $caseId,
|
'caseId' => $caseId,
|
||||||
|
@ -1,30 +0,0 @@
|
|||||||
<?php
|
|
||||||
|
|
||||||
namespace App\Controller;
|
|
||||||
|
|
||||||
use App\Entity\Messages;
|
|
||||||
use App\Entity\User;
|
|
||||||
use Doctrine\ORM\EntityManagerInterface;
|
|
||||||
use Symfony\Component\HttpFoundation\Request;
|
|
||||||
use Symfony\Component\HttpFoundation\Response;
|
|
||||||
use Symfony\Component\Routing\Annotation\Route;
|
|
||||||
use Symfony\Bundle\FrameworkBundle\Controller\AbstractController;
|
|
||||||
use Symfony\Component\HttpFoundation\JsonResponse;
|
|
||||||
|
|
||||||
class MessageController extends AbstractController
|
|
||||||
{
|
|
||||||
public function __construct(
|
|
||||||
private EntityManagerInterface $entityManager
|
|
||||||
) {
|
|
||||||
}
|
|
||||||
|
|
||||||
#[Route('/api/notifications/{msgId}', name: 'app_read_message')]
|
|
||||||
public function readMessage(string $msgId): Response
|
|
||||||
{
|
|
||||||
$message = $this->entityManager->getRepository(Messages::class)->find($msgId);
|
|
||||||
$message->setReceived(new \DateTimeImmutable());
|
|
||||||
$this->entityManager->flush();
|
|
||||||
|
|
||||||
return new JsonResponse(true, Response::HTTP_OK);
|
|
||||||
}
|
|
||||||
}
|
|
@ -3,7 +3,6 @@
|
|||||||
namespace App\Controller;
|
namespace App\Controller;
|
||||||
|
|
||||||
use App\Entity\Member;
|
use App\Entity\Member;
|
||||||
use App\Entity\Messages;
|
|
||||||
use App\Entity\Referral;
|
use App\Entity\Referral;
|
||||||
use App\Entity\StandardNote;
|
use App\Entity\StandardNote;
|
||||||
use App\Entity\User;
|
use App\Entity\User;
|
||||||
@ -25,15 +24,6 @@ use Symfony\Component\Security\Http\Attribute\CurrentUser;
|
|||||||
|
|
||||||
class NoteController extends AbstractController
|
class NoteController extends AbstractController
|
||||||
{
|
{
|
||||||
/**
|
|
||||||
* Variable to store unread notification messages
|
|
||||||
*
|
|
||||||
* @var array
|
|
||||||
*/
|
|
||||||
private array $msgs;
|
|
||||||
|
|
||||||
private int $notificationCount;
|
|
||||||
|
|
||||||
public function __construct(
|
public function __construct(
|
||||||
private EntityManagerInterface $entityManager,
|
private EntityManagerInterface $entityManager,
|
||||||
private array $navLinks = [],
|
private array $navLinks = [],
|
||||||
@ -45,9 +35,6 @@ class NoteController extends AbstractController
|
|||||||
#[Route('/list-notes/{id?null}', name: 'app_list_notes')]
|
#[Route('/list-notes/{id?null}', name: 'app_list_notes')]
|
||||||
public function listNotes(#[CurrentUser()] User $user, ?string $id = null): Response
|
public function listNotes(#[CurrentUser()] User $user, ?string $id = null): Response
|
||||||
{
|
{
|
||||||
$this->msgs = $this->entityManager->getRepository(Messages::class)->getUnreadMessages($user);
|
|
||||||
$this->notificationCount = $this->entityManager->getRepository(Messages::class)->getUnreadMessageCount($user);
|
|
||||||
|
|
||||||
/** @var UserCase[] $cases */
|
/** @var UserCase[] $cases */
|
||||||
$cases = $this->entityManager->getRepository(UserCase::class)->findBy(['user' => $user]);
|
$cases = $this->entityManager->getRepository(UserCase::class)->findBy(['user' => $user]);
|
||||||
$referrals = [];
|
$referrals = [];
|
||||||
@ -84,10 +71,9 @@ class NoteController extends AbstractController
|
|||||||
'breadcrumbs' => [
|
'breadcrumbs' => [
|
||||||
new Breadcrumb($this->generateUrl('app_list_notes'), 'List Notes')
|
new Breadcrumb($this->generateUrl('app_list_notes'), 'List Notes')
|
||||||
],
|
],
|
||||||
'notifications' => $this->msgs,
|
'notifications' => $user->retrieveUnreadNotifications(),
|
||||||
'cases' => $cases,
|
'cases' => $cases,
|
||||||
'notes' => $notes,
|
'notes' => $notes,
|
||||||
'notificationCount' => $this->notificationCount,
|
|
||||||
]
|
]
|
||||||
)
|
)
|
||||||
);
|
);
|
||||||
@ -99,8 +85,8 @@ class NoteController extends AbstractController
|
|||||||
/** @var Referral $referral */
|
/** @var Referral $referral */
|
||||||
$referral = $this->entityManager->getRepository(Referral::class)->find($id);
|
$referral = $this->entityManager->getRepository(Referral::class)->find($id);
|
||||||
$this->entityManager->getRepository(Referral::class)->populateNotes($referral);
|
$this->entityManager->getRepository(Referral::class)->populateNotes($referral);
|
||||||
$this->msgs = $this->entityManager->getRepository(Messages::class)->getUnreadMessages($user);
|
|
||||||
$this->notificationCount = $this->entityManager->getRepository(Messages::class)->getUnreadMessageCount($user);
|
//dd($referral);
|
||||||
|
|
||||||
$members = $this->entityManager->getRepository(Member::class)->findBy(['caseId' => $referral->getMemberCase()]);
|
$members = $this->entityManager->getRepository(Member::class)->findBy(['caseId' => $referral->getMemberCase()]);
|
||||||
$defaultMethod = NoteMethod::BILLABLE;
|
$defaultMethod = NoteMethod::BILLABLE;
|
||||||
@ -142,31 +128,23 @@ class NoteController extends AbstractController
|
|||||||
'breadcrumbs' => [
|
'breadcrumbs' => [
|
||||||
new Breadcrumb($this->generateUrl('app_list_notes'), 'List Notes')
|
new Breadcrumb($this->generateUrl('app_list_notes'), 'List Notes')
|
||||||
],
|
],
|
||||||
'notifications' => $this->msgs,
|
'notifications' => $user->retrieveUnreadNotifications(),
|
||||||
'referral' => $referral,
|
'referral' => $referral,
|
||||||
'form' => $form,
|
'form' => $form,
|
||||||
'default_method' => $defaultMethod,
|
'default_method' => $defaultMethod,
|
||||||
'default_location' => $defaultLocation,
|
'default_location' => $defaultLocation,
|
||||||
'notificationCount' => $this->notificationCount,
|
|
||||||
]
|
]
|
||||||
)
|
)
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
#[Route('/edit-note/{noteId}', name: 'app_edit_note')]
|
#[Route('/edit-note', name: 'app_edit_note')]
|
||||||
public function editNote(string $noteId, #[CurrentUser()] User $user, Request $request): Response
|
public function editNote(): Response
|
||||||
{
|
{
|
||||||
$this->msgs = $this->entityManager->getRepository(Messages::class)->getUnreadMessages($user);
|
|
||||||
$this->notificationCount = $this->entityManager->getRepository(Messages::class)->getUnreadMessageCount($user);
|
|
||||||
|
|
||||||
return $this->render(
|
return $this->render(
|
||||||
'internal/cases/notes/edit-note.html.twig',
|
'internal/cases/notes/edit-note.html.twig',
|
||||||
array_merge(
|
array_merge(
|
||||||
$this->navLinks,
|
$this->navLinks,
|
||||||
[
|
|
||||||
'notifications' => $this->msgs,
|
|
||||||
'notificationCount' => $this->notificationCount,
|
|
||||||
]
|
|
||||||
)
|
)
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
@ -3,11 +3,8 @@
|
|||||||
namespace App\Controller;
|
namespace App\Controller;
|
||||||
|
|
||||||
use App\Entity\MemberCase;
|
use App\Entity\MemberCase;
|
||||||
use App\Entity\Messages;
|
|
||||||
use App\Entity\Referral;
|
use App\Entity\Referral;
|
||||||
use App\Entity\User;
|
use App\Entity\User;
|
||||||
use App\Entity\UserCase;
|
|
||||||
use App\Factory\MessageFactory;
|
|
||||||
use App\Form\ReferralFormType;
|
use App\Form\ReferralFormType;
|
||||||
use App\Libs\Breadcrumb;
|
use App\Libs\Breadcrumb;
|
||||||
use App\Libs\NavList;
|
use App\Libs\NavList;
|
||||||
@ -20,15 +17,6 @@ use Symfony\Component\Security\Http\Attribute\CurrentUser;
|
|||||||
|
|
||||||
class ReferralController extends AbstractController
|
class ReferralController extends AbstractController
|
||||||
{
|
{
|
||||||
/**
|
|
||||||
* Variable to store unread notification messages
|
|
||||||
*
|
|
||||||
* @var array
|
|
||||||
*/
|
|
||||||
private array $msgs;
|
|
||||||
|
|
||||||
private int $notificationCount;
|
|
||||||
|
|
||||||
public function __construct(
|
public function __construct(
|
||||||
private EntityManagerInterface $entityManager,
|
private EntityManagerInterface $entityManager,
|
||||||
private array $navLinks = []
|
private array $navLinks = []
|
||||||
@ -38,11 +26,8 @@ class ReferralController extends AbstractController
|
|||||||
}
|
}
|
||||||
|
|
||||||
#[Route('/list-referrals/{id}', name: 'app_list_referrals')]
|
#[Route('/list-referrals/{id}', name: 'app_list_referrals')]
|
||||||
public function listReferrals(#[CurrentUser()] User $user, string $id): Response
|
public function listReferrals(Request $request, #[CurrentUser()] User $user, string $id): Response
|
||||||
{
|
{
|
||||||
$this->msgs = $this->entityManager->getRepository(Messages::class)->getUnreadMessages($user);
|
|
||||||
$this->notificationCount = $this->entityManager->getRepository(Messages::class)->getUnreadMessageCount($user);
|
|
||||||
|
|
||||||
$case = $this->entityManager->getRepository(MemberCase::class)->find($id);
|
$case = $this->entityManager->getRepository(MemberCase::class)->find($id);
|
||||||
$openReferrals = $this->entityManager->getRepository(Referral::class)->getActiveReferrals($case);
|
$openReferrals = $this->entityManager->getRepository(Referral::class)->getActiveReferrals($case);
|
||||||
$closedReferrals = $this->entityManager->getRepository(Referral::class)->getClosedReferrals($case);
|
$closedReferrals = $this->entityManager->getRepository(Referral::class)->getClosedReferrals($case);
|
||||||
@ -56,8 +41,7 @@ class ReferralController extends AbstractController
|
|||||||
new Breadcrumb($this->generateUrl('app_list_cases'), 'List Cases'),
|
new Breadcrumb($this->generateUrl('app_list_cases'), 'List Cases'),
|
||||||
new Breadcrumb($this->generateUrl('app_list_referrals', ['id' => $case->getId()]), 'Referrals'),
|
new Breadcrumb($this->generateUrl('app_list_referrals', ['id' => $case->getId()]), 'Referrals'),
|
||||||
],
|
],
|
||||||
'notifications' => $this->msgs,
|
'notifications' => $user->retrieveUnreadNotifications(),
|
||||||
'notificationCount' => $this->notificationCount,
|
|
||||||
'case' => $case,
|
'case' => $case,
|
||||||
'openReferrals' => $openReferrals,
|
'openReferrals' => $openReferrals,
|
||||||
'closedReferrals' => $closedReferrals,
|
'closedReferrals' => $closedReferrals,
|
||||||
@ -69,13 +53,7 @@ class ReferralController extends AbstractController
|
|||||||
#[Route('/add-referral/{id}', name: 'app_case_add_referral')]
|
#[Route('/add-referral/{id}', name: 'app_case_add_referral')]
|
||||||
public function addReferral(Request $request, #[CurrentUser()] User $user, string $id): Response
|
public function addReferral(Request $request, #[CurrentUser()] User $user, string $id): Response
|
||||||
{
|
{
|
||||||
$this->denyAccessUnlessGranted(['ROLE_ADMIN', 'ROLE_CASE_MANAGER']);
|
|
||||||
$this->msgs = $this->entityManager->getRepository(Messages::class)->getUnreadMessages($user);
|
|
||||||
$this->notificationCount = $this->entityManager->getRepository(Messages::class)->getUnreadMessageCount($user);
|
|
||||||
|
|
||||||
$case = $this->entityManager->getRepository(MemberCase::class)->find($id);
|
$case = $this->entityManager->getRepository(MemberCase::class)->find($id);
|
||||||
/** @var UserCase $uc */
|
|
||||||
$uc = $this->entityManager->getRepository(UserCase::class)->findBy(['memberCase' => $case]);
|
|
||||||
|
|
||||||
$referral = new Referral();
|
$referral = new Referral();
|
||||||
$form = $this->createForm(ReferralFormType::class, $referral);
|
$form = $this->createForm(ReferralFormType::class, $referral);
|
||||||
@ -86,9 +64,6 @@ class ReferralController extends AbstractController
|
|||||||
$referral = $form->getData();
|
$referral = $form->getData();
|
||||||
$referral->setMemberCase($case);
|
$referral->setMemberCase($case);
|
||||||
|
|
||||||
$msg = MessageFactory::createReferral($user, $uc->getUser(), $case);
|
|
||||||
|
|
||||||
$this->entityManager->persist($msg);
|
|
||||||
$this->entityManager->persist($referral);
|
$this->entityManager->persist($referral);
|
||||||
$this->entityManager->flush();
|
$this->entityManager->flush();
|
||||||
|
|
||||||
@ -105,8 +80,7 @@ class ReferralController extends AbstractController
|
|||||||
new Breadcrumb($this->generateUrl('app_list_referrals', ['id' => $case->getId()]), 'Referrals'),
|
new Breadcrumb($this->generateUrl('app_list_referrals', ['id' => $case->getId()]), 'Referrals'),
|
||||||
new Breadcrumb($this->generateUrl('app_case_add_referral', ['id' => $case->getId()]), 'Add Referral')
|
new Breadcrumb($this->generateUrl('app_case_add_referral', ['id' => $case->getId()]), 'Add Referral')
|
||||||
],
|
],
|
||||||
'notifications' => $this->msgs,
|
'notifications' => $user->retrieveUnreadNotifications(),
|
||||||
'notificationCount' => $this->notificationCount,
|
|
||||||
'case' => $case,
|
'case' => $case,
|
||||||
'form' => $form,
|
'form' => $form,
|
||||||
]
|
]
|
||||||
@ -117,14 +91,8 @@ class ReferralController extends AbstractController
|
|||||||
#[Route('/case/{caseId}/edit-referral/{referralId}', name: 'app_case_edit_referral')]
|
#[Route('/case/{caseId}/edit-referral/{referralId}', name: 'app_case_edit_referral')]
|
||||||
public function editReferral(Request $request, #[CurrentUser()] User $user, string $caseId, string $referralId): Response
|
public function editReferral(Request $request, #[CurrentUser()] User $user, string $caseId, string $referralId): Response
|
||||||
{
|
{
|
||||||
$this->denyAccessUnlessGranted(['ROLE_ADMIN', 'ROLE_CASE_MANAGER']);
|
|
||||||
$this->msgs = $this->entityManager->getRepository(Messages::class)->getUnreadMessages($user);
|
|
||||||
$this->notificationCount = $this->entityManager->getRepository(Messages::class)->getUnreadMessageCount($user);
|
|
||||||
|
|
||||||
$referral = $this->entityManager->getRepository(Referral::class)->find($referralId);
|
$referral = $this->entityManager->getRepository(Referral::class)->find($referralId);
|
||||||
$case = $this->entityManager->getRepository(MemberCase::class)->find($caseId);
|
$case = $this->entityManager->getRepository(MemberCase::class)->find($caseId);
|
||||||
/** @var UserCase $uc */
|
|
||||||
$uc = $this->entityManager->getRepository(UserCase::class)->findBy(['case' => $case]);
|
|
||||||
|
|
||||||
$form = $this->createForm(ReferralFormType::class, $referral);
|
$form = $this->createForm(ReferralFormType::class, $referral);
|
||||||
$form->handleRequest($request);
|
$form->handleRequest($request);
|
||||||
@ -132,9 +100,6 @@ class ReferralController extends AbstractController
|
|||||||
if ($form->isSubmitted() && $form->isValid()) {
|
if ($form->isSubmitted() && $form->isValid()) {
|
||||||
$referral = $form->getData();
|
$referral = $form->getData();
|
||||||
|
|
||||||
$msg = MessageFactory::createReferral($user, $uc->getUser(), $case);
|
|
||||||
|
|
||||||
$this->entityManager->persist($msg);
|
|
||||||
$this->entityManager->flush();
|
$this->entityManager->flush();
|
||||||
|
|
||||||
return $this->redirectToRoute('app_list_referrals', ['id' => $case->getId()]);
|
return $this->redirectToRoute('app_list_referrals', ['id' => $case->getId()]);
|
||||||
@ -150,8 +115,7 @@ class ReferralController extends AbstractController
|
|||||||
new Breadcrumb($this->generateUrl('app_list_referrals', ['id' => $case->getId()]), 'Referrals'),
|
new Breadcrumb($this->generateUrl('app_list_referrals', ['id' => $case->getId()]), 'Referrals'),
|
||||||
new Breadcrumb($this->generateUrl('app_case_edit_referral', ['caseId' => $case->getId(), 'referralId' => $referral->getId()]), 'Edit Referral'),
|
new Breadcrumb($this->generateUrl('app_case_edit_referral', ['caseId' => $case->getId(), 'referralId' => $referral->getId()]), 'Edit Referral'),
|
||||||
],
|
],
|
||||||
'notifications' => $this->msgs,
|
'notifications' => $user->retrieveUnreadNotifications(),
|
||||||
'notificationCount' => $this->notificationCount,
|
|
||||||
'case' => $case,
|
'case' => $case,
|
||||||
'form' => $form,
|
'form' => $form,
|
||||||
'referral' => $referral,
|
'referral' => $referral,
|
||||||
|
@ -2,7 +2,6 @@
|
|||||||
|
|
||||||
namespace App\Controller;
|
namespace App\Controller;
|
||||||
|
|
||||||
use App\Entity\Messages;
|
|
||||||
use App\Entity\ReferralSource;
|
use App\Entity\ReferralSource;
|
||||||
use App\Entity\User;
|
use App\Entity\User;
|
||||||
use App\Form\ReferralSourceFormType;
|
use App\Form\ReferralSourceFormType;
|
||||||
@ -17,15 +16,6 @@ use Symfony\Component\Security\Http\Attribute\CurrentUser;
|
|||||||
|
|
||||||
class ReferralSourceController extends AbstractController
|
class ReferralSourceController extends AbstractController
|
||||||
{
|
{
|
||||||
/**
|
|
||||||
* Variable to store unread notification messages
|
|
||||||
*
|
|
||||||
* @var array
|
|
||||||
*/
|
|
||||||
private array $msgs;
|
|
||||||
|
|
||||||
private int $notificationCount;
|
|
||||||
|
|
||||||
public function __construct(
|
public function __construct(
|
||||||
private EntityManagerInterface $entityManager,
|
private EntityManagerInterface $entityManager,
|
||||||
private array $navList = []
|
private array $navList = []
|
||||||
@ -38,8 +28,6 @@ class ReferralSourceController extends AbstractController
|
|||||||
public function listReferralSources(#[CurrentUser()] User $user): Response
|
public function listReferralSources(#[CurrentUser()] User $user): Response
|
||||||
{
|
{
|
||||||
$this->denyAccessUnlessGranted('ROLE_ADMIN');
|
$this->denyAccessUnlessGranted('ROLE_ADMIN');
|
||||||
$this->msgs = $this->entityManager->getRepository(Messages::class)->getUnreadMessages($user);
|
|
||||||
$this->notificationCount = $this->entityManager->getRepository(Messages::class)->getUnreadMessageCount($user);
|
|
||||||
|
|
||||||
$sources = $this->entityManager->getRepository(ReferralSource::class)->retrieveOrderedList();
|
$sources = $this->entityManager->getRepository(ReferralSource::class)->retrieveOrderedList();
|
||||||
|
|
||||||
@ -49,8 +37,7 @@ class ReferralSourceController extends AbstractController
|
|||||||
$this->navList,
|
$this->navList,
|
||||||
[
|
[
|
||||||
'sources' => $sources,
|
'sources' => $sources,
|
||||||
'notifications' => $this->msgs,
|
'notifications' => $user->retrieveUnreadNotifications(),
|
||||||
'notificationCount' => $this->notificationCount,
|
|
||||||
'breadcrumbs' => [
|
'breadcrumbs' => [
|
||||||
new Breadcrumb($this->generateUrl('app_referral_source'), 'Referral Sources')
|
new Breadcrumb($this->generateUrl('app_referral_source'), 'Referral Sources')
|
||||||
]
|
]
|
||||||
@ -63,8 +50,6 @@ class ReferralSourceController extends AbstractController
|
|||||||
public function addSource(Request $request, #[CurrentUser()] User $user): Response
|
public function addSource(Request $request, #[CurrentUser()] User $user): Response
|
||||||
{
|
{
|
||||||
$this->denyAccessUnlessGranted('ROLE_ADMIN');
|
$this->denyAccessUnlessGranted('ROLE_ADMIN');
|
||||||
$this->msgs = $this->entityManager->getRepository(Messages::class)->getUnreadMessages($user);
|
|
||||||
$this->notificationCount = $this->entityManager->getRepository(Messages::class)->getUnreadMessageCount($user);
|
|
||||||
|
|
||||||
$rs = new ReferralSource();
|
$rs = new ReferralSource();
|
||||||
$form = $this->createForm(ReferralSourceFormType::class, $rs);
|
$form = $this->createForm(ReferralSourceFormType::class, $rs);
|
||||||
@ -88,8 +73,7 @@ class ReferralSourceController extends AbstractController
|
|||||||
$this->navList,
|
$this->navList,
|
||||||
[
|
[
|
||||||
'form' => $form,
|
'form' => $form,
|
||||||
'notifications' => $this->msgs,
|
'notifications' => $user->retrieveUnreadNotifications(),
|
||||||
'notificationCount' => $this->notificationCount,
|
|
||||||
'breadcrumbs' => [
|
'breadcrumbs' => [
|
||||||
new Breadcrumb($this->generateUrl('app_referral_source'), 'Referral Sources'),
|
new Breadcrumb($this->generateUrl('app_referral_source'), 'Referral Sources'),
|
||||||
new Breadcrumb($this->generateUrl('app_add_source'), 'Add Source')
|
new Breadcrumb($this->generateUrl('app_add_source'), 'Add Source')
|
||||||
@ -103,8 +87,6 @@ class ReferralSourceController extends AbstractController
|
|||||||
public function editSource(Request $request, #[CurrentUser()] User $user, string $id): Response
|
public function editSource(Request $request, #[CurrentUser()] User $user, string $id): Response
|
||||||
{
|
{
|
||||||
$this->denyAccessUnlessGranted('ROLE_ADMIN');
|
$this->denyAccessUnlessGranted('ROLE_ADMIN');
|
||||||
$this->msgs = $this->entityManager->getRepository(Messages::class)->getUnreadMessages($user);
|
|
||||||
$this->notificationCount = $this->entityManager->getRepository(Messages::class)->getUnreadMessageCount($user);
|
|
||||||
|
|
||||||
$rs = $this->entityManager->getRepository(ReferralSource::class)->find($id);
|
$rs = $this->entityManager->getRepository(ReferralSource::class)->find($id);
|
||||||
|
|
||||||
@ -129,8 +111,7 @@ class ReferralSourceController extends AbstractController
|
|||||||
[
|
[
|
||||||
'form' => $form,
|
'form' => $form,
|
||||||
'rs' => $rs,
|
'rs' => $rs,
|
||||||
'notifications' => $this->msgs,
|
'notifications' => $user->retrieveUnreadNotifications(),
|
||||||
'notificationCount' => $this->notificationCount,
|
|
||||||
'breadcrumbs' => [
|
'breadcrumbs' => [
|
||||||
new Breadcrumb($this->generateUrl('app_referral_source'), 'Referral Sources'),
|
new Breadcrumb($this->generateUrl('app_referral_source'), 'Referral Sources'),
|
||||||
new Breadcrumb($this->generateUrl('app_edit_source', ['id' => $id]), 'Edit Source')
|
new Breadcrumb($this->generateUrl('app_edit_source', ['id' => $id]), 'Edit Source')
|
||||||
|
@ -2,35 +2,21 @@
|
|||||||
|
|
||||||
namespace App\Controller;
|
namespace App\Controller;
|
||||||
|
|
||||||
use App\Entity\MemberCase;
|
|
||||||
use App\Entity\Messages;
|
|
||||||
use App\Entity\StaffNote;
|
|
||||||
use App\Entity\Supervision;
|
|
||||||
use App\Entity\User;
|
use App\Entity\User;
|
||||||
use App\Entity\UserCase;
|
|
||||||
use App\Form\StaffNoteFormType;
|
|
||||||
use App\Libs\Breadcrumb;
|
use App\Libs\Breadcrumb;
|
||||||
use App\Libs\NavList;
|
use App\Libs\NavList;
|
||||||
use Doctrine\ORM\EntityManagerInterface;
|
use Doctrine\ORM\EntityManagerInterface;
|
||||||
use Symfony\Bundle\FrameworkBundle\Controller\AbstractController;
|
use Symfony\Bundle\FrameworkBundle\Controller\AbstractController;
|
||||||
use Symfony\Component\HttpFoundation\Request;
|
|
||||||
use Symfony\Component\HttpFoundation\Response;
|
use Symfony\Component\HttpFoundation\Response;
|
||||||
|
use Symfony\Component\PasswordHasher\Hasher\UserPasswordHasherInterface;
|
||||||
use Symfony\Component\Routing\Annotation\Route;
|
use Symfony\Component\Routing\Annotation\Route;
|
||||||
use Symfony\Component\Security\Http\Attribute\CurrentUser;
|
use Symfony\Component\Security\Http\Attribute\CurrentUser;
|
||||||
|
|
||||||
class StaffController extends AbstractController
|
class StaffController extends AbstractController
|
||||||
{
|
{
|
||||||
/**
|
|
||||||
* Variable to store unread notification messages
|
|
||||||
*
|
|
||||||
* @var array <int, Message>
|
|
||||||
*/
|
|
||||||
private array $msgs;
|
|
||||||
|
|
||||||
private int $notificationCount;
|
|
||||||
|
|
||||||
public function __construct(
|
public function __construct(
|
||||||
private readonly EntityManagerInterface $entityManager,
|
private readonly EntityManagerInterface $entityManager,
|
||||||
|
private readonly UserPasswordHasherInterface $userPasswordHasher,
|
||||||
private array $navLinks = []
|
private array $navLinks = []
|
||||||
) {
|
) {
|
||||||
$this->navLinks = NavList::LIST;
|
$this->navLinks = NavList::LIST;
|
||||||
@ -40,203 +26,17 @@ class StaffController extends AbstractController
|
|||||||
#[Route('/staff-dashboard', name: 'app_staff_dashboard')]
|
#[Route('/staff-dashboard', name: 'app_staff_dashboard')]
|
||||||
public function staffDashboard(#[CurrentUser()] User $user): Response
|
public function staffDashboard(#[CurrentUser()] User $user): Response
|
||||||
{
|
{
|
||||||
$this->msgs = $this->entityManager->getRepository(Messages::class)->getUnreadMessages($user);
|
|
||||||
$this->notificationCount = $this->entityManager->getRepository(Messages::class)->getUnreadMessageCount($user);
|
|
||||||
|
|
||||||
$sups = $this->entityManager->getRepository(Supervision::class)->findBy(['supervisor' => $user]);
|
|
||||||
$staff = [];
|
|
||||||
|
|
||||||
foreach ($sups as $sup) {
|
|
||||||
$staff[] = $sup->getWorker();
|
|
||||||
}
|
|
||||||
|
|
||||||
return $this->render(
|
return $this->render(
|
||||||
'internal/staff/staff-dashboard.html.twig',
|
'internal/staff/staff-dashboard.html.twig',
|
||||||
array_merge(
|
array_merge(
|
||||||
$this->navLinks,
|
$this->navLinks,
|
||||||
[
|
[
|
||||||
'staff' => $staff,
|
|
||||||
'breadcrumbs' => [
|
'breadcrumbs' => [
|
||||||
new Breadcrumb('', 'Staff Dashboard')
|
new Breadcrumb('', 'Staff Dashboard')
|
||||||
],
|
],
|
||||||
'notifications' => $this->msgs,
|
'notifications' => $user->retrieveUnreadNotifications(),
|
||||||
'notificationCount' => $this->notificationCount,
|
|
||||||
]
|
]
|
||||||
)
|
)
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
#[Route('/staff/my-cases', name:'app_staff_my_cases')]
|
|
||||||
public function staffMyCases(#[CurrentUser()] User $user): Response
|
|
||||||
{
|
|
||||||
$this->denyAccessUnlessGranted('IS_FULLY_AUTHENTICATED');
|
|
||||||
$this->msgs = $this->entityManager->getRepository(Messages::class)->getUnreadMessages($user);
|
|
||||||
$this->notificationCount = $this->entityManager->getRepository(Messages::class)->getUnreadMessageCount($user);
|
|
||||||
|
|
||||||
$ucs = $this->entityManager->getRepository(UserCase::class)->findBy(['user' => $user]);
|
|
||||||
$cases = [];
|
|
||||||
$this->navLinks['staff_dashboard'] = 'nav-link text-dark';
|
|
||||||
$this->navLinks['staff_notes'] = NavList::PRESENT_LINK;
|
|
||||||
|
|
||||||
foreach ($ucs as $uc) {
|
|
||||||
$cases[] = $uc->getMemberCase();
|
|
||||||
}
|
|
||||||
|
|
||||||
return $this->render(
|
|
||||||
'internal/staff/cases/my-cases.html.twig',
|
|
||||||
array_merge(
|
|
||||||
$this->navLinks,
|
|
||||||
[
|
|
||||||
'cases' => $cases,
|
|
||||||
'user' => $user,
|
|
||||||
'breadcrumbs' => [
|
|
||||||
new Breadcrumb($this->generateUrl('app_staff_dashboard'), 'Staff Dashboard'),
|
|
||||||
new Breadcrumb('', 'Staff Cases')
|
|
||||||
],
|
|
||||||
'notifications' => $this->msgs,
|
|
||||||
'notificationCount' => $this->notificationCount,
|
|
||||||
]
|
|
||||||
)
|
|
||||||
);
|
|
||||||
}
|
|
||||||
|
|
||||||
#[Route('/staff/{staffId}', name: 'app_staff_cases')]
|
|
||||||
public function staffCases(string $staffId, #[CurrentUser()] User $user): Response
|
|
||||||
{
|
|
||||||
$this->denyAccessUnlessGranted(['ROLE_ADMIN', 'ROLE_CASE_MANAGER']);
|
|
||||||
$this->msgs = $this->entityManager->getRepository(Messages::class)->getUnreadMessages($user);
|
|
||||||
$this->notificationCount = $this->entityManager->getRepository(Messages::class)->getUnreadMessageCount($user);
|
|
||||||
|
|
||||||
$staff = $this->entityManager->getRepository(User::class)->find($staffId);
|
|
||||||
$ucs = $this->entityManager->getRepository(UserCase::class)->findBy(['user' => $staff]);
|
|
||||||
$cases = [];
|
|
||||||
|
|
||||||
foreach ($ucs as $case) {
|
|
||||||
/** @var UserCase $case */
|
|
||||||
$cases[] = $case->getMemberCase();
|
|
||||||
}
|
|
||||||
|
|
||||||
return $this->render(
|
|
||||||
'internal/staff/cases/staff-cases.html.twig',
|
|
||||||
array_merge(
|
|
||||||
$this->navLinks,
|
|
||||||
[
|
|
||||||
'staffId' => $staffId,
|
|
||||||
'cases' => $cases,
|
|
||||||
'breadcrumbs' => [
|
|
||||||
new Breadcrumb($this->generateUrl('app_staff_dashboard'), 'Staff Dashboard'),
|
|
||||||
new Breadcrumb('', 'Staff Cases')
|
|
||||||
],
|
|
||||||
'notifications' => $this->msgs,
|
|
||||||
'notificationCount' => $this->notificationCount,
|
|
||||||
]
|
|
||||||
)
|
|
||||||
);
|
|
||||||
}
|
|
||||||
|
|
||||||
#[Route('/staff/{staffId}/case/{caseId}/list-notes', name: 'app_staff_list_notes')]
|
|
||||||
public function staffListNotes(string $staffId, string $caseId, #[CurrentUser()] User $user): Response
|
|
||||||
{
|
|
||||||
$this->denyAccessUnlessGranted('IS_FULLY_AUTHENTICATED');
|
|
||||||
$this->msgs = $this->entityManager->getRepository(Messages::class)->getUnreadMessages($user);
|
|
||||||
$this->notificationCount = $this->entityManager->getRepository(Messages::class)->getUnreadMessageCount($user);
|
|
||||||
|
|
||||||
$staff = $this->entityManager->getRepository(User::class)->find($staffId);
|
|
||||||
$case = $this->entityManager->getRepository(MemberCase::class)->find($caseId);
|
|
||||||
$staffNotes = $this->entityManager->getRepository(StaffNote::class)->findBy(['memberCase' => $case]);
|
|
||||||
|
|
||||||
return $this->render(
|
|
||||||
'internal/staff/notes/list-notes.html.twig',
|
|
||||||
array_merge(
|
|
||||||
$this->navLinks,
|
|
||||||
[
|
|
||||||
'staffId' => $staffId,
|
|
||||||
'staff' => $staff,
|
|
||||||
'case' => $case,
|
|
||||||
'staffNotes' => $staffNotes,
|
|
||||||
'breadcrumbs' => [
|
|
||||||
new Breadcrumb($this->generateUrl('app_staff_dashboard'), 'Staff Dashboard'),
|
|
||||||
new Breadcrumb(
|
|
||||||
$this->generateUrl(
|
|
||||||
($staffId == $user->getId()->toHex() ? 'app_staff_my_cases' : 'app_staff_cases'),
|
|
||||||
['staffId' => $staffId]
|
|
||||||
),
|
|
||||||
($staffId == $user->getId()->toHex() ? 'My Cases' : 'Staff Cases')
|
|
||||||
),
|
|
||||||
new Breadcrumb('', 'List Notes')
|
|
||||||
],
|
|
||||||
'notifications' => $this->msgs,
|
|
||||||
'notificationCount' => $this->notificationCount,
|
|
||||||
]
|
|
||||||
)
|
|
||||||
);
|
|
||||||
}
|
|
||||||
|
|
||||||
#[Route('/staff/add-note/{caseId}', name: 'app_staff_add_note')]
|
|
||||||
public function addNote(string $caseId, #[CurrentUser()] User $user, Request $request): Response
|
|
||||||
{
|
|
||||||
$this->denyAccessUnlessGranted('IS_FULLY_AUTHENTICATED');
|
|
||||||
$this->msgs = $this->entityManager->getRepository(Messages::class)->getUnreadMessages($user);
|
|
||||||
$this->notificationCount = $this->entityManager->getRepository(Messages::class)->getUnreadMessageCount($user);
|
|
||||||
|
|
||||||
$case = $this->entityManager->getRepository(MemberCase::class)->find($caseId);
|
|
||||||
$form = $this->createForm(StaffNoteFormType::class);
|
|
||||||
$this->navLinks['staff_dashboard'] = 'nav-link text-dark';
|
|
||||||
$this->navLinks['staff_notes'] = NavList::PRESENT_LINK;
|
|
||||||
|
|
||||||
$form->handleRequest($request);
|
|
||||||
|
|
||||||
if ($form->isSubmitted() && $form->isValid()) {
|
|
||||||
$note = $form->getData();
|
|
||||||
$note->setMemberCase($case);
|
|
||||||
|
|
||||||
$this->entityManager->persist($note);
|
|
||||||
$this->entityManager->flush();
|
|
||||||
|
|
||||||
return $this->redirectToRoute('app_staff_list_notes', ['staffId' => $user->getId()->toHex(), 'caseId' => $caseId]);
|
|
||||||
}
|
|
||||||
|
|
||||||
return $this->render(
|
|
||||||
'internal/staff/notes/add-note.html.twig',
|
|
||||||
array_merge(
|
|
||||||
$this->navLinks,
|
|
||||||
[
|
|
||||||
'case' => $case,
|
|
||||||
'form' => $form,
|
|
||||||
'breadcrumbs' => [
|
|
||||||
new Breadcrumb($this->generateUrl('app_staff_dashboard'), 'Staff Dashboard'),
|
|
||||||
new Breadcrumb($this->generateUrl('app_staff_list_notes', ['staffId' => $user->getId()->toHex(), 'caseId' => $caseId]), 'My Cases'),
|
|
||||||
new Breadcrumb('', 'Add Note'),
|
|
||||||
],
|
|
||||||
'notifications' => $this->msgs,
|
|
||||||
'notificationCount' => $this->notificationCount,
|
|
||||||
]
|
|
||||||
)
|
|
||||||
);
|
|
||||||
}
|
|
||||||
|
|
||||||
#[Route('/staff/edit-note/{noteId}', name: 'app_staff_edit_note')]
|
|
||||||
public function editNote(string $noteId, #[CurrentUser()] User $user, Request $request): Response
|
|
||||||
{
|
|
||||||
$this->denyAccessUnlessGranted('IS_FULLY_AUTHENTICATED');
|
|
||||||
$this->msgs = $this->entityManager->getRepository(Messages::class)->getUnreadMessages($user);
|
|
||||||
$this->notificationCount = $this->entityManager->getRepository(Messages::class)->getUnreadMessageCount($user);
|
|
||||||
|
|
||||||
$note = $this->entityManager->getRepository(StaffNote::class)->find($noteId);
|
|
||||||
$case = $note->getMemberCase();
|
|
||||||
|
|
||||||
$form = $this->createForm(StaffNoteFormType::class, $note);
|
|
||||||
|
|
||||||
$form->handleRequest($request);
|
|
||||||
|
|
||||||
if ($form->isSubmitted() && $form->isValid()) {
|
|
||||||
$this->entityManager->flush();
|
|
||||||
|
|
||||||
$this->addFlash('info', 'Staff notes updated');
|
|
||||||
|
|
||||||
$this->redirectToRoute('app_staff_list_note', ['staffId' => $user->getId()->toHex(), 'caseId' => $case->getId()->toHex()]);
|
|
||||||
}
|
|
||||||
|
|
||||||
return new Response();
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
@ -104,8 +104,9 @@ class CommunityResource
|
|||||||
private array $type = [];
|
private array $type = [];
|
||||||
|
|
||||||
public function __construct(
|
public function __construct(
|
||||||
private DateTime $today = new DateTime('now', new DateTimeZone('America/New_York'))
|
private DateTime $today
|
||||||
) {
|
) {
|
||||||
|
$this->today = new DateTime('now', new DateTimeZone('America/New_York'));
|
||||||
}
|
}
|
||||||
|
|
||||||
public function getId(): ?Uuid
|
public function getId(): ?Uuid
|
||||||
|
@ -91,31 +91,10 @@ class MemberCase
|
|||||||
#[ORM\OneToMany(targetEntity: Referral::class, mappedBy: 'memberCase', orphanRemoval: true)]
|
#[ORM\OneToMany(targetEntity: Referral::class, mappedBy: 'memberCase', orphanRemoval: true)]
|
||||||
private Collection $referrals;
|
private Collection $referrals;
|
||||||
|
|
||||||
/**
|
|
||||||
* @var Collection<int, MonthlyCaseNote>
|
|
||||||
*/
|
|
||||||
#[ORM\OneToMany(targetEntity: MonthlyCaseNote::class, mappedBy: 'memberCase')]
|
|
||||||
private Collection $monthlyCaseNotes;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @var Collection<int, Member>
|
|
||||||
*/
|
|
||||||
#[ORM\OneToMany(targetEntity: Member::class, mappedBy: 'memberCase', orphanRemoval: true)]
|
|
||||||
private Collection $members;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @var Collection<int, StaffNote>
|
|
||||||
*/
|
|
||||||
#[ORM\OneToMany(targetEntity: StaffNote::class, mappedBy: 'memberCase')]
|
|
||||||
private Collection $staffNotes;
|
|
||||||
|
|
||||||
public function __construct()
|
public function __construct()
|
||||||
{
|
{
|
||||||
$this->userCases = new ArrayCollection();
|
$this->userCases = new ArrayCollection();
|
||||||
$this->referrals = new ArrayCollection();
|
$this->referrals = new ArrayCollection();
|
||||||
$this->monthlyCaseNotes = new ArrayCollection();
|
|
||||||
$this->members = new ArrayCollection();
|
|
||||||
$this->staffNotes = new ArrayCollection();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public function getId(): ?Uuid
|
public function getId(): ?Uuid
|
||||||
@ -415,94 +394,4 @@ class MemberCase
|
|||||||
|
|
||||||
return $this;
|
return $this;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* @return Collection<int, MonthlyCaseNote>
|
|
||||||
*/
|
|
||||||
public function getMonthlyCaseNotes(): Collection
|
|
||||||
{
|
|
||||||
return $this->monthlyCaseNotes;
|
|
||||||
}
|
|
||||||
|
|
||||||
public function addMonthlyCaseNote(MonthlyCaseNote $monthlyCaseNote): static
|
|
||||||
{
|
|
||||||
if (!$this->monthlyCaseNotes->contains($monthlyCaseNote)) {
|
|
||||||
$this->monthlyCaseNotes->add($monthlyCaseNote);
|
|
||||||
$monthlyCaseNote->setMemberCase($this);
|
|
||||||
}
|
|
||||||
|
|
||||||
return $this;
|
|
||||||
}
|
|
||||||
|
|
||||||
public function removeMonthlyCaseNote(MonthlyCaseNote $monthlyCaseNote): static
|
|
||||||
{
|
|
||||||
if ($this->monthlyCaseNotes->removeElement($monthlyCaseNote)) {
|
|
||||||
// set the owning side to null (unless already changed)
|
|
||||||
if ($monthlyCaseNote->getMemberCase() === $this) {
|
|
||||||
$monthlyCaseNote->setMemberCase(null);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return $this;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @return Collection<int, Member>
|
|
||||||
*/
|
|
||||||
public function getMembers(): Collection
|
|
||||||
{
|
|
||||||
return $this->members;
|
|
||||||
}
|
|
||||||
|
|
||||||
public function addMember(Member $member): static
|
|
||||||
{
|
|
||||||
if (!$this->members->contains($member)) {
|
|
||||||
$this->members->add($member);
|
|
||||||
$member->setCaseId($this);
|
|
||||||
}
|
|
||||||
|
|
||||||
return $this;
|
|
||||||
}
|
|
||||||
|
|
||||||
public function removeMember(Member $member): static
|
|
||||||
{
|
|
||||||
if ($this->members->removeElement($member)) {
|
|
||||||
// set the owning side to null (unless already changed)
|
|
||||||
if ($member->getCaseId() === $this) {
|
|
||||||
$member->setCaseId(null);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return $this;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @return Collection<int, StaffNote>
|
|
||||||
*/
|
|
||||||
public function getStaffNotes(): Collection
|
|
||||||
{
|
|
||||||
return $this->staffNotes;
|
|
||||||
}
|
|
||||||
|
|
||||||
public function addStaffNote(StaffNote $staffNote): static
|
|
||||||
{
|
|
||||||
if (!$this->staffNotes->contains($staffNote)) {
|
|
||||||
$this->staffNotes->add($staffNote);
|
|
||||||
$staffNote->setMemberCase($this);
|
|
||||||
}
|
|
||||||
|
|
||||||
return $this;
|
|
||||||
}
|
|
||||||
|
|
||||||
public function removeStaffNote(StaffNote $staffNote): static
|
|
||||||
{
|
|
||||||
if ($this->staffNotes->removeElement($staffNote)) {
|
|
||||||
// set the owning side to null (unless already changed)
|
|
||||||
if ($staffNote->getMemberCase() === $this) {
|
|
||||||
$staffNote->setMemberCase(null);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return $this;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
@ -1,144 +0,0 @@
|
|||||||
<?php
|
|
||||||
|
|
||||||
namespace App\Entity;
|
|
||||||
|
|
||||||
use App\Enums\MessageType;
|
|
||||||
use App\Repository\MessagesRepository;
|
|
||||||
use Doctrine\DBAL\Types\Types;
|
|
||||||
use Doctrine\ORM\Mapping as ORM;
|
|
||||||
use Symfony\Bridge\Doctrine\Types\UuidType;
|
|
||||||
use Symfony\Component\Uid\Uuid;
|
|
||||||
|
|
||||||
#[ORM\Entity(repositoryClass: MessagesRepository::class)]
|
|
||||||
class Messages
|
|
||||||
{
|
|
||||||
#[ORM\Id]
|
|
||||||
#[ORM\Column(type: UuidType::NAME, unique: true)]
|
|
||||||
#[ORM\GeneratedValue(strategy: 'CUSTOM')]
|
|
||||||
#[ORM\CustomIdGenerator(class: 'doctrine.uuid_generator')]
|
|
||||||
private ?Uuid $id = null;
|
|
||||||
|
|
||||||
#[ORM\Column]
|
|
||||||
private ?\DateTimeImmutable $sent = null;
|
|
||||||
|
|
||||||
#[ORM\Column(nullable: true)]
|
|
||||||
private ?\DateTimeImmutable $received = null;
|
|
||||||
|
|
||||||
#[ORM\ManyToOne]
|
|
||||||
#[ORM\JoinColumn(nullable: false)]
|
|
||||||
private ?User $recipient = null;
|
|
||||||
|
|
||||||
#[ORM\Column(enumType: MessageType::class)]
|
|
||||||
private ?MessageType $type = null;
|
|
||||||
|
|
||||||
#[ORM\Column(type: Types::TEXT)]
|
|
||||||
private ?string $message = null;
|
|
||||||
|
|
||||||
#[ORM\Column(length: 255)]
|
|
||||||
private ?string $title = null;
|
|
||||||
|
|
||||||
#[ORM\ManyToOne]
|
|
||||||
#[ORM\JoinColumn(nullable: false)]
|
|
||||||
private ?User $sender = null;
|
|
||||||
|
|
||||||
public function getId(): ?Uuid
|
|
||||||
{
|
|
||||||
return $this->id;
|
|
||||||
}
|
|
||||||
|
|
||||||
public function getSent(): ?\DateTimeImmutable
|
|
||||||
{
|
|
||||||
return $this->sent;
|
|
||||||
}
|
|
||||||
|
|
||||||
public function setSent(\DateTimeImmutable $sent): static
|
|
||||||
{
|
|
||||||
$this->sent = $sent;
|
|
||||||
|
|
||||||
return $this;
|
|
||||||
}
|
|
||||||
|
|
||||||
public function getReceived(): ?\DateTimeImmutable
|
|
||||||
{
|
|
||||||
return $this->received;
|
|
||||||
}
|
|
||||||
|
|
||||||
public function setReceived(?\DateTimeImmutable $received): static
|
|
||||||
{
|
|
||||||
$this->received = $received;
|
|
||||||
|
|
||||||
return $this;
|
|
||||||
}
|
|
||||||
|
|
||||||
public function getRecipient(): ?User
|
|
||||||
{
|
|
||||||
return $this->recipient;
|
|
||||||
}
|
|
||||||
|
|
||||||
public function setRecipient(?User $recipient): static
|
|
||||||
{
|
|
||||||
$this->recipient = $recipient;
|
|
||||||
|
|
||||||
return $this;
|
|
||||||
}
|
|
||||||
|
|
||||||
public function getType(): ?MessageType
|
|
||||||
{
|
|
||||||
return $this->type;
|
|
||||||
}
|
|
||||||
|
|
||||||
public function setType(MessageType $type): static
|
|
||||||
{
|
|
||||||
$this->type = $type;
|
|
||||||
|
|
||||||
return $this;
|
|
||||||
}
|
|
||||||
|
|
||||||
public function getMessage(): ?string
|
|
||||||
{
|
|
||||||
return $this->message;
|
|
||||||
}
|
|
||||||
|
|
||||||
public function setMessage(string $message): static
|
|
||||||
{
|
|
||||||
$this->message = $message;
|
|
||||||
|
|
||||||
return $this;
|
|
||||||
}
|
|
||||||
|
|
||||||
public function getTitle(): ?string
|
|
||||||
{
|
|
||||||
return $this->title;
|
|
||||||
}
|
|
||||||
|
|
||||||
public function setTitle(string $title): static
|
|
||||||
{
|
|
||||||
$this->title = $title;
|
|
||||||
|
|
||||||
return $this;
|
|
||||||
}
|
|
||||||
|
|
||||||
public function getSender(): ?User
|
|
||||||
{
|
|
||||||
return $this->sender;
|
|
||||||
}
|
|
||||||
|
|
||||||
public function setSender(?User $sender): static
|
|
||||||
{
|
|
||||||
$this->sender = $sender;
|
|
||||||
|
|
||||||
return $this;
|
|
||||||
}
|
|
||||||
|
|
||||||
public function toArray(): array
|
|
||||||
{
|
|
||||||
return [
|
|
||||||
'id' => $this->id->toHex(),
|
|
||||||
'title' => $this->title,
|
|
||||||
'sender' => $this->sender->getName(),
|
|
||||||
'type' => $this->type->name,
|
|
||||||
'date' => $this->sent,
|
|
||||||
'message' => $this->message
|
|
||||||
];
|
|
||||||
}
|
|
||||||
}
|
|
@ -140,13 +140,6 @@ class Note
|
|||||||
return $this;
|
return $this;
|
||||||
}
|
}
|
||||||
|
|
||||||
public function setMembers(?array $members): static
|
|
||||||
{
|
|
||||||
$this->members = $members;
|
|
||||||
|
|
||||||
return $this;
|
|
||||||
}
|
|
||||||
|
|
||||||
public function getLocation(): ?NoteLocation
|
public function getLocation(): ?NoteLocation
|
||||||
{
|
{
|
||||||
return $this->location;
|
return $this->location;
|
||||||
@ -173,10 +166,10 @@ class Note
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* Method to calculate the number of minutes used for a visit rounded to the nearest 15 min increment
|
* Method to calculate the number of minutes used for a visit rounded to the nearest 15 min increment
|
||||||
*
|
*
|
||||||
* @param int $precision
|
* @param int $precision
|
||||||
* The number of minutes to round the time to defaulted to 15
|
* The number of minutes to round the time to defaulted to 15
|
||||||
*
|
*
|
||||||
* @return int
|
* @return int
|
||||||
* The number of minutes calculated
|
* The number of minutes calculated
|
||||||
*/
|
*/
|
||||||
|
@ -1,101 +0,0 @@
|
|||||||
<?php
|
|
||||||
|
|
||||||
namespace App\Entity;
|
|
||||||
|
|
||||||
use App\Enums\ReferralServiceType;
|
|
||||||
use App\Repository\StaffNoteRepository;
|
|
||||||
use Doctrine\DBAL\Types\Types;
|
|
||||||
use Doctrine\ORM\Mapping as ORM;
|
|
||||||
|
|
||||||
#[ORM\Entity(repositoryClass: StaffNoteRepository::class)]
|
|
||||||
class StaffNote
|
|
||||||
{
|
|
||||||
#[ORM\Id]
|
|
||||||
#[ORM\GeneratedValue]
|
|
||||||
#[ORM\Column]
|
|
||||||
private ?int $id = null;
|
|
||||||
|
|
||||||
#[ORM\Column(type: Types::DATE_MUTABLE)]
|
|
||||||
private ?\DateTimeInterface $date = null;
|
|
||||||
|
|
||||||
#[ORM\ManyToOne(inversedBy: 'staffNotes')]
|
|
||||||
#[ORM\JoinColumn(nullable: false)]
|
|
||||||
private ?MemberCase $memberCase = null;
|
|
||||||
|
|
||||||
#[ORM\Column(type: Types::SIMPLE_ARRAY, enumType: ReferralServiceType::class)]
|
|
||||||
private array $servicesProvided = [];
|
|
||||||
|
|
||||||
#[ORM\Column(type: Types::TEXT)]
|
|
||||||
private ?string $note = null;
|
|
||||||
|
|
||||||
#[ORM\Column(length: 500, nullable: true)]
|
|
||||||
private ?string $recommendations = null;
|
|
||||||
|
|
||||||
public function getId(): ?int
|
|
||||||
{
|
|
||||||
return $this->id;
|
|
||||||
}
|
|
||||||
|
|
||||||
public function getDate(): ?\DateTimeInterface
|
|
||||||
{
|
|
||||||
return $this->date;
|
|
||||||
}
|
|
||||||
|
|
||||||
public function setDate(\DateTimeInterface $date): static
|
|
||||||
{
|
|
||||||
$this->date = $date;
|
|
||||||
|
|
||||||
return $this;
|
|
||||||
}
|
|
||||||
|
|
||||||
public function getMemberCase(): ?MemberCase
|
|
||||||
{
|
|
||||||
return $this->memberCase;
|
|
||||||
}
|
|
||||||
|
|
||||||
public function setMemberCase(?MemberCase $memberCase): static
|
|
||||||
{
|
|
||||||
$this->memberCase = $memberCase;
|
|
||||||
|
|
||||||
return $this;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @return ReferralServiceType[]
|
|
||||||
*/
|
|
||||||
public function getServicesProvided(): array
|
|
||||||
{
|
|
||||||
return $this->servicesProvided;
|
|
||||||
}
|
|
||||||
|
|
||||||
public function setServicesProvided(array $servicesProvided): static
|
|
||||||
{
|
|
||||||
$this->servicesProvided = $servicesProvided;
|
|
||||||
|
|
||||||
return $this;
|
|
||||||
}
|
|
||||||
|
|
||||||
public function getNote(): ?string
|
|
||||||
{
|
|
||||||
return $this->note;
|
|
||||||
}
|
|
||||||
|
|
||||||
public function setNote(string $note): static
|
|
||||||
{
|
|
||||||
$this->note = $note;
|
|
||||||
|
|
||||||
return $this;
|
|
||||||
}
|
|
||||||
|
|
||||||
public function getRecommendations(): ?string
|
|
||||||
{
|
|
||||||
return $this->recommendations;
|
|
||||||
}
|
|
||||||
|
|
||||||
public function setRecommendations(string $recommendations): static
|
|
||||||
{
|
|
||||||
$this->recommendations = $recommendations;
|
|
||||||
|
|
||||||
return $this;
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,17 +0,0 @@
|
|||||||
<?php
|
|
||||||
|
|
||||||
namespace App\Enums;
|
|
||||||
|
|
||||||
enum MessageType: int
|
|
||||||
{
|
|
||||||
case GENERAL = 0;
|
|
||||||
case CASE = 1;
|
|
||||||
case STAFFING = 2;
|
|
||||||
case BILLING = 3;
|
|
||||||
case NEW_CASE = 4;
|
|
||||||
case USER = 5;
|
|
||||||
case NEW_REFERRAL = 6;
|
|
||||||
case CALENDAR = 97;
|
|
||||||
case REMINDER = 98;
|
|
||||||
case UNKNOWN = 99;
|
|
||||||
}
|
|
@ -1,124 +0,0 @@
|
|||||||
<?php
|
|
||||||
|
|
||||||
namespace App\Factory;
|
|
||||||
|
|
||||||
use App\Entity\MemberCase;
|
|
||||||
use App\Entity\Messages;
|
|
||||||
use App\Entity\User;
|
|
||||||
use App\Enums\MessageType;
|
|
||||||
use DateTimeImmutable;
|
|
||||||
|
|
||||||
class MessageFactory
|
|
||||||
{
|
|
||||||
public static function createGeneral(User $sender, User $recipient, string $title, string $message): Messages
|
|
||||||
{
|
|
||||||
$msg = new Messages();
|
|
||||||
$msg->setSent(new DateTimeImmutable())
|
|
||||||
->setType(MessageType::GENERAL)
|
|
||||||
->setSender($sender)
|
|
||||||
->setRecipient($recipient)
|
|
||||||
->setMessage($message)
|
|
||||||
->setTitle($title)
|
|
||||||
;
|
|
||||||
|
|
||||||
return $msg;
|
|
||||||
}
|
|
||||||
|
|
||||||
public static function createCase(User $sender, User $recipient): Messages
|
|
||||||
{
|
|
||||||
$msg = new Messages();
|
|
||||||
$msg->setSent(new DateTimeImmutable())
|
|
||||||
->setType(MessageType::CASE)
|
|
||||||
->setSender($sender)
|
|
||||||
->setRecipient($recipient)
|
|
||||||
->setTitle('Case')
|
|
||||||
->setMessage("{$sender->getName()} has updated a case")
|
|
||||||
;
|
|
||||||
|
|
||||||
return $msg;
|
|
||||||
}
|
|
||||||
|
|
||||||
public static function createNewCase(User $sender, User $recipient): Messages
|
|
||||||
{
|
|
||||||
$msg = new Messages();
|
|
||||||
$msg->setSent(new DateTimeImmutable())
|
|
||||||
->setType(MessageType::NEW_CASE)
|
|
||||||
->setSender($sender)
|
|
||||||
->setRecipient($recipient)
|
|
||||||
->setTitle('New Case')
|
|
||||||
->setMessage("You've been assigned a new case")
|
|
||||||
;
|
|
||||||
|
|
||||||
return $msg;
|
|
||||||
}
|
|
||||||
|
|
||||||
public static function createStaffing(User $sender, User $recipient): Messages
|
|
||||||
{
|
|
||||||
$msg = new Messages();
|
|
||||||
$msg->setSent(new DateTimeImmutable())
|
|
||||||
->setType(MessageType::STAFFING)
|
|
||||||
->setSender($sender)
|
|
||||||
->setRecipient($recipient)
|
|
||||||
->setTitle('Staff Notes')
|
|
||||||
->setMessage("Staff notes from {$sender->getName()} are ready for your review")
|
|
||||||
;
|
|
||||||
|
|
||||||
return $msg;
|
|
||||||
}
|
|
||||||
|
|
||||||
public static function createBilling(User $sender, User $recipient): Messages
|
|
||||||
{
|
|
||||||
$msg = new Messages();
|
|
||||||
$msg->setSent(new DateTimeImmutable())
|
|
||||||
->setType(MessageType::BILLING)
|
|
||||||
->setSender($sender)
|
|
||||||
->setRecipient($recipient)
|
|
||||||
->setTitle('New Billing')
|
|
||||||
->setMessage("{$sender->getName()} has published their timesheet")
|
|
||||||
;
|
|
||||||
|
|
||||||
return $msg;
|
|
||||||
}
|
|
||||||
|
|
||||||
public static function createReminder(User $sender, User $recipient, string $title, string $message): Messages
|
|
||||||
{
|
|
||||||
$msg = new Messages();
|
|
||||||
$msg->setSent(new DateTimeImmutable())
|
|
||||||
->setType(MessageType::REMINDER)
|
|
||||||
->setSender($sender)
|
|
||||||
->setRecipient($recipient)
|
|
||||||
->setTitle($title)
|
|
||||||
->setMessage($message)
|
|
||||||
;
|
|
||||||
|
|
||||||
return $msg;
|
|
||||||
}
|
|
||||||
|
|
||||||
public static function createUser(User $sender, User $recipient, string $title, string $message): Messages
|
|
||||||
{
|
|
||||||
$msg = new Messages();
|
|
||||||
$msg->setSent(new DateTimeImmutable())
|
|
||||||
->setType(MessageType::USER)
|
|
||||||
->setSender($sender)
|
|
||||||
->setRecipient($recipient)
|
|
||||||
->setTitle($title)
|
|
||||||
->setMessage($message)
|
|
||||||
;
|
|
||||||
|
|
||||||
return $msg;
|
|
||||||
}
|
|
||||||
|
|
||||||
public static function createReferral(User $sender, User $recipient, MemberCase $case): Messages
|
|
||||||
{
|
|
||||||
$msg = new Messages();
|
|
||||||
$msg->setSender($sender)
|
|
||||||
->setRecipient($recipient)
|
|
||||||
->setSent(new DateTimeImmutable())
|
|
||||||
->setType(MessageType::NEW_REFERRAL)
|
|
||||||
->setTitle('New Referral')
|
|
||||||
->setMessage("A referral has been added/updated to case {$case->getCaseName()}")
|
|
||||||
;
|
|
||||||
|
|
||||||
return $msg;
|
|
||||||
}
|
|
||||||
}
|
|
@ -4,7 +4,6 @@ namespace App\Form;
|
|||||||
|
|
||||||
use App\Entity\CommunityResource;
|
use App\Entity\CommunityResource;
|
||||||
use App\Enums\County;
|
use App\Enums\County;
|
||||||
use App\Enums\ResourceType;
|
|
||||||
use App\Enums\State;
|
use App\Enums\State;
|
||||||
use Symfony\Component\Form\AbstractType;
|
use Symfony\Component\Form\AbstractType;
|
||||||
use Symfony\Component\Form\Extension\Core\Type\EmailType;
|
use Symfony\Component\Form\Extension\Core\Type\EmailType;
|
||||||
@ -84,12 +83,6 @@ class ResourceFormType extends AbstractType
|
|||||||
'widget' => 'single_text',
|
'widget' => 'single_text',
|
||||||
])
|
])
|
||||||
->add('notes')
|
->add('notes')
|
||||||
->add('type', EnumType::class, [
|
|
||||||
'class' => ResourceType::class,
|
|
||||||
'expanded' => true,
|
|
||||||
'multiple' => true,
|
|
||||||
|
|
||||||
])
|
|
||||||
->add('servicesAvailable')
|
->add('servicesAvailable')
|
||||||
;
|
;
|
||||||
}
|
}
|
||||||
|
@ -1,38 +0,0 @@
|
|||||||
<?php
|
|
||||||
|
|
||||||
namespace App\Form;
|
|
||||||
|
|
||||||
use App\Entity\Member;
|
|
||||||
use App\Entity\StaffNote;
|
|
||||||
use App\Enums\ReferralServiceType;
|
|
||||||
use Symfony\Component\Form\AbstractType;
|
|
||||||
use Symfony\Component\Form\Extension\Core\Type\EnumType;
|
|
||||||
use Symfony\Component\Form\Extension\Core\Type\TextareaType;
|
|
||||||
use Symfony\Component\Form\FormBuilderInterface;
|
|
||||||
use Symfony\Component\OptionsResolver\OptionsResolver;
|
|
||||||
|
|
||||||
class StaffNoteFormType extends AbstractType
|
|
||||||
{
|
|
||||||
public function buildForm(FormBuilderInterface $builder, array $options): void
|
|
||||||
{
|
|
||||||
$builder
|
|
||||||
->add('date', null, [
|
|
||||||
'widget' => 'single_text',
|
|
||||||
])
|
|
||||||
->add('servicesProvided', EnumType::class, [
|
|
||||||
'class' => ReferralServiceType::class,
|
|
||||||
'expanded' => true,
|
|
||||||
'multiple' => true,
|
|
||||||
])
|
|
||||||
->add('note', TextareaType::class)
|
|
||||||
->add('recommendations')
|
|
||||||
;
|
|
||||||
}
|
|
||||||
|
|
||||||
public function configureOptions(OptionsResolver $resolver): void
|
|
||||||
{
|
|
||||||
$resolver->setDefaults([
|
|
||||||
'data_class' => StaffNote::class,
|
|
||||||
]);
|
|
||||||
}
|
|
||||||
}
|
|
@ -16,7 +16,6 @@ class NavList
|
|||||||
'case_notes' => 'nav-link text-dark',
|
'case_notes' => 'nav-link text-dark',
|
||||||
'community_resource' => 'nav-link text-dark',
|
'community_resource' => 'nav-link text-dark',
|
||||||
'my_cases' => 'nav-link text-dark',
|
'my_cases' => 'nav-link text-dark',
|
||||||
'staff_notes' => 'nav-link text-dark',
|
|
||||||
];
|
];
|
||||||
|
|
||||||
public const PRESENT_LINK = 'nav-link text-white active bg-gradient-dark';
|
public const PRESENT_LINK = 'nav-link text-white active bg-gradient-dark';
|
||||||
|
@ -1,73 +0,0 @@
|
|||||||
<?php
|
|
||||||
|
|
||||||
namespace App\Repository;
|
|
||||||
|
|
||||||
use App\Entity\Messages;
|
|
||||||
use App\Entity\User;
|
|
||||||
use Doctrine\Bundle\DoctrineBundle\Repository\ServiceEntityRepository;
|
|
||||||
use Doctrine\Persistence\ManagerRegistry;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @extends ServiceEntityRepository<Messages>
|
|
||||||
*/
|
|
||||||
class MessagesRepository extends ServiceEntityRepository
|
|
||||||
{
|
|
||||||
public function __construct(ManagerRegistry $registry)
|
|
||||||
{
|
|
||||||
parent::__construct($registry, Messages::class);
|
|
||||||
}
|
|
||||||
|
|
||||||
public function getUnreadMessages(User $user): array
|
|
||||||
{
|
|
||||||
$query = $this->createQueryBuilder('m')
|
|
||||||
->andWhere('m.recipient = :recipient')
|
|
||||||
->andWhere('m.received IS NULL')
|
|
||||||
->setParameter('recipient', $user->getId()->toBinary())
|
|
||||||
->orderBy('m.sent', 'ASC')
|
|
||||||
->setMaxResults(5)
|
|
||||||
->getQuery()
|
|
||||||
->getResult()
|
|
||||||
;
|
|
||||||
|
|
||||||
return $query;
|
|
||||||
}
|
|
||||||
|
|
||||||
public function getUnreadMessageCount(User $user): int
|
|
||||||
{
|
|
||||||
$query = $this->createQueryBuilder('m')
|
|
||||||
->andWhere('m.recipient = :recipient')
|
|
||||||
->andWhere('m.received IS NULL')
|
|
||||||
->setParameter('recipient', $user->getId()->toBinary())
|
|
||||||
->select('COUNT(m)')
|
|
||||||
->getQuery()
|
|
||||||
->getSingleScalarResult()
|
|
||||||
;
|
|
||||||
|
|
||||||
return $query;
|
|
||||||
}
|
|
||||||
|
|
||||||
// /**
|
|
||||||
// * @return Messages[] Returns an array of Messages objects
|
|
||||||
// */
|
|
||||||
// public function findByExampleField($value): array
|
|
||||||
// {
|
|
||||||
// return $this->createQueryBuilder('m')
|
|
||||||
// ->andWhere('m.exampleField = :val')
|
|
||||||
// ->setParameter('val', $value)
|
|
||||||
// ->orderBy('m.id', 'ASC')
|
|
||||||
// ->setMaxResults(10)
|
|
||||||
// ->getQuery()
|
|
||||||
// ->getResult()
|
|
||||||
// ;
|
|
||||||
// }
|
|
||||||
|
|
||||||
// public function findOneBySomeField($value): ?Messages
|
|
||||||
// {
|
|
||||||
// return $this->createQueryBuilder('m')
|
|
||||||
// ->andWhere('m.exampleField = :val')
|
|
||||||
// ->setParameter('val', $value)
|
|
||||||
// ->getQuery()
|
|
||||||
// ->getOneOrNullResult()
|
|
||||||
// ;
|
|
||||||
// }
|
|
||||||
}
|
|
@ -1,43 +0,0 @@
|
|||||||
<?php
|
|
||||||
|
|
||||||
namespace App\Repository;
|
|
||||||
|
|
||||||
use App\Entity\StaffNote;
|
|
||||||
use Doctrine\Bundle\DoctrineBundle\Repository\ServiceEntityRepository;
|
|
||||||
use Doctrine\Persistence\ManagerRegistry;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @extends ServiceEntityRepository<StaffNote>
|
|
||||||
*/
|
|
||||||
class StaffNoteRepository extends ServiceEntityRepository
|
|
||||||
{
|
|
||||||
public function __construct(ManagerRegistry $registry)
|
|
||||||
{
|
|
||||||
parent::__construct($registry, StaffNote::class);
|
|
||||||
}
|
|
||||||
|
|
||||||
// /**
|
|
||||||
// * @return StaffNote[] Returns an array of StaffNote objects
|
|
||||||
// */
|
|
||||||
// public function findByExampleField($value): array
|
|
||||||
// {
|
|
||||||
// return $this->createQueryBuilder('s')
|
|
||||||
// ->andWhere('s.exampleField = :val')
|
|
||||||
// ->setParameter('val', $value)
|
|
||||||
// ->orderBy('s.id', 'ASC')
|
|
||||||
// ->setMaxResults(10)
|
|
||||||
// ->getQuery()
|
|
||||||
// ->getResult()
|
|
||||||
// ;
|
|
||||||
// }
|
|
||||||
|
|
||||||
// public function findOneBySomeField($value): ?StaffNote
|
|
||||||
// {
|
|
||||||
// return $this->createQueryBuilder('s')
|
|
||||||
// ->andWhere('s.exampleField = :val')
|
|
||||||
// ->setParameter('val', $value)
|
|
||||||
// ->getQuery()
|
|
||||||
// ->getOneOrNullResult()
|
|
||||||
// ;
|
|
||||||
// }
|
|
||||||
}
|
|
@ -37,6 +37,7 @@
|
|||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</main>
|
</main>
|
||||||
|
@ -17,7 +17,6 @@
|
|||||||
<div class="card card-plain">
|
<div class="card card-plain">
|
||||||
<div class="card-header">
|
<div class="card-header">
|
||||||
<h4 class="font-weight-bolder">Assign Case Worker</h4>
|
<h4 class="font-weight-bolder">Assign Case Worker</h4>
|
||||||
<p>{{ case.level.name|lower|capitalize }}</p>
|
|
||||||
</div>
|
</div>
|
||||||
<div class="card-body">
|
<div class="card-body">
|
||||||
{{ form_start(form, {'attr': {'onsubmit': 'return validateAssignForm()'}}) }}
|
{{ form_start(form, {'attr': {'onsubmit': 'return validateAssignForm()'}}) }}
|
||||||
@ -39,7 +38,7 @@
|
|||||||
|
|
||||||
<div class='input-group input-group-outline mb-3'>
|
<div class='input-group input-group-outline mb-3'>
|
||||||
<input type='checkbox' name='{{ field_name(form.overrideLevel) }}' id='user_form_levelOverride' value='1'/>
|
<input type='checkbox' name='{{ field_name(form.overrideLevel) }}' id='user_form_levelOverride' value='1'/>
|
||||||
<label for='user_form_levelOverride' id='levelOverride-label'>Override Level</label>
|
<label for='user_form_levelOverride'>Override Level</label>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<div class="text-center">
|
<div class="text-center">
|
||||||
|
@ -73,7 +73,7 @@
|
|||||||
{% endif %}
|
{% endif %}
|
||||||
</td>
|
</td>
|
||||||
<td class='align-middle'>
|
<td class='align-middle'>
|
||||||
<a href='{{ path('app_case_edit_member', {caseId: case.id, memberId: member.id}) }}' title='Edit Member'>
|
<a href='{{ path('app_case_edit_member', {caseId: case.id, memberId: member.id}) }}' class='text-secondary font-weight-bold text-xs' data-toggle='tooltip' data-original-title='Edit Source'>
|
||||||
<i class="material-symbols-rounded opacity-5">edit</i>
|
<i class="material-symbols-rounded opacity-5">edit</i>
|
||||||
</a>
|
</a>
|
||||||
</td>
|
</td>
|
||||||
|
@ -88,10 +88,6 @@
|
|||||||
<label for='rsc_form_services' class='form-label'>Services Available</label>
|
<label for='rsc_form_services' class='form-label'>Services Available</label>
|
||||||
<input type='text' name='{{ field_name(form.servicesAvailable) }}' id='rsc_form_services' class='form-control'/>
|
<input type='text' name='{{ field_name(form.servicesAvailable) }}' id='rsc_form_services' class='form-control'/>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<div class='input-group input-group-outline mb-3'>
|
|
||||||
{{ form_row(form.type) }}
|
|
||||||
</div>
|
|
||||||
</div>
|
</div>
|
||||||
<div class='col'>
|
<div class='col'>
|
||||||
<div class='input-group input-group-outline mb-3'>
|
<div class='input-group input-group-outline mb-3'>
|
||||||
|
@ -47,21 +47,12 @@
|
|||||||
{% endif %}
|
{% endif %}
|
||||||
|
|
||||||
{% if is_granted('ROLE_CASE_MANAGER') or is_granted('ROLE_ADMIN') %}
|
{% if is_granted('ROLE_CASE_MANAGER') or is_granted('ROLE_ADMIN') %}
|
||||||
<li class="nav-item mt-3">
|
|
||||||
<h6 class="ps-4 ms-2 text-uppercase text-xs text-dark font-weight-bolder opacity-5">Staffing pages</h6>
|
|
||||||
</li>
|
|
||||||
<li class='nav-item'>
|
<li class='nav-item'>
|
||||||
<a class='{{ staff_dashboard }}' href='{{ path('app_staff_dashboard') }}'>
|
<a class='{{ staff_dashboard }}' href='{{ path('app_staff_dashboard') }}'>
|
||||||
<i class='material-symbols-rounded opacity-5'>dashboard</i>
|
<i class='material-symbols-rounded opacity-5'>dashboard</i>
|
||||||
<span class='nav-link-text ms-1'>Staff Dashboard</span>
|
<span class='nav-link-text ms-1'>Staff Dashboard</span>
|
||||||
</a>
|
</a>
|
||||||
</li>
|
</li>
|
||||||
<li class='nav-item'>
|
|
||||||
<a class='{{ staff_notes }}' href='{{ path('app_staff_my_cases') }}'>
|
|
||||||
<i class='material-symbols-rounded opacity-5'></i>
|
|
||||||
<span class='nav-link-text ms-1'>Staff My Cases</span>
|
|
||||||
</a>
|
|
||||||
</li>
|
|
||||||
{% endif %}
|
{% endif %}
|
||||||
|
|
||||||
<li class="nav-item mt-3">
|
<li class="nav-item mt-3">
|
||||||
@ -97,7 +88,7 @@
|
|||||||
<li class="nav-item">
|
<li class="nav-item">
|
||||||
<a class="{{ profile }}" href="{{ path('app_profile') }}">
|
<a class="{{ profile }}" href="{{ path('app_profile') }}">
|
||||||
<i class="material-symbols-rounded opacity-5">person</i>
|
<i class="material-symbols-rounded opacity-5">person</i>
|
||||||
<span class="nav-link-text ms-1">{{ app.user.name }}</span>
|
<span class="nav-link-text ms-1">Profile</span>
|
||||||
</a>
|
</a>
|
||||||
</li>
|
</li>
|
||||||
<li class='nav-item'>
|
<li class='nav-item'>
|
||||||
|
@ -6,7 +6,7 @@
|
|||||||
<div class='ms-md-auto pe-md-3 d-flex align-items-left'>
|
<div class='ms-md-auto pe-md-3 d-flex align-items-left'>
|
||||||
{% for label, messages in app.flashes %}
|
{% for label, messages in app.flashes %}
|
||||||
{% for message in messages %}
|
{% for message in messages %}
|
||||||
<div class="flash-{{ label }} bg-gradient-info text-white">
|
<div class="flash-{{ label }}">
|
||||||
{{ message }}
|
{{ message }}
|
||||||
</div>
|
</div>
|
||||||
{% endfor %}
|
{% endfor %}
|
||||||
@ -37,9 +37,8 @@
|
|||||||
</li>
|
</li>
|
||||||
{% endif %}
|
{% endif %}
|
||||||
<li class="nav-item dropdown pe-3 d-flex align-items-center" title="Notifications">
|
<li class="nav-item dropdown pe-3 d-flex align-items-center" title="Notifications">
|
||||||
<a href="javascript:;" class="nav-link text-body p-0 notification" id="dropdownMenuButton" data-bs-toggle="dropdown" aria-expanded="false">
|
<a href="javascript:;" class="nav-link text-body p-0" id="dropdownMenuButton" data-bs-toggle="dropdown" aria-expanded="false">
|
||||||
<i class="material-symbols-rounded">notifications</i>
|
<i class="material-symbols-rounded">notifications</i>
|
||||||
<span class='badge' {% if notificationCount == 0 %} style='display:none;' {% endif %}>{{ notificationCount }}</span>
|
|
||||||
</a>
|
</a>
|
||||||
<ul class="dropdown-menu dropdown-menu-end px-2 py-3 me-sm-n4" aria-labelledby="dropdownMenuButton">
|
<ul class="dropdown-menu dropdown-menu-end px-2 py-3 me-sm-n4" aria-labelledby="dropdownMenuButton">
|
||||||
{% for note in notifications %}
|
{% for note in notifications %}
|
||||||
@ -52,12 +51,12 @@
|
|||||||
<div class='d-flex flex-column justify-content-center'>
|
<div class='d-flex flex-column justify-content-center'>
|
||||||
<h6 class='text-sm font-weight-normal mb-1'>
|
<h6 class='text-sm font-weight-normal mb-1'>
|
||||||
<span class='font-weight-bold'>{{ note.title }}</span>
|
<span class='font-weight-bold'>{{ note.title }}</span>
|
||||||
{{ note.sender.getName() }}
|
{{ note.from }}
|
||||||
</h6>
|
</h6>
|
||||||
<p>{{ note.message }}</p>
|
<p>{{ note.message }}</p>
|
||||||
<p class='text-xs text-secondary mb-0'>
|
<p class='text-xs text-secondary mb-0'>
|
||||||
<i class='fa fa-clock me-1'></i>
|
<i class='fa fa-clock me-1'></i>
|
||||||
{{ note.sent|format_datetime('short', 'short', timezone: 'America/Indiana/Indianapolis') }}
|
{{ note.timestamp|format_datetime('short', 'short', timezone: 'America/Indiana/Indianapolis') }}
|
||||||
</p>
|
</p>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
@ -1,44 +0,0 @@
|
|||||||
{% extends 'base.html.twig' %}
|
|
||||||
|
|
||||||
{% block body %}
|
|
||||||
{{ block('nav', 'internal/libs/nav.html.twig') }}
|
|
||||||
|
|
||||||
<main class="main-content position-relative max-height-vh-100 h-100 border-radius-lg ">
|
|
||||||
{{ block('topnav', 'internal/libs/top-nav.html.twig') }}
|
|
||||||
<div class='container-fluid py-2'>
|
|
||||||
<div class='row'>
|
|
||||||
<div class='ms-3'>
|
|
||||||
<h3 class='mb-0 h4 font-weight-bolder'>My Cases</h3>
|
|
||||||
<p class='mb-4'></p>
|
|
||||||
</div>
|
|
||||||
{% for c in cases %}
|
|
||||||
<div class='col-xl-3 col-sm-6 mb-xl-0 mb-4'>
|
|
||||||
<div class='card'>
|
|
||||||
<div class='card-header p-2 ps-3'>
|
|
||||||
<div class='d-flex justify-content-between'>
|
|
||||||
<div>
|
|
||||||
<h4 class='mb-0'>{{ c.caseName }}</h4>
|
|
||||||
<p class='text-sm mb-0 text-capitalize'>
|
|
||||||
<a href='tel:'></a>
|
|
||||||
</p>
|
|
||||||
</div>
|
|
||||||
<div class="icon icon-md icon-shape bg-gradient-dark shadow-dark shadow text-center border-radius-lg">
|
|
||||||
<i class="material-symbols-rounded opacity-10">weekend</i>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
<hr class='dark horizontal my-0'>
|
|
||||||
<div class='card-footer p-2 ps-3'>
|
|
||||||
<p class='mb-0 text-sm'>
|
|
||||||
<span class='text-info font-weight-bolder'>
|
|
||||||
<a href='{{ path('app_staff_list_notes', {staffId: user.id, caseId: c.id}) }}'>Staff Notes</a>
|
|
||||||
</span>
|
|
||||||
</p>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
{% endfor %}
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</main>
|
|
||||||
{% endblock %}
|
|
@ -1,44 +0,0 @@
|
|||||||
{% extends 'base.html.twig' %}
|
|
||||||
|
|
||||||
{% block body %}
|
|
||||||
{{ block('nav', 'internal/libs/nav.html.twig') }}
|
|
||||||
|
|
||||||
<main class="main-content position-relative max-height-vh-100 h-100 border-radius-lg ">
|
|
||||||
{{ block('topnav', 'internal/libs/top-nav.html.twig') }}
|
|
||||||
<div class='container-fluid py-2'>
|
|
||||||
<div class='row'>
|
|
||||||
<div class='ms-3'>
|
|
||||||
<h3 class='mb-0 h4 font-weight-bolder'>Staff Cases</h3>
|
|
||||||
<p class='mb-4'></p>
|
|
||||||
</div>
|
|
||||||
{% for c in cases %}
|
|
||||||
<div class='col-xl-3 col-sm-6 mb-xl-0 mb-4'>
|
|
||||||
<div class='card'>
|
|
||||||
<div class='card-header p-2 ps-3'>
|
|
||||||
<div class='d-flex justify-content-between'>
|
|
||||||
<div>
|
|
||||||
<h4 class='mb-0'>{{ c.caseName }}</h4>
|
|
||||||
<p class='text-sm mb-0 text-capitalize'>
|
|
||||||
<a href='tel:'></a>
|
|
||||||
</p>
|
|
||||||
</div>
|
|
||||||
<div class="icon icon-md icon-shape bg-gradient-dark shadow-dark shadow text-center border-radius-lg">
|
|
||||||
<i class="material-symbols-rounded opacity-10">weekend</i>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
<hr class='dark horizontal my-0'>
|
|
||||||
<div class='card-footer p-2 ps-3'>
|
|
||||||
<p class='mb-0 text-sm'>
|
|
||||||
<span class='text-info font-weight-bolder'>
|
|
||||||
<a href='{{ path('app_staff_list_notes', {staffId: staffId, caseId: c.id}) }}'>Staff Notes</a>
|
|
||||||
</span>
|
|
||||||
</p>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
{% endfor %}
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</main>
|
|
||||||
{% endblock %}
|
|
@ -1,56 +0,0 @@
|
|||||||
{% extends 'base.html.twig' %}
|
|
||||||
|
|
||||||
{% block body %}
|
|
||||||
{{ block('nav', 'internal/libs/nav.html.twig') }}
|
|
||||||
|
|
||||||
<main class="main-content position-relative max-height-vh-100 h-100 border-radius-lg ">
|
|
||||||
{{ block('topnav', 'internal/libs/top-nav.html.twig') }}
|
|
||||||
|
|
||||||
<section>
|
|
||||||
|
|
||||||
<div class="card card-plain">
|
|
||||||
<div class="card-header">
|
|
||||||
<h4 class="font-weight-bolder">Case Info</h4>
|
|
||||||
<p class="mb-0"></p>
|
|
||||||
</div>
|
|
||||||
<div class="card-body">
|
|
||||||
<div class="container">
|
|
||||||
{{ form_errors(form) }}
|
|
||||||
|
|
||||||
{{ form_start(form) }}
|
|
||||||
<div class="row">
|
|
||||||
<div class='col'>
|
|
||||||
<div class='input-group input-group-outline mb-3'>
|
|
||||||
<label for='note_form_date'></label>
|
|
||||||
<input type='date' name='{{ field_name(form.date) }}' id='note_form_date' class='form-control'/>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<div class='input-group input-group-outline mb-3'>
|
|
||||||
{{ form_row(form.servicesProvided) }}
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<div class='input-group input-group-outline mb-3'>
|
|
||||||
<label for='note_form_recommendation' class='form-label'>Recommendation</label>
|
|
||||||
<input type='text' name='{{ field_name(form.recommendations) }}' id='note_form_recommendation' class='form-control'/>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<div class='col'>
|
|
||||||
<div class='input-group input-group-outline mb-3'>
|
|
||||||
<textarea name='{{ field_name(form.note) }}' id='note_form_note' class='form-control' placeholder='Note' style='width:100%;height:200px;'></textarea>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<div class='row'>
|
|
||||||
<div class="text-center">
|
|
||||||
<button type="submit" class="btn btn-lg bg-gradient-dark btn-lg w-100 mt-4 mb-0">Save Staff Note</button>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
{{ form_end(form) }}
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</section>
|
|
||||||
</main>
|
|
||||||
{% endblock %}
|
|
@ -1,60 +0,0 @@
|
|||||||
{% extends 'base.html.twig' %}
|
|
||||||
|
|
||||||
{% block body %}
|
|
||||||
{{ block('nav', 'internal/libs/nav.html.twig') }}
|
|
||||||
|
|
||||||
<main class="main-content position-relative max-height-vh-100 h-100 border-radius-lg ">
|
|
||||||
{{ block('topnav', 'internal/libs/top-nav.html.twig') }}
|
|
||||||
|
|
||||||
<div class="container-fluid py-2">
|
|
||||||
<div class="row">
|
|
||||||
<div class="col-12">
|
|
||||||
<div class="card my-4">
|
|
||||||
<div class="card-header p-0 position-relative mt-n4 mx-3 z-index-2">
|
|
||||||
<div class="d-flex justify-content-between bg-gradient-dark shadow-dark border-radius-lg pt-4 pb-3 ps-3 p-2">
|
|
||||||
<div>
|
|
||||||
<h6 class="text-white text-capitalize ps-3">{{ case.caseName }}</h6>
|
|
||||||
</div>
|
|
||||||
{% if app.user.id == staffId %}
|
|
||||||
<div>
|
|
||||||
<button type="button" class="btn btn-block btn-light mb-3" onclick="window.open('{{ path('app_staff_add_note', {caseId: case.id}) }}', '_self')">Add Staff Note</button>
|
|
||||||
</div>
|
|
||||||
{% endif %}
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
<div class="card-body px-0 pb-2">
|
|
||||||
<div class="table-responsive p-0">
|
|
||||||
<table class="table align-items-center mb-0">
|
|
||||||
<thead>
|
|
||||||
<tr>
|
|
||||||
<th class="text-uppercase text-secondary text-xxs font-weight-bolder opacity-7">Date</th>
|
|
||||||
<th class="text-secondary opacity-7"></th>
|
|
||||||
</tr>
|
|
||||||
</thead>
|
|
||||||
<tbody id='case-list'>
|
|
||||||
{% for n in staffNotes %}
|
|
||||||
<tr>
|
|
||||||
<td>
|
|
||||||
<div class='d-flex px-2 py-1'>
|
|
||||||
<div class='d-flex flex-column justify-content-center'>
|
|
||||||
<h6 class='mb-0 text-small'>{{ n.date|date('F j, Y') }}</h6>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</td>
|
|
||||||
<td class='align-right'>
|
|
||||||
<a href='{{ path('app_staff_edit_note', {noteId: n.id}) }}' title='Edit Note'>
|
|
||||||
<i class='material-symbols-rounded opacity-5'>edit</i>
|
|
||||||
</a>
|
|
||||||
</td>
|
|
||||||
</tr>
|
|
||||||
{% endfor %}
|
|
||||||
</tbody>
|
|
||||||
</table>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</main>
|
|
||||||
{% endblock %}
|
|
@ -5,40 +5,5 @@
|
|||||||
|
|
||||||
<main class="main-content position-relative max-height-vh-100 h-100 border-radius-lg ">
|
<main class="main-content position-relative max-height-vh-100 h-100 border-radius-lg ">
|
||||||
{{ block('topnav', 'internal/libs/top-nav.html.twig') }}
|
{{ block('topnav', 'internal/libs/top-nav.html.twig') }}
|
||||||
<div class='container-fluid py-2'>
|
|
||||||
<div class='row'>
|
|
||||||
<div class='ms-3'>
|
|
||||||
<h3 class='mb-0 h4 font-weight-bolder'>Staff Dashboard</h3>
|
|
||||||
<p class='mb-4'></p>
|
|
||||||
</div>
|
|
||||||
{% for s in staff %}
|
|
||||||
<div class='col-xl-3 col-sm-6 mb-xl-0 mb-4'>
|
|
||||||
<div class='card'>
|
|
||||||
<div class='card-header p-2 ps-3'>
|
|
||||||
<div class='d-flex justify-content-between'>
|
|
||||||
<div>
|
|
||||||
<h4 class='mb-0'>{{ s.name }}</h4>
|
|
||||||
<p class='text-sm mb-0 text-capitalize'>
|
|
||||||
<a href='tel:'></a>
|
|
||||||
</p>
|
|
||||||
</div>
|
|
||||||
<div class="icon icon-md icon-shape bg-gradient-dark shadow-dark shadow text-center border-radius-lg">
|
|
||||||
<i class="material-symbols-rounded opacity-10">weekend</i>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
<hr class='dark horizontal my-0'>
|
|
||||||
<div class='card-footer p-2 ps-3'>
|
|
||||||
<p class='mb-0 text-sm'>
|
|
||||||
<span class='text-info font-weight-bolder'>
|
|
||||||
<a href='{{ path('app_staff_cases', {staffId: s.id}) }}'>Staff Cases</a>
|
|
||||||
</span>
|
|
||||||
</p>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
{% endfor %}
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</main>
|
</main>
|
||||||
{% endblock %}
|
{% endblock %}
|
||||||
|
Loading…
Reference in New Issue
Block a user