aboutsummaryrefslogtreecommitdiff
path: root/lib/classes/DataFieldComboEntry.class.php
blob: 60470500225366bdfe5dcd93f720c524ed430bce (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
<?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 DataFieldComboEntry extends DataFieldEntry
{
    protected $template = 'combo.php';

    /**
     * Constructs this datafield
     *
     * @param DataField $datafield Underlying model
     * @param String    $rangeID   Range id
     * @param mixed     $value     Value
     */
    public function __construct(DataField $struct, $range_id, $value)
    {
        parent::__construct($struct, $range_id, $value);

        if ($this->getValue() === null) {
            $parameters = $this->getParameters();
            $this->setValue($parameters[0]); // first selectbox entry is default
        }
    }

    /**
     * Returns the number of html fields this datafield uses for input.
     *
     * @return int representing the number of html fields
     */
    public function numberOfHTMLFields()
    {
        return 2;
    }

    /**
     * Sets the value from a post request
     *
     * @param mixed $submitted_value The value from request
     */
    public function setValueFromSubmit($value)
    {
        $index = $value['combo'];
        $value = $value[$index];
        parent::setValueFromSubmit($value);
    }

    /**
     * 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 + [
            'values' => $this->getParameters(),
        ]);
    }

    /**
     * Returns the individual type parameters.
     *
     * @return array containing the individual type parameters
     */
    protected function getParameters()
    {
        $parameters = explode("\n", rtrim($this->model->typeparam));
        $parameters = array_map('trim', $parameters);
        return $parameters;
    }
}