diff options
| author | Jan-Hendrik Willms <tleilax+github@gmail.com> | 2021-07-22 16:07:19 +0200 |
|---|---|---|
| committer | Jan-Hendrik Willms <tleilax+github@gmail.com> | 2021-07-22 16:19:12 +0200 |
| commit | a3da1483a9e689846179159355badfec8073dbec (patch) | |
| tree | 770dcca6bdf5f6f2a11b0e7fcbbeda6919a3fc52 /lib/classes/DataFieldSelectboxMultipleEntry.class.php | |
current code from svn, revision 62608
Diffstat (limited to 'lib/classes/DataFieldSelectboxMultipleEntry.class.php')
| -rw-r--r-- | lib/classes/DataFieldSelectboxMultipleEntry.class.php | 93 |
1 files changed, 93 insertions, 0 deletions
diff --git a/lib/classes/DataFieldSelectboxMultipleEntry.class.php b/lib/classes/DataFieldSelectboxMultipleEntry.class.php new file mode 100644 index 0000000..3abb373 --- /dev/null +++ b/lib/classes/DataFieldSelectboxMultipleEntry.class.php @@ -0,0 +1,93 @@ +<?php +# Lifter002: DONE +# Lifter007: TEST + +/** + * @author Jan-Hendrik Willms <tleilax+studip@gmail.com> + * @author Marcus Lunzenauer <mlunzena@uos.de> + * @author Martin Gieseking <mgieseki@uos.de> + * @license GPL2 or any later version + */ +class DataFieldSelectboxMultipleEntry extends DataFieldSelectboxEntry +{ + const SEPARATOR = '|'; + + /** + * Constructs this datafield + * + * @param DataField $datafield Underlying model + * @param String $rangeID Range id + * @param mixed $value Value + */ + public function __construct(DataField $datafield = null, $rangeID = '', $value = null) + { + parent::__construct($datafield, $rangeID, $value); + + if ($this->getValue() === null) { + $this->setValue(''); + } + } + + /** + * Returns the according input elements as html for this datafield + * + * @param String $name Name prefix of the associated input + * @param Array $variables Additional variables + * @return String containing the required html + */ + public function getHTML($name = '', $variables = []) + { + return parent::getHTML($name, $variables + [ + 'multiple' => true, + 'value' => explode(self::SEPARATOR, $this->value) + ]); + } + + /** + * Returns the display/rendered value of this datafield + * + * @param bool $entities Should html entities be encoded (defaults to true) + * @return String containg the rendered value + */ + public function getDisplayValue($entities = true) + { + $value = $this->getValue(); + if ($value) { + $type_param = $this->type_param; + + $mapper = 'trim'; + if ($this->is_assoc_param) { + $mapper = function ($a) use ($type_param) { + $a = trim($a); + return $type_param[$a]; + }; + } + + $value = explode(self::SEPARATOR, $value); + $value = array_map($mapper, $value); + $value = implode('; ', $value); + } + return $entities + ? htmlReady($value) + : $value; + } + + /** + * Sets the value from a post request + * + * @param mixed $submitted_value The value from request + */ + public function setValueFromSubmit($value) + { + if (is_array($value)) { + $value = array_map('trim', $value); + $value = array_filter($value); + $value = array_unique($value); + $value = implode(self::SEPARATOR, $value); + } else { + $value = ''; + } + + parent::setValueFromSubmit($value); + } +} |
