ILIAS  trunk Revision v11.0_alpha-3011-gc6b235a2e85
class.ilADTDateTimeSearchBridgeRange.php
Go to the documentation of this file.
1<?php
2
19declare(strict_types=1);
20
25{
26 protected function isValidADTDefinition(ilADTDefinition $a_adt_def): bool
27 {
28 return ($a_adt_def instanceof ilADTDateTimeDefinition);
29 }
30
31 // table2gui / filter
32
33 public function loadFilter(): void
34 {
35 $value = $this->readFilter();
36 if (isset($value) && is_array($value)) {
37 if ($value["lower"] ?? false) {
38 $this->getLowerADT()->setDate(new ilDateTime($value["lower"], IL_CAL_DATETIME));
39 }
40 if ($value["upper"] ?? false) {
41 $this->getUpperADT()->setDate(new ilDateTime($value["upper"], IL_CAL_DATETIME));
42 }
43 }
44 }
45
46 // form
47
48 public function addToForm(): void
49 {
50 if ($this->getForm() instanceof ilPropertyFormGUI) {
51 // :TODO: use DateDurationInputGUI ?!
52
53 $check = new ilCustomInputGUI($this->getTitle());
54
55 $date_from = new ilDateTimeInputGUI($this->lng->txt('from'), $this->addToElementId("lower"));
56 $date_from->setShowTime(true);
57 $check->addSubItem($date_from);
58
59 if ($this->getLowerADT()->getDate() && !$this->getLowerADT()->isNull()) {
60 $date_from->setDate($this->getLowerADT()->getDate());
61 $checked = true;
62 }
63
64 $date_until = new ilDateTimeInputGUI($this->lng->txt('until'), $this->addToElementId("upper"));
65 $date_until->setShowTime(true);
66 $check->addSubItem($date_until);
67
68 if ($this->getUpperADT()->getDate() && !$this->getUpperADT()->isNull()) {
69 $date_until->setDate($this->getUpperADT()->getDate());
70 $checked = true;
71 }
72
74 } else {
75 // see ilTable2GUI::addFilterItemByMetaType()
76 $item = new ilCombinationInputGUI($this->getTitle(), $this->getElementId());
77
78 $lower = new ilDateTimeInputGUI("", $this->addToElementId("lower"));
79 $lower->setShowTime(true);
80 $item->addCombinationItem("lower", $lower, $this->lng->txt("from"));
81
82 if ($this->getLowerADT()->getDate() && !$this->getLowerADT()->isNull()) {
83 $lower->setDate($this->getLowerADT()->getDate());
84 }
85
86 $upper = new ilDateTimeInputGUI("", $this->addToElementId("upper"));
87 $upper->setShowTime(true);
88 $item->addCombinationItem("upper", $upper, $this->lng->txt("to"));
89
90 if ($this->getUpperADT()->getDate() && !$this->getUpperADT()->isNull()) {
91 $upper->setDate($this->getUpperADT()->getDate());
92 }
93
94 $item->setComparisonMode(ilCombinationInputGUI::COMPARISON_ASCENDING);
95
96 $this->addToParentElement($item);
97 }
98 }
99
100 protected function shouldBeImportedFromPost($a_post): bool
101 {
102 if ($this->getForm() instanceof ilPropertyFormGUI) {
103 return ($a_post['lower'] ?? false) || ($a_post['upper'] ?? false);
104 }
105 return parent::shouldBeImportedFromPost($a_post);
106 }
107
108 public function importFromPost(?array $a_post = null): bool
109 {
110 $post = $this->extractPostValues($a_post);
111
112 if ($post && $this->shouldBeImportedFromPost($post)) {
113 $start = ilCalendarUtil::parseIncomingDate($post["lower"], true);
114 $end = ilCalendarUtil::parseIncomingDate($post["upper"], true);
115 if ($start && $end && $start->get(IL_CAL_UNIX) > $end->get(IL_CAL_UNIX)) {
116 $tmp = $start;
117 $start = $end;
118 $end = $tmp;
119 }
120
121 if ($this->getForm() instanceof ilPropertyFormGUI) {
122 $item = $this->getForm()->getItemByPostVar($this->getElementId() . "[lower]");
123 $item->setDate($start);
124
125 $item = $this->getForm()->getItemByPostVar($this->getElementId() . "[upper]");
126 $item->setDate($end);
127 } elseif (array_key_exists($this->getElementId(), $this->table_filter_fields)) {
128 $this->table_filter_fields[$this->getElementId()]->getCombinationItem("lower")->setDate($start);
129 $this->table_filter_fields[$this->getElementId()]->getCombinationItem("upper")->setDate($end);
130 $this->writeFilter(array(
131 "lower" => (!$start || $start->isNull()) ? null : $start->get(IL_CAL_DATETIME),
132 "upper" => (!$end || $end->isNull()) ? null : $end->get(IL_CAL_DATETIME)
133 ));
134 }
135
136 $this->getLowerADT()->setDate($start);
137 $this->getUpperADT()->setDate($end);
138 } else {
139 $this->getLowerADT()->setDate();
140 $this->getUpperADT()->setDate();
141 }
142 return true;
143 }
144
145 // db
146
147 public function getSQLCondition(string $a_element_id, int $mode = self::SQL_LIKE, array $quotedWords = []): string
148 {
149 if (!$this->isNull() && $this->isValid()) {
150 $sql = array();
151 if (!$this->getLowerADT()->isNull()) {
152 $sql[] = $a_element_id . " >= " . $this->db->quote(
153 $this->getLowerADT()->getDate()->get(IL_CAL_DATETIME),
154 "timestamp"
155 );
156 }
157 if (!$this->getUpperADT()->isNull()) {
158 $sql[] = $a_element_id . " <= " . $this->db->quote(
159 $this->getUpperADT()->getDate()->get(IL_CAL_DATETIME),
160 "timestamp"
161 );
162 }
163 return "(" . implode(" AND ", $sql) . ")";
164 }
165 return '';
166 }
167
168 public function isInCondition(ilADT $a_adt): bool
169 {
170 assert($a_adt instanceof ilADTDateTime);
171
172 if (!$this->getLowerADT()->isNull() && !$this->getUpperADT()->isNull()) {
173 return (bool) $a_adt->isInbetweenOrEqual($this->getLowerADT(), $this->getUpperADT());
174 } elseif (!$this->getLowerADT()->isNull()) {
175 return (bool) $a_adt->isLargerOrEqual($this->getLowerADT());
176 } else {
177 return (bool) $a_adt->isSmallerOrEqual($this->getUpperADT());
178 }
179 }
180
181 // import/export
182
183 public function getSerializedValue(): string
184 {
185 if (!$this->isNull() && $this->isValid()) {
186 $res = array();
187 if (!$this->getLowerADT()->isNull()) {
188 $res["lower"] = $this->getLowerADT()->getDate()->get(IL_CAL_DATETIME);
189 }
190 if (!$this->getUpperADT()->isNull()) {
191 $res["upper"] = $this->getUpperADT()->getDate()->get(IL_CAL_DATETIME);
192 }
193 return serialize($res);
194 }
195 return '';
196 }
197
198 public function setSerializedValue(string $a_value): void
199 {
200 $a_value = unserialize($a_value);
201 if (is_array($a_value)) {
202 if (isset($a_value["lower"])) {
203 $this->getLowerADT()->setDate(new ilDateTime($a_value["lower"], IL_CAL_DATETIME));
204 }
205 if (isset($a_value["upper"])) {
206 $this->getUpperADT()->setDate(new ilDateTime($a_value["upper"], IL_CAL_DATETIME));
207 }
208 }
209 }
210}
$check
Definition: buildRTE.php:81
const IL_CAL_UNIX
const IL_CAL_DATETIME
Class ilADTDateTimeSearchBridgeRange.
setSerializedValue(string $a_value)
Set current value(s) in serialized form (for easy persisting)
shouldBeImportedFromPost($a_post)
Check if incoming values should be imported at all.
isInCondition(ilADT $a_adt)
Compare directly against ADT.
getSQLCondition(string $a_element_id, int $mode=self::SQL_LIKE, array $quotedWords=[])
Get SQL condition for current value(s)
getSerializedValue()
Get current value(s) in serialized form (for easy persisting)
ADT definition base class.
Class ilADTSearchBridgeRange.
addToElementId(string $a_add)
Add sub-element.
readFilter()
Load value(s) from filter store (in session)
extractPostValues(?array $a_post=null)
Extract data from (post) values.
addToParentElement(ilFormPropertyGUI $a_field)
Add form field to parent element.
writeFilter($a_value=null)
Write value(s) to filter store (in session)
ADT base class.
Definition: class.ilADT.php:26
isSmallerOrEqual(ilADT $a_adt)
Check if given ADT is smaller or equal than self.
isLargerOrEqual(ilADT $a_adt)
isInbetweenOrEqual(ilADT $a_adt_from, ilADT $a_adt_to)
Check if self is inbetween given ADTs (inclusive)
static parseIncomingDate($value, bool $add_time=false)
Try to parse incoming value to date object.
This class represents a number property in a property form.
This class represents a custom property in a property form.
This class represents a date/time property in a property form.
@classDescription Date and time handling
This class represents a property form user interface.
$res
Definition: ltiservices.php:69
$post
Definition: ltitoken.php:46