Finaly got the routing right.

This commit is contained in:
Tim Schumacher 2014-07-19 20:07:07 +02:00
parent 6f0b6eabef
commit 8f66f58965
2 changed files with 67 additions and 87 deletions

View file

@ -2,6 +2,7 @@
namespace Hackspace\Bundle\CalciferBundle\Controller;
use Doctrine\Common\Annotations\Annotation\Required;
use Doctrine\ORM\EntityManager;
use Doctrine\ORM\EntityRepository;
use Doctrine\ORM\QueryBuilder;
@ -35,11 +36,11 @@ class LocationController extends Controller
/**
* Finds and displays a Event entity.
*
* @Route("/{slug}(?!\.ics)", name="location_show")
* @Route("/{slug}.{format}", name="location_show", defaults={"format" = "html"})
* @Method("GET")
* @Template("CalciferBundle:Event:index.html.twig")
*/
public function showAction($slug)
public function showAction($slug,$format)
{
/** @var EntityManager $em */
$em = $this->getDoctrine()->getManager();
@ -67,39 +68,22 @@ class LocationController extends Controller
->andWhere('e.locations_id = :location')
->orderBy('e.startdate')
->setParameter('startdate',$now)
->setParameter('location',$location->getId());
->setParameter('location',$location->id);
$entities = $qb->getQuery()->execute();
return array(
'entities' => $entities,
'location' => $location,
);
}
/**
* Finds and displays a Event entity.
*
* @Route("/{slug}\.ics", name="location_show_ics")
* @Method("GET")
*/
public function showActionICS($slug)
{
$results = $this->showAction(str_replace('.ics','',$slug));
$entities = $results['entities'];
if ($format == 'ics') {
$calendar = new Calendar();
$calendar->setProdId('-//My Company//Cool Calendar App//EN');
foreach ($entities as $entity) {
/** @var Event $entity */
$event = new CalendarEvent();
$event->setStart($entity->getStartdate());
if ($entity->getEnddate() instanceof DateTime)
$event->setEnd($entity->getEnddate());
$event->setSummary($entity->getSummary());
$event->setDescription($entity->getDescription());
$event->setStart($entity->startdate);
$event->setEnd($entity->enddate);
$event->setSummary($entity->summary);
$event->setDescription($entity->description);
$location = new \Jsvrcek\ICS\Model\Description\Location();
$location->setName($entity->getLocation()->getName());
$location->setName($entity->getLocation()->name);
$event->setLocations([$location]);
$calendar->addEvent($event);
}
@ -114,5 +98,11 @@ class LocationController extends Controller
$response->headers->set('Content-Type', 'text/calendar');
return $response;
} else {
return array(
'entities' => $entities,
'location' => $location,
);
}
}
}

View file

@ -35,11 +35,11 @@ class TagController extends Controller
/**
* Finds and displays a Event entity.
*
* @Route("/{slug}(?!\.ics)", name="tag_show")
* @Route("/{slug}.{format}", defaults={"format" = "html"}, name="tag_show")
* @Method("GET")
* @Template("CalciferBundle:Event:index.html.twig")
*/
public function showAction($slug)
public function showAction($slug, $format)
{
/** @var EntityManager $em */
$em = $this->getDoctrine()->getManager();
@ -67,35 +67,19 @@ class TagController extends Controller
->setParameter('startdate', $now);
$entities = $qb->getQuery()->execute();
return array(
'entities' => $entities,
'tag' => $tag,
);
}
/**
* Finds and displays a Event entity.
*
* @Route("/{slug}.ics", name="tag_show_ics")
* @Method("GET")
*/
public function showActionICS($slug)
{
$results = $this->showAction(str_replace('.ics','',$slug));
$entities = $results['entities'];
if ($format == 'ics') {
$calendar = new Calendar();
$calendar->setProdId('-//My Company//Cool Calendar App//EN');
foreach ($entities as $entity) {
/** @var Event $entity */
$event = new CalendarEvent();
$event->setStart($entity->getStartdate());
$event->setEnd($entity->getEnddate());
$event->setSummary($entity->getSummary());
$event->setDescription($entity->getDescription());
$event->setStart($entity->startdate);
$event->setEnd($entity->enddate);
$event->setSummary($entity->summary);
$event->setDescription($entity->description);
$location = new \Jsvrcek\ICS\Model\Description\Location();
$location->setName($entity->getLocation()->getName());
$location->setName($entity->getLocation()->name);
$event->setLocations([$location]);
$calendar->addEvent($event);
}
@ -110,5 +94,11 @@ class TagController extends Controller
$response->headers->set('Content-Type', 'text/calendar');
return $response;
} else {
return array(
'entities' => $entities,
'tag' => $tag,
);
}
}
}