You cannot select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
117 lines
4.5 KiB
PHP
117 lines
4.5 KiB
PHP
<?php
|
|
|
|
namespace KekRozsak\FrontBundle\Controller;
|
|
|
|
use Symfony\Bundle\FrameworkBundle\Controller\Controller;
|
|
use Sensio\Bundle\FrameworkExtraBundle\Configuration\Route;
|
|
use Sensio\Bundle\FrameworkExtraBundle\Configuration\Template;
|
|
use Sensio\Bundle\FrameworkExtraBundle\Configuration\ParamConverter;
|
|
use Symfony\Component\Security\Core\Exception\AccessDeniedException;
|
|
|
|
use KekRozsak\FrontBundle\Entity\Event;
|
|
|
|
class EventController extends Controller
|
|
{
|
|
/**
|
|
* @param DateTime $startDate
|
|
* @param KekRozsak\FrontBundle\Entity\Event $event
|
|
* @return array
|
|
*
|
|
* @Route("/esesmenyek/{startDate}/{eventSlug}.html", name="KekRozsakFrontBundle_eventView")
|
|
* @Template()
|
|
* @ParamConverter("event", class="KekRozsakFrontBundle:Event", options={"mapping"={"eventSlug" = "slug", "startDate"="startDate"}})
|
|
* @ParamConverter("startDate", class="DateTime", options={"format"="Y-m-d"})
|
|
*/
|
|
public function viewAction(\DateTime $startDate, Event $event)
|
|
{
|
|
if ($event->getGroup() !== null) {
|
|
if (!$event->getGroup()->isMember($this->get('security.context')->getToken()->getUser())) {
|
|
throw new AccessDeniedException('Ehhez az eseményhez nem csatlakozhatsz, mivel a csoportjának nem vagy tagja.');
|
|
}
|
|
}
|
|
|
|
return array(
|
|
'event' => $event,
|
|
);
|
|
}
|
|
|
|
/**
|
|
* @param DateTime $startDate
|
|
* @param KekRozsak\FrontBundle\Entity\Event $event
|
|
* @return array
|
|
*
|
|
* @Route("/esemenyek/{startDate}/{eventSlug}/csatlakozas.do", name="KekRozsakFrontBundle_eventJoin")
|
|
* @Template()
|
|
* @ParamConverter("event", class="KekRozsakFrontBundle:Event", options={"mapping"={"eventSlug": "slug", "startDate": "startDate"}})
|
|
* @ParamConverter("startDate", class="DateTime", options={"format"="Y-m-d"})
|
|
*/
|
|
public function joinAction(\DateTime $startDate, Event $event)
|
|
{
|
|
$user = $this->get('security.context')->getToken()->getUser();
|
|
|
|
if ($event->getGroup() !== null) {
|
|
if (!$event->getGroup()->isMember($user)) {
|
|
throw new AccessDeniedException('Ehhez az eseményhez nem csatlakozhatsz, mivel a csoportjának nem vagy tagja.');
|
|
}
|
|
}
|
|
|
|
$event->addAttendee($user);
|
|
|
|
$em = $this->getDoctrine()->getManager();
|
|
$em->persist($event);
|
|
$em->flush();
|
|
|
|
return $this->redirect($this->generateUrl('KekRozsakFrontBundle_eventView', array(
|
|
'eventDate' => $eventDate,
|
|
'eventSlug' => $eventSlug,
|
|
)));
|
|
}
|
|
|
|
/**
|
|
* @param string $date
|
|
* @return array
|
|
*
|
|
* @Route("/esemenyek/{date}", name="KekRozsakFrontBundle_eventList", defaults={"date": null})
|
|
* @Template()
|
|
*/
|
|
public function listAction($date = null)
|
|
{
|
|
$realDate = null;
|
|
|
|
if ($date === null) {
|
|
$query = $this->getDoctrine()->getManager()->createQuery('SELECT e FROM KekRozsakFrontBundle:Event e WHERE e.cancelled = FALSE AND (e.startDate >= :day OR (e.startDate <= :day AND e.endDate >= :day))');
|
|
$query->setParameter('day', new \DateTime('now'), \Doctrine\DBAL\Types\Type::DATE);
|
|
} else {
|
|
$realDate = \DateTime::createFromFormat('Y-m-d', $date);
|
|
$query = $this->getDoctrine()->getManager()->createQuery('SELECT e FROM KekRozsakFrontBundle:Event e WHERE e.cancelled = FALSE AND ((e.startDate < :day AND e.endDate >= :day) OR e.startDate = :day)');
|
|
$query->setParameter('day', $realDate, \Doctrine\DBAL\Types\Type::DATE);
|
|
}
|
|
$events = $query->getResult();
|
|
|
|
return array(
|
|
'day' => $realDate,
|
|
'events' => $events,
|
|
);
|
|
}
|
|
|
|
/**
|
|
* @param DateTime $date
|
|
* @return array
|
|
*
|
|
* @Route("/esemenyek/{date}/ajax-lista.{_format}", name="KekRozsakFrontBundle_eventAjaxList", requirements={"_format": "html"})
|
|
* @Template()
|
|
* @ParamConverter("date", options={"format": "Y-m-d"})
|
|
*/
|
|
public function ajaxListAction(\DateTime $date)
|
|
{
|
|
$query = $this->getDoctrine()->getManager()->createQuery('SELECT e FROM KekRozsakFrontBundle:Event e WHERE e.cancelled = FALSE AND ((e.startDate < :day AND e.endDate >= :day) OR e.startDate = :day)');
|
|
$query->setParameter('day', $date, \Doctrine\DBAL\Types\Type::DATE);
|
|
$events = $query->getResult();
|
|
|
|
return array(
|
|
'day' => $date,
|
|
'events' => $events,
|
|
);
|
|
}
|
|
}
|