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 [];
}
}
?>
|