File: enum-types.php

package info (click to toggle)
adminer 4.7.1-1%2Bdeb10u1
  • links: PTS, VCS
  • area: main
  • in suites: buster
  • size: 2,608 kB
  • sloc: php: 25,013; javascript: 2,236; makefile: 21; sh: 3
file content (50 lines) | stat: -rw-r--r-- 1,493 bytes parent folder | download | duplicates (3)
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
<?php

/** Use <select><option> for enum edit instead of regular input text on enum type in PostgreSQL
 * @link https://www.adminer.org/plugins/#use
 * @author Adam KuĊ›mierz, http://kusmierz.be/
 * @license https://www.apache.org/licenses/LICENSE-2.0 Apache License, Version 2.0
 * @license https://www.gnu.org/licenses/gpl-2.0.html GNU General Public License, version 2 (one or other)
 */
class AdminerEnumTypes {
	var $_types = null;

	function editInput($table, $field, $attrs, $value) {
		// PostgreSQL only
		if (!in_array(strtolower(connection()->extension), array('pgsql', 'pdo_pgsql'))) {
			return;
		}

		// read types and "cache" it
		if (is_null($this->_types)) {
			$types = types();
			$this->_types = array();

			foreach ($types as $type) {
				$values = get_vals("SELECT unnest(enum_range(NULL::$type))::text AS value");
				if (!empty($values) && is_array($values)) {
					$this->_types[$type] = $values;
				}
			}
		}

		if (array_key_exists($field["type"], $this->_types)) {
			$options = $this->_types[$field["type"]];
			$options = array_combine($options, $options);
			$selected = $value;

			if ($field["null"]) {
				$options = array("" => array("" => "NULL")) + $options;
				if ($value === null && !isset($_GET["select"])) {
					$selected = "";
				}
			}
			if (isset($_GET["select"])) {
				$options = array("" => array(-1 => lang('original'))) + $options;
			}

			return "<select$attrs>" . optionlist($options, (string) $selected, 1) . "</select>";
		}
	}

}