summaryrefslogtreecommitdiff
path: root/src/controller/ajax_calendar_visitor.php
blob: dcdbebdc0dbc79e239b0c637b1b01524317ae187 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
<?php
// src/controller/ajax_calendar_visitor.php

declare(strict_types=1);

use App\Entity\Event;

// chargement des évènements à la création du calendrier
// et au changement de dates affichées (boutons flèches mais pas changement de vue)
if($_SERVER['REQUEST_METHOD'] === 'GET' && isset($_GET['action']) && $_GET['action'] === 'get_events'
    && isset($_GET['start']) && isset($_GET['end']) && empty($_POST))
{
	// bornes début et fin du calendrier affiché à l'heure locale
    // noter que la vue "planning" est similaire à la vue "semaine"
    $start = new DateTime($_GET['start']);
    $end = new DateTime($_GET['end']);
    $start->setTimezone(new DateTimeZone('UTC'));
    $end->setTimezone(new DateTimeZone('UTC'));

    // affichage format ISO à l'heure UTC
    //$date->format('Y-m-d\TH:i:s\Z');

    // on prend les évènements se finissant après le début ou commençant avant la fin de la fourchette
    $dql = 'SELECT e FROM App\Entity\Event e WHERE e.end >= :start AND e.start <= :end';
    $bulk_data = $entityManager->createQuery($dql)
        ->setParameter('start', $start)
        ->setParameter('end', $end)
        ->getResult();

    $events = [];
    foreach($bulk_data as $one_entry){
        $event = new EventDTO($one_entry);
        $events[] = $event->toArray();
    }

    header('Content-Type: application/json');
    echo json_encode($events);
    die;
}