ILIAS  release_8 Revision v8.24
class.ilADTTextSearchBridgeSingle.php
Go to the documentation of this file.
1<?php
2
19declare(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) {
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
115 if (!is_array($quotedWords)) {
116 return $this->db->like($a_element_id, "text", $quotedWords . "%");
117 }
118 break;
119
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}
ADT definition base class.
Class ilADTSearchBridgeSingle.
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.
shouldBeImportedFromPost($a_post)
Check if incoming values should be imported at all.
writeFilter($a_value=null)
Write value(s) to filter store (in session)
isInCondition(ilADT $a_adt)
Compare directly against ADT.
isValidADTDefinition(ilADTDefinition $a_adt_def)
getSerializedValue()
Get current value(s) in serialized form (for easy persisting)
loadFilter()
Load filter value(s) into ADT.
setSerializedValue(string $a_value)
Set current value(s) in serialized form (for easy persisting)
addToForm()
Add ADT-specific fields to form.
getSQLCondition(string $a_element_id, int $mode=self::SQL_LIKE, array $quotedWords=[])
Get SQL condition for current value(s)
ADT base class.
Definition: class.ilADT.php:12
This class represents a property form user interface.
This class represents a text property in a property form.
$post
Definition: ltitoken.php:49