namespace Rapsys\AirBundle\Controller;
use Rapsys\AirBundle\Entity\Application;
+use Rapsys\AirBundle\Entity\Location;
use Rapsys\AirBundle\Entity\Session;
+use Rapsys\AirBundle\Entity\Slot;
+use Rapsys\AirBundle\Entity\User;
use Symfony\Bridge\Twig\Mime\TemplatedEmail;
use Symfony\Bundle\FrameworkBundle\Controller\AbstractController;
use Symfony\Component\DependencyInjection\ContainerInterface;
use Symfony\Component\HttpFoundation\Request;
use Symfony\Component\Mailer\Exception\TransportExceptionInterface;
use Symfony\Component\Mailer\MailerInterface;
-use Symfony\Component\Mime\NamedAddress;
+use Symfony\Component\Mime\Address;
use Symfony\Component\Routing\Generator\UrlGeneratorInterface;
+use Symfony\Component\Routing\RouterInterface;
use Symfony\Component\Translation\TranslatorInterface;
+use Rapsys\UserBundle\Utils\Slugger;
+use Symfony\Bundle\FrameworkBundle\Controller\ControllerTrait;
+use Symfony\Component\DependencyInjection\ContainerAwareTrait;
-class DefaultController extends AbstractController {
- //Config array
+
+class DefaultController {
+ use ControllerTrait;
+
+ ///Config array
protected $config;
- //Translator instance
+ ///Context array
+ protected $context;
+
+ ///Router instance
+ protected $router;
+
+ ///Slugger instance
+ protected $slugger;
+
+ ///Translator instance
protected $translator;
- public function __construct(ContainerInterface $container, TranslatorInterface $translator) {
+ /**
+ * @var ContainerInterface
+ */
+ protected $container;
+
+ /**
+ * Inject container and translator interface
+ *
+ * @param ContainerInterface $container The container instance
+ * @param RouterInterface $router The router instance
+ * @param Slugger $slugger The slugger instance
+ * @param TranslatorInterface $translator The translator instance
+ */
+ public function __construct(ContainerInterface $container, RouterInterface $router, Slugger $slugger, TranslatorInterface $translator) {
//Retrieve config
$this->config = $container->getParameter($this->getAlias());
+ //Set the container
+ $this->container = $container;
+
+ //Set the router
+ $this->router = $router;
+
+ //Set the slugger
+ $this->slugger = $slugger;
+
//Set the translator
$this->translator = $translator;
+
+ //Set the context
+ $this->context = [
+ 'copy_long' => $translator->trans($this->config['copy']['long']),
+ 'copy_short' => $translator->trans($this->config['copy']['short']),
+ 'site_ico' => $this->config['site']['ico'],
+ 'site_logo' => $this->config['site']['logo'],
+ 'site_png' => $this->config['site']['png'],
+ 'site_svg' => $this->config['site']['svg'],
+ 'site_title' => $translator->trans($this->config['site']['title']),
+ 'site_url' => $router->generate($this->config['site']['url'])
+ ];
}
+ /**
+ * The contact page
+ *
+ * @desc Send a contact mail to configured contact
+ *
+ * @param Request $request The request instance
+ * @param MailerInterface $mailer The mailer instance
+ *
+ * @return Response The rendered view or redirection
+ */
public function contact(Request $request, MailerInterface $mailer) {
//Set section
$section = $this->translator->trans('Contact');
//Create the form according to the FormType created previously.
//And give the proper parameters
$form = $this->createForm('Rapsys\AirBundle\Form\ContactType', null, [
- // To set the action use $this->generateUrl('route_identifier')
'action' => $this->generateUrl('rapsys_air_contact'),
'method' => 'POST'
]);
//Create message
$message = (new TemplatedEmail())
//Set sender
- ->from(new NamedAddress($data['mail'], $data['name']))
+ ->from(new Address($data['mail'], $data['name']))
//Set recipient
//XXX: remove the debug set in vendor/symfony/mime/Address.php +46
- ->to(new NamedAddress($this->config['contact']['mail'], $this->config['contact']['name']))
+ ->to(new Address($this->config['contact']['mail'], $this->config['contact']['name']))
//Set subject
->subject($data['subject'])
//Set context
->context(
[
- 'site_logo' => $this->config['site']['logo'],
- 'site_title' => $this->config['site']['title'],
- 'site_url' => $this->get('router')->generate('rapsys_air_homepage', [], UrlGeneratorInterface::ABSOLUTE_URL),
- 'copy_long' => $this->config['copy']['long'],
- 'copy_short' => $this->config['copy']['short'],
'subject' => $data['subject'],
'message' => strip_tags($data['message']),
- ]
+ ]+$this->context
);
//Try sending message
}
//Render template
- return $this->render('@RapsysAir/form/contact.html.twig', ['title' => $title, 'section' => $section, 'form' => $form->createView(), 'sent' => $request->query->get('sent', 0)]);
- }
-
- public function index() {
- //Set section
- $section = $this->translator->trans('Index');
-
- //Set title
- $title = $section.' - '.$this->translator->trans($this->config['site']['title']);
-
- //Render template
- return $this->render('@RapsysAir/page/index.html.twig', ['title' => $title, 'section' => $section]);
+ return $this->render('@RapsysAir/form/contact.html.twig', ['title' => $title, 'section' => $section, 'form' => $form->createView(), 'sent' => $request->query->get('sent', 0)]+$this->context);
}
- public function admin(Request $request) {
- //Prevent non-admin to access here
- $this->denyAccessUnlessGranted('ROLE_GUEST', null, 'Unable to access this page without ROLE_GUEST!');
+ /**
+ * The index page
+ *
+ * @desc Display all granted sessions with an application or login form
+ *
+ * @param Request $request The request instance
+ *
+ * @return Response The rendered view
+ */
+ public function index(Request $request = null) {
+ //Fetch doctrine
+ $doctrine = $this->getDoctrine();
//Set section
- $section = $this->translator->trans('Admin');
+ $section = $this->translator->trans('Index');
//Set title
$title = $section.' - '.$this->translator->trans($this->config['site']['title']);
- header('Content-Type: text/plain');
- var_dump('TODO');
- exit;
- //Create the form according to the FormType created previously.
- //And give the proper parameters
- $form = $this->createForm('Rapsys\AirBundle\Form\ApplicationType', null, [
- // To set the action use $this->generateUrl('route_identifier')
- 'action' => $this->generateUrl('rapsys_air_admin'),
- 'method' => 'POST',
- 'attr' => [ 'class' => 'form_col' ]
- ]);
-
- //Get doctrine
- $doctrine = $this->getDoctrine();
-
- //Handle request
- if ($request->isMethod('POST')) {
- // Refill the fields in case the form is not valid.
- $form->handleRequest($request);
-
- if ($form->isValid()) {
- //Get data
- $data = $form->getData();
-
- //Get manager
- $manager = $doctrine->getManager();
-
- //Protect session fetching
- try {
- $session = $doctrine->getRepository(Session::class)->findOneByLocationSlotDate($data['location'], $data['slot'], $data['date']);
- //Catch no session case
- } catch (\Doctrine\ORM\NoResultException $e) {
- //Create the session
- $session = new Session();
- $session->setLocation($data['location']);
- $session->setSlot($data['slot']);
- $session->setDate($data['date']);
- $session->setCreated(new \DateTime('now'));
- $session->setUpdated(new \DateTime('now'));
- $manager->persist($session);
- //Flush to get the ids
- #$manager->flush();
- }
-
- //Init application
- $application = false;
-
- //Protect application fetching
- try {
- //TODO: handle admin case where we provide a user in extra
- $application = $doctrine->getRepository(Application::class)->findOneBySessionUser($session, $this->getUser());
-
- //Add error message to mail field
- $form->get('slot')->addError(new FormError($this->translator->trans('Application already exists')));
- //Catch no application cases
- //XXX: combine these catch when php 7.1 is available
- } catch (\Doctrine\ORM\NoResultException $e) {
- //Catch invalid argument because session is not already persisted
- } catch(\Doctrine\ORM\ORMInvalidArgumentException $e) {
- }
-
- //Create new application if none found
- if (!$application) {
- //Create the application
- $application = new Application();
- $application->setSession($session);
- //TODO: handle admin case where we provide a user in extra
- $application->setUser($this->getUser());
- $application->setCreated(new \DateTime('now'));
- $application->setUpdated(new \DateTime('now'));
- $manager->persist($application);
-
- //Flush to get the ids
- $manager->flush();
-
- //Add notice in flash message
- $this->addFlash('notice', $this->translator->trans('Application request the %date% for %location% on the slot %slot% saved', ['%location%' => $data['location']->getTitle(), '%slot%' => $data['slot']->getTitle(), '%date%' => $data['date']->format('Y-m-d')]));
-
- //Redirect to cleanup the form
- return $this->redirectToRoute('rapsys_air_admin');
- }
- }
+ //Init context
+ $context = [];
+
+ //Create application form for role_guest
+ if ($this->isGranted('ROLE_GUEST')) {
+ //Create ApplicationType form
+ $application = $this->createForm('Rapsys\AirBundle\Form\ApplicationType', null, [
+ //Set the action
+ 'action' => $this->generateUrl('rapsys_air_application_add'),
+ //Set the form attribute
+ 'attr' => [ 'class' => 'col' ],
+ //Set admin
+ 'admin' => $this->isGranted('ROLE_ADMIN'),
+ //Set default user to current
+ 'user' => $this->getUser()->getId(),
+ //Set default slot to evening
+ //XXX: default to Evening (3)
+ 'slot' => $doctrine->getRepository(Slot::class)->findOneById(3)
+ ]);
+
+ //Add form to context
+ $context['application'] = $application->createView();
+ //Create login form for anonymous
+ } elseif (!$this->isGranted('IS_AUTHENTICATED_REMEMBERED')) {
+ //Create ApplicationType form
+ $login = $this->createForm('Rapsys\UserBundle\Form\LoginType', null, [
+ //Set the action
+ 'action' => $this->generateUrl('rapsys_user_login'),
+ //Set the form attribute
+ 'attr' => [ 'class' => 'col' ]
+ ]);
+
+ //Add form to context
+ $context['login'] = $login->createView();
}
//Compute period
new \DateTime('Monday this week + 5 week')
);
- //Fetch sessions
- $sessions = $doctrine->getRepository(Session::class)->findByDatePeriod($period);
-
- //Init calendar
- $calendar = [];
-
- //Init month
- $month = null;
-
- //Iterate on each day
- foreach($period as $date) {
- //Init day in calendar
- $calendar[$Ymd = $date->format('Ymd')] = [
- 'title' => $date->format('d'),
- 'class' => [],
- 'sessions' => []
- ];
- //Append month for first day of month
- if ($month != $date->format('m')) {
- $month = $date->format('m');
- $calendar[$Ymd]['title'] .= '/'.$month;
- }
- //Deal with today
- if ($date->format('U') == ($today = strtotime('today'))) {
- $calendar[$Ymd]['title'] .= '/'.$month;
- $calendar[$Ymd]['current'] = true;
- $calendar[$Ymd]['class'][] = 'current';
- }
- //Disable passed days
- if ($date->format('U') < $today) {
- $calendar[$Ymd]['disabled'] = true;
- $calendar[$Ymd]['class'][] = 'disabled';
- }
- //Set next month days
- if ($date->format('m') > date('m')) {
- $calendar[$Ymd]['next'] = true;
- $calendar[$Ymd]['class'][] = 'next';
- }
- //Iterate on each session to find the one of the day
- foreach($sessions as $session) {
- if (($sessionYmd = $session->getDate()->format('Ymd')) == $Ymd) {
- //Count number of application
- $count = count($session->getApplications());
-
- //Compute classes
- $class = [];
- if ($session->getApplication()) {
- $class[] = 'granted';
- } elseif ($count == 0) {
- $class[] = 'orphaned';
- } elseif ($count > 1) {
- $class[] = 'disputed';
- } else {
- $class[] = 'pending';
- }
+ //Fetch calendar
+ $calendar = $doctrine->getRepository(Session::class)->fetchCalendarByDatePeriod($this->translator, $period, null, $request->get('session'), !$this->isGranted('IS_AUTHENTICATED_REMEMBERED'));
- //Add the session
- $calendar[$Ymd]['sessions'][$session->getSlot()->getId().$session->getLocation()->getId()] = [
- 'id' => $session->getId(),
- 'title' => ($count > 1?'['.$count.'] ':'').$session->getSlot()->getTitle().' '.$session->getLocation()->getTitle(),
- 'class' => $class
- ];
- }
- }
-
- //Sort sessions
- ksort($calendar[$Ymd]['sessions']);
- }
+ //Fetch locations
+ //XXX: we want to display all active locations anyway
+ $locations = $doctrine->getRepository(Location::class)->fetchTranslatedLocationByDatePeriod($this->translator, $period/*, !$this->isGranted('IS_AUTHENTICATED_REMEMBERED')*/);
- return $this->render('@RapsysAir/admin/index.html.twig', ['title' => $title, 'section' => $section, 'form' => $form->createView(), 'calendar' => $calendar]);
+ //Render the view
+ return $this->render('@RapsysAir/default/index.html.twig', ['title' => $title, 'section' => $section, 'calendar' => $calendar, 'locations' => $locations]+$context+$this->context);
}
- public function session(Request $request, $id) {
- /*header('Content-Type: text/plain');
- var_dump($calendar);
- exit;*/
+ /**
+ * The regulation page
+ *
+ * @desc Display the regulation policy
+ *
+ * @return Response The rendered view
+ */
+ public function regulation() {
//Set section
- $section = $this->translator->trans('Session %id%', ['%id%' => $id]);
+ $section = $this->translator->trans('Regulation');
//Set title
$title = $section.' - '.$this->translator->trans($this->config['site']['title']);
- //Create the form according to the FormType created previously.
- //And give the proper parameters
- /*$form = $this->createForm('Rapsys\AirBundle\Form\ApplicationType', null, [
- // To set the action use $this->generateUrl('route_identifier')
- 'action' => $this->generateUrl('rapsys_air_admin'),
- 'method' => 'POST',
- 'attr' => [ 'class' => 'form_col' ]
- ]);*/
-
- //Get doctrine
- $doctrine = $this->getDoctrine();
-
- //Fetch session
- $session = $doctrine->getRepository(Session::class)->findOneById($id);
-
- return $this->render('@RapsysAir/admin/session.html.twig', ['title' => $title, 'section' => $section, /*'form' => $form->createView(),*/ 'session' => $session]);
+ //Render template
+ return $this->render('@RapsysAir/default/regulation.html.twig', ['title' => $title, 'section' => $section]+$this->context);
}
/**
+ * Return the bundle alias
+ *
* {@inheritdoc}
*/
public function getAlias() {