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