ILIAS  trunk Revision v11.0_alpha-1843-g9e1fad99175
All Data Structures Namespaces Files Functions Variables Enumerations Enumerator Modules Pages
class.ilADTDateTimeSearchBridgeRange.php
Go to the documentation of this file.
1 <?php
2 
19 declare(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 
73  $this->addToParentElement($check);
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 }
$res
Definition: ltiservices.php:66
static parseIncomingDate($value, bool $add_time=false)
Try to parse incoming value to date object.
const IL_CAL_DATETIME
isLargerOrEqual(ilADT $a_adt)
Class ilADTDateTimeSearchBridgeRange.
isInbetweenOrEqual(ilADT $a_adt_from, ilADT $a_adt_to)
Check if self is inbetween given ADTs (inclusive)
setShowTime(bool $a_showtime)
isSmallerOrEqual(ilADT $a_adt)
Check if given ADT is smaller or equal than self.
const IL_CAL_UNIX
ADT base class.
Definition: class.ilADT.php:25
This class represents a date/time property in a property form.
while($session_entry=$r->fetchRow(ilDBConstants::FETCHMODE_ASSOC)) return null
getSQLCondition(string $a_element_id, int $mode=self::SQL_LIKE, array $quotedWords=[])
readFilter()
Load value(s) from filter store (in session)
extractPostValues(?array $a_post=null)
Extract data from (post) values.
This class represents a number property in a property form.
writeFilter($a_value=null)
Write value(s) to filter store (in session)
Class ilADTSearchBridgeRange.
$check
Definition: buildRTE.php:81
addToElementId(string $a_add)
Add sub-element.
$post
Definition: ltitoken.php:46
ADT definition base class.
addToParentElement(ilFormPropertyGUI $a_field)
Add form field to parent element.