ILIAS  release_8 Revision v8.19
All Data Structures Namespaces Files Functions Variables Modules Pages
class.ilADTTextSearchBridgeSingle.php
Go to the documentation of this file.
1 <?php
2 
19 declare(strict_types=1);
20 
22 {
23  public const SQL_STRICT = 1;
24  public const SQL_LIKE = 2;
25  public const SQL_LIKE_END = 3;
26  public const SQL_LIKE_START = 4;
27 
28  protected function isValidADTDefinition(ilADTDefinition $a_adt_def): bool
29  {
30  return ($a_adt_def instanceof ilADTTextDefinition);
31  }
32 
33  // table2gui / filter
34 
35  public function loadFilter(): void
36  {
37  $value = $this->readFilter();
38  if ($value !== null) {
39  $this->getADT()->setText($value);
40  }
41  }
42 
43  // form
44 
45  public function addToForm(): void
46  {
47  $text = new ilTextInputGUI($this->getTitle(), $this->getElementId());
48  $text->setSize(20);
49  $text->setMaxLength(512);
50  $text->setSubmitFormOnEnter(true);
51 
52  $text->setValue($this->getADT()->getText());
53 
54  $this->addToParentElement($text);
55  }
56 
57  public function importFromPost(array $a_post = null): bool
58  {
59  $post = $this->extractPostValues($a_post);
60 
61  if ($post && $this->shouldBeImportedFromPost($post)) {
62  if ($this->getForm() instanceof ilPropertyFormGUI) {
63  $item = $this->getForm()->getItemByPostVar($this->getElementId());
64  $item->setValue($post);
65  } elseif (array_key_exists($this->getElementId(), $this->table_filter_fields)) {
66  $this->table_filter_fields[$this->getElementId()]->setValue($post);
67  $this->writeFilter($post);
68  }
69 
70  $this->getADT()->setText($post);
71  } else {
72  $this->writeFilter();
73  $this->getADT()->setText();
74  }
75  return true;
76  }
77 
78  // db
79 
80  public function getSQLCondition(string $a_element_id, int $mode = self::SQL_LIKE, array $quotedWords = []): string
81  {
82  if (!$quotedWords) {
83  if ($this->isNull() || !$this->isValid()) {
84  return '';
85  }
86  $quotedWords = $this->getADT()->getText();
87  }
88 
89  switch ($mode) {
90  case self::SQL_STRICT:
91  if (!is_array($quotedWords)) {
92  return $a_element_id . " = " . $this->db->quote($quotedWords, "text");
93  } else {
94  return $this->db->in($a_element_id, $quotedWords, false, "text");
95  }
96 
97  // no break
98  case self::SQL_LIKE:
99  if (!is_array($quotedWords)) {
100  return $this->db->like($a_element_id, "text", "%" . $quotedWords . "%");
101  } else {
102  $tmp = array();
103  foreach ($quotedWords as $word) {
104  if ($word) {
105  $tmp[] = $this->db->like($a_element_id, "text", "%" . $word . "%");
106  }
107  }
108  if (count($tmp)) {
109  return "(" . implode(" OR ", $tmp) . ")";
110  }
111  }
112  break;
113 
114  case self::SQL_LIKE_END:
115  if (!is_array($quotedWords)) {
116  return $this->db->like($a_element_id, "text", $quotedWords . "%");
117  }
118  break;
119 
120  case self::SQL_LIKE_START:
121  if (!is_array($quotedWords)) {
122  return $this->db->like($a_element_id, "text", "%" . $quotedWords);
123  }
124  break;
125  }
126  return '';
127  }
128 
129  public function isInCondition(ilADT $a_adt): bool
130  {
131  if ($this->getADT()->getCopyOfDefinition()->isComparableTo($a_adt)) {
132  $search_term = strtolower(trim((string) $this->getADT()->getText()));
133  $text = strtolower(trim((string) $a_adt->getText()));
134  return str_contains($text, $search_term);
135  }
136  return false;
137  }
138 
139  // import/export
140 
141  public function getSerializedValue(): string
142  {
143  if (!$this->isNull() && $this->isValid()) {
144  return serialize(array($this->getADT()->getText()));
145  }
146  return '';
147  }
148 
149  public function setSerializedValue(string $a_value): void
150  {
151  $a_value = unserialize($a_value);
152  if (is_array($a_value)) {
153  $this->getADT()->setText($a_value[0]);
154  }
155  }
156 }
getSQLCondition(string $a_element_id, int $mode=self::SQL_LIKE, array $quotedWords=[])
isValidADTDefinition(ilADTDefinition $a_adt_def)
ADT base class.
Definition: class.ilADT.php:11
extractPostValues(array $a_post=null)
Extract data from (post) values.
shouldBeImportedFromPost($a_post)
Check if incoming values should be imported at all.
readFilter()
Load value(s) from filter store (in session)
Class ilADTSearchBridgeSingle.
writeFilter($a_value=null)
Write value(s) to filter store (in session)
$post
Definition: ltitoken.php:49
ADT definition base class.
addToParentElement(ilFormPropertyGUI $a_field)
Add form field to parent element.