HEX
Server: Apache
System: Linux WWW 6.1.0-40-amd64 #1 SMP PREEMPT_DYNAMIC Debian 6.1.153-1 (2025-09-20) x86_64
User: web11 (1011)
PHP: 8.2.29
Disabled: NONE
Upload Files
File: /var/www/dvpis2025/dvpis.kaunokolegija.lt/src/Controller/MeovLecturerPlanController.php
<?php

namespace App\Controller;

use App\Entity\ActivitiesPlan;
use Doctrine\DBAL\Exception;
use Sensio\Bundle\FrameworkExtraBundle\Configuration\Method;
use App\Entity\LecturerApprovedActivities;
use Sensio\Bundle\FrameworkExtraBundle\Configuration\Security;
use App\Entity\MeovLecturer;
use Symfony\Bundle\FrameworkBundle\Controller\AbstractController;
use Symfony\Component\Form\Form;
use Symfony\Component\Routing\Annotation\Route;
use Symfony\Component\HttpFoundation\Request;
use Symfony\Component\HttpKernel\Exception\AccessDeniedHttpException;
use App\Service\ProcessDatesValidation;
use Symfony\Component\Security\Core\Authorization\AuthorizationCheckerInterface;
use Doctrine\ORM\EntityManagerInterface;
use App\Service\DbDataFilter;

/**
 * @Security("
    is_granted('ROLE_LECTURER')
    or is_granted('ROLE_DEPARTMENT_ADMINISTRATOR')
    or is_granted('ROLE_DEPARTMENT_HEAD')
    or is_granted('ROLE_ACADEMIC_UNIT_PROHEAD')
    ")
 */
#[Route(path: 'meovlecturerplan')]
class MeovLecturerPlanController extends AbstractController
{
    public function __construct(
        private readonly ProcessDatesValidation $dateValidator,
        private readonly EntityManagerInterface $em,
        private readonly DbDataFilter $dbDataFilter,
        private readonly AuthorizationCheckerInterface $authorizationChecker
    ) {

//        if (!$this->dateValidator->isActiveProcessPlan()) {
//            throw new AccessDeniedHttpException("Jūs negalite pasiekti šio turinio");
//        }


        if ($this->authorizationChecker->isGranted('ROLE_ACADEMIC_UNIT_PROHEAD')) {
            $this->dbDataFilter->enableOnlyAcademicUnitFilter();
            return;
        }

        if ($this->authorizationChecker->isGranted('ROLE_DEPARTMENT_HEAD')) {
            $this->dbDataFilter->enableOnlyDepartmentFilter();
            return;
        }

        if ($this->authorizationChecker->isGranted('ROLE_DEPARTMENT_ADMINISTRATOR')) {
            $this->dbDataFilter->enableOnlyDepartmentFilter();

            return;
        }

        if ($this->authorizationChecker->isGranted('ROLE_LECTURER')) {
            $this->dbDataFilter->enableOnlyLecturerFilter();
            return;
        }

        throw new AccessDeniedHttpException("Jūsų naudotojas negali pasiekti šio turinio");
    }

    /**
     * Lists all meovLecturer entities.
     *
     * @Method("GET")
     */
    #[Route(path: '/', name: 'meovlecturer_plan_index')]
    public function indexAction(Request $request)
    {


        $meovLecturers = $this->em->getRepository(MeovLecturer::class)->findAll();

        $lecturer = $this->dbDataFilter->getLecturerFromUser();
        $activities = $activitiesSum = $meovLecturersSum = [];
        if ($lecturer) {
            $activities = $this->em->getRepository(ActivitiesPlan::class)->findLecturerActivities($lecturer);
            $activitiesSum = $this->em->getRepository(ActivitiesPlan::class)->findLecturerActivitiesSum($lecturer);
            $meovLecturersSum = $this->em->getRepository(MeovLecturer::class)->findAllLecturerSum($lecturer);
        }

        $filter = [];

        if (!empty($request->query)) {
            $filter = $request->query;
        }

        $tableSearch = '';
        if (!empty($filter->get('lecturer'))) {
            $tableSearch = $filter->get('lecturer');
        }

        return $this->render('meovlecturerplan/index.html.twig', array(
            'meovLecturers' => $meovLecturers,
            'tableSearch' => $tableSearch,
            'activitiesPlans' => $activities,
            'activitiesPlansSum' => $activitiesSum,
            'meovLecturersSum' =>  $meovLecturersSum['meovHours'] ?? 0,
            'lectApprovals' => $this->em->getRepository(LecturerApprovedActivities::class)->getListByLecturerId(),
        ));
    }

    /**
     * Creates a new meovLecturer entity.
     *
     * @Method({"GET", "POST"})
     */
    #[Route(path: '/new', name: 'meovlecturer_plan_new')]
    public function newAction(Request $request)
    {

        if (!$this->dateValidator->isActiveProcessPlan()) {
            throw new AccessDeniedHttpException("Jūs negalite pasiekti šio turinio");
        }

        if ($this->dbDataFilter->getUserInfo()->getRole() === "ROLE_DEPARTMENT_ADMINISTRATOR") {
            $this->dbDataFilter->enableOnlyLecturerFilter();
        }

        $this->dbDataFilter->enableOnlyLecturerApprovedFilter();

        $meovLecturer = new Meovlecturer();
        $lecturer = $this->dbDataFilter->getLecturerFromUser();
        if ($lecturer) {
            $activitiesSum = $this->em->getRepository(ActivitiesPlan::class)->findLecturerActivitiesSum($lecturer);
            $meovLecturersSum = $this->em->getRepository(MeovLecturer::class)->findAllLecturerSum($lecturer);
        }
        $leftToPlan = ($activitiesSum['meovHours'] ?? 99999) - ($meovLecturersSum['meovHours'] ?? 0);

        $form = $this->createForm('App\Form\MeovLecturerPlanType', $meovLecturer, [
            'isEnabledDepartmentHeadComment' => $this->isGranted('ROLE_DEPARTMENT_HEAD'),
            'maxHours' => $leftToPlan,
            'plannedHours' => $meovLecturer->getHours(),
            'lecturerId' => null,
        ]);
        $form->handleRequest($request);

        if ($form->isSubmitted() && $form->isValid()) {
            $this->em->persist($meovLecturer);
            $this->em->flush();

            return $this->redirectToRoute('meovlecturer_plan_index', array('id' => $meovLecturer->getId()));
        }

        return $this->render('meovlecturerplan/new.html.twig', array(
                    'meovLecturer' => $meovLecturer,
                    'form' => $form->createView(),
        ));
    }

    /**
     * Displays a form to edit an existing meovLecturer entity.
     *
     * @Method({"GET", "POST"})
     */
    #[Route(path: '/{id}/edit', name: 'meovlecturer_plan_edit')]
    public function editAction(Request $request, MeovLecturer $meovLecturer)
    {
        if (!$this->dateValidator->isActiveProcessPlan()) {
            throw new AccessDeniedHttpException("Jūs negalite pasiekti šio turinio");
        }

        if ($this->dbDataFilter->getUserInfo()->getRole() === "ROLE_DEPARTMENT_ADMINISTRATOR") {
            $this->dbDataFilter->enableOnlyLecturerFilter();
        }

        $this->dbDataFilter->enableOnlyLecturerApprovedFilter();

        $deleteForm = $this->createDeleteForm($meovLecturer);
        $lecturer = $this->dbDataFilter->getLecturerFromUser();
        if ($lecturer) {
            $activitiesSum = $this->em->getRepository(ActivitiesPlan::class)->findLecturerActivitiesSum($lecturer);
            $meovLecturersSum = $this->em->getRepository(MeovLecturer::class)->findAllLecturerSum($lecturer);
        }

        $leftToPlan = ($activitiesSum['meovHours'] ?? 99999) - ($meovLecturersSum['meovHours'] ?? 0);

//        $activitiesSumByLecturer = $this->em->getRepository(ActivitiesPlan::class)->findActivitiesSumByLecturer();

//        dump($leftToPlan);
//        dump($activitiesSumByLecturer ?? []);
//        dump($activitiesSum ?? []);
//        dump($meovLecturersSum ?? []);

        $editForm = $this->createForm('App\Form\MeovLecturerPlanType', $meovLecturer, [
            'isEnabledDepartmentHeadComment' => $this->isGranted('ROLE_DEPARTMENT_HEAD'),
            'maxHours' => $leftToPlan,
            'plannedHours' => $meovLecturer->getHours(),
            'lecturerId' => $meovLecturer->getLecturer()?->getId(),
        ]);
        $editForm->handleRequest($request);

        if ($editForm->isSubmitted() && $editForm->isValid()) {
            $this->em->flush();

            return $this->redirectToRoute('meovlecturer_plan_edit', array('id' => $meovLecturer->getId()));
        }

        return $this->render('meovlecturerplan/edit.html.twig', array(
                    'meovLecturer' => $meovLecturer,
                    'edit_form' => $editForm->createView(),
                    'delete_form' => $deleteForm->createView(),
        ));
    }

    /**
     * Deletes a meovLecturer entity.
     *
     * @Method("DELETE")
     */
    #[Route(path: '/{id}', requirements: ['id' => '\d+'], name: 'meovlecturer_plan_delete')]
    public function deleteAction(Request $request, MeovLecturer $meovLecturer)
    {

        if (!$this->dateValidator->isActiveProcessPlan()) {
            throw new AccessDeniedHttpException("Jūs negalite pasiekti šio turinio");
        }

        $this->dbDataFilter->enableOnlyLecturerApprovedFilter();

        $form = $this->createDeleteForm($meovLecturer);
        $form->handleRequest($request);

        if ($form->isSubmitted() && $form->isValid()) {
            $this->em->remove($meovLecturer);
            try {
                $this->em->flush();
            } catch (Exception $ex) {
                $this->addFlash('warning', "Ištrinti įrašo nepavyko! Jis gali turėti susijusių įrašų." . $ex->getMessage());
            }
        }

        return $this->redirectToRoute('meovlecturer_plan_index');
    }

    /**
     * Creates a form to delete a meovLecturer entity.
     *
     * @param MeovLecturer $meovLecturer The meovLecturer entity
     *
     * @return Form The form
     */
    private function createDeleteForm(MeovLecturer $meovLecturer)
    {
        return $this->createFormBuilder()
                        ->setAction($this->generateUrl('meovlecturer_plan_delete', array('id' => $meovLecturer->getId())))
                        ->setMethod('DELETE')
                        ->getForm()
        ;
    }
}