Skip to content
Browse files

EnumOption plugin

  • Loading branch information...
1 parent 045bce3 commit 0836c34aef75f576f4cb69424e55b8bf17ed41e2 @vrana committed Feb 10, 2011
Showing with 37 additions and 0 deletions.
  1. +1 −0 adminer/plugin.php
  2. +36 −0 plugins/enum-option.php
View
1 adminer/plugin.php
@@ -22,6 +22,7 @@ class AdminerCustomization extends AdminerPlugin {
new AdminerSlugify,
new AdminerTranslation,
new AdminerForeignSystem,
+ new AdminerEnumOption,
));
}
View
36 plugins/enum-option.php
@@ -0,0 +1,36 @@
+<?php
+
+/** Use <select><option> for enum edit instead of <input type="radio">
+* @author Jakub Vrana, http://www.vrana.cz/
+* @license http://www.apache.org/licenses/LICENSE-2.0 Apache License, Version 2.0
+* @license http://www.gnu.org/licenses/gpl-2.0.html GNU General Public License, version 2 (one or other)
+*/
+class AdminerEnumOption {
+
+ function editInput($table, $field, $attrs, $value) {
+ if ($field["type"] == "enum") {
+ $options = array("" => array());
+ $selected = $value;
+ if (isset($_GET["select"])) {
+ $options[""][-1] = lang('original');
+ }
+ if ($field["null"]) {
+ $options[""][""] = "NULL";
+ if (!isset($value) && !isset($_GET["select"])) {
+ $selected = "";
+ }
+ }
+ $options[""][0] = lang('empty');
+ preg_match_all("~'((?:[^']|'')*)'~", $field["length"], $matches);
+ foreach ($matches[1] as $i => $val) {
+ $val = stripcslashes(str_replace("''", "'", $val));
+ $options[$i + 1] = $val;
+ if ($value === $val) {
+ $selected = $i + 1;
+ }
+ }
+ return "<select$attrs>" . optionlist($options, (string) $selected, 1) . "</select>"; // 1 - use keys
+ }
+ }
+
+}

0 comments on commit 0836c34

Please sign in to comment.
Something went wrong with that request. Please try again.