summaryrefslogtreecommitdiff
path: root/app/frontend/facades/EventFacade.php
blob: 79ca3638aeb2d5623bfe649576cda02d689eccb2 (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
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
<?php

Prado::using('Application.facades.Facade');
Prado::using('Application.dto.EventDTO');
Prado::using('Application.dto.TimezoneDTO');
Prado::using('Application.dto.GridEventDTO');
Prado::using('Application.dto.CalendarGridDTO');
Prado::using('Application.dto.GroupedCalendarGridDTO');
Prado::using('Application.model.Calendar');
Prado::using('Application.facades.CalendarFacade');
Prado::using('Application.user.DbUser');

class EventFacade extends Facade {

    public function getEventList(string $dateFrom=NULL, string $dateTo=NULL,
                                 array $calendars=NULL, string $order='ASC') {
        $calendarClause = '1=1';
        if ($calendars) {
            $calendarClause = sprintf(
                '_calendar IN (%s)',
                implode(
                    ',',
                    array_map(
                        function($calendar) {
                            return $this->quoteString($calendar->UID);
                        },
                        $calendars
                    )
                )
            );
        }
        return $this->fetchList(
            'getEvents',
            [
                'date_from' => $dateFrom ?: '0000-00-00 00:00:00',
                'date_to' => $dateTo ?: '9999-99-99',
                'calendar_clause' => $calendarClause,
                'order_clause' => $order
            ]
        );
    }

    private function _compileEventObjects(array $events, array $calendars,
                                          TimezoneDTO $tz,
                                          string $class = 'Application.dto.EventDTO') {
        return array_map(
            function($event) use($calendars, $class, $tz) {
                $dto = Prado::createComponent($class, $tz);
                $dto->loadRecord($event, $calendars);
                return $dto;
            },
            $events
        );
    }

    public function getTimeframeListForUser(
        DbUser $user,
        DateTime $dateFrom, DateTime $dateTo,
        string $returnClass = 'Application.dto.EventDTO') {
        $calendars = CalendarFacade::getInstance()->getCalendarPreference($user);
        if ($calendars) {
            $events = $this->getEventList(
                $dateFrom->format('Y-m-d H:i:s'),
                $dateTo->format('Y-m-d H:i:s'),
                $calendars
            );
            $calendars = $this->_getCalendarsForEvents($events);
            return $this->_compileEventObjects(
                $events, $calendars,
                UserFacade::getInstance()->getTimezonePreference($user),
                $returnClass);
        }
        return [];
    }

    public function getCalendarListForUser(DbUser $user,
                                           $month, $year) {
        if (!$year) {
            $year = intval(date('Y'));
        }
        if (!$month) {
            $month = intval(date('m'));
        }
        $timezone = $user
            ? UserFacade::getInstance()->getTimezonePreference($user)
            : new TimezoneDTO(date_default_timezone_get());
        $timeframe = CalendarFacade::getInstance()->getCalendarBoundaries(
            $year, $month, $timezone
        );
        $dtoClass = 'CalendarGridDTO';
        if (UserFacade::getInstance()->getGroupedViewPreference($user)) {
            $dtoClass = 'Grouped' . $dtoClass;
        }
        return new $dtoClass(
            $this->getTimeframeListForUser(
                $user,
                $timeframe[0], $timeframe[1],
                'Application.dto.GridEventDTO'
            ),
            ...$timeframe
        );
    }

    private function _getCalendarsForEvents(array $events) {
        if ($events) {
            return Calendar::finder()->findAllByPks(
                array_map(
                    function($event) {
                        return $event->CalendarID;
                    },
                    $events
                )
            );
        }
        return [];
    }

}

?>