X-Git-Url: https://vcs.fsf.org/?p=squirrelmail.git;a=blobdiff_plain;f=functions%2Foptions.php;h=61ddf027ee6eb30deb3bf7b9b1e611e886d44333;hp=0e8d32ed4d87938dd399bd808c9091bf1bb28d53;hb=de4c101c7f7fbbc2522a143eae9479b0dc55e93b;hpb=ca479ad18c00a6a4ff2ddfb58a2f0af40bc81379 diff --git a/functions/options.php b/functions/options.php index 0e8d32ed..61ddf027 100644 --- a/functions/options.php +++ b/functions/options.php @@ -3,11 +3,10 @@ /** * options.php * - * Copyright (c) 1999-2005 The SquirrelMail Project Team - * Licensed under the GNU GPL. For full terms see the file COPYING. - * * Functions needed to display the options pages. * + * @copyright © 1999-2007 The SquirrelMail Project Team + * @license http://opensource.org/licenses/gpl-license.php GNU Public License * @version $Id$ * @package squirrelmail * @subpackage prefs @@ -27,6 +26,17 @@ define('SMOPT_TYPE_BOOLEAN', 5); define('SMOPT_TYPE_HIDDEN', 6); define('SMOPT_TYPE_COMMENT', 7); define('SMOPT_TYPE_FLDRLIST', 8); +define('SMOPT_TYPE_FLDRLIST_MULTI', 9); +define('SMOPT_TYPE_EDIT_LIST', 10); +define('SMOPT_TYPE_STRLIST_MULTI', 11); +define('SMOPT_TYPE_BOOLEAN_CHECKBOX', 12); +define('SMOPT_TYPE_BOOLEAN_RADIO', 13); +define('SMOPT_TYPE_STRLIST_RADIO', 14); +define('SMOPT_TYPE_SUBMIT', 15); + +/* Define constants for the layout scheme for edit lists. */ +define('SMOPT_EDIT_LIST_LAYOUT_LIST', 0); +define('SMOPT_EDIT_LIST_LAYOUT_SELECT', 1); /* Define constants for the options refresh levels. */ define('SMOPT_REFRESH_NONE', 0); @@ -51,6 +61,11 @@ define('SMOPT_SAVE_NOOP', 'save_option_noop'); * @subpackage prefs */ class SquirrelOption { + /** + * The original option configuration array + * @var array + */ + var $raw_option_array; /** * The name of this setting * @var string @@ -91,6 +106,40 @@ class SquirrelOption { * @var string */ var $trailing_text; + /** + * Text that overrides the "Yes" label for boolean + * radio option widgets + * + * @var string + */ + var $yes_text; + /** + * Text that overrides the "No" label for boolean + * radio option widgets + * + * @var string + */ + var $no_text; + /** + * Some widgets support more than one layout type + * + * @var int + */ + var $layout_type; + /** + * Indicates if the Add widget should be included + * with edit lists. + * + * @var boolean + */ + var $use_add_widget; + /** + * Indicates if the Delete widget should be included + * with edit lists. + * + * @var boolean + */ + var $use_delete_widget; /** * text displayed to the user * @@ -99,10 +148,12 @@ class SquirrelOption { */ var $comment; /** - * additional javascript or other code added to the user input - * @var string + * additional javascript or other widget attributes added to the + * user input; must be an array where keys are attribute names + * ("onclick", etc) and values are the attribute values. + * @var array */ - var $script; + var $aExtraAttribs; /** * script (usually Javascript) that will be placed after (outside of) * the INPUT tag @@ -138,14 +189,22 @@ class SquirrelOption { * disables html sanitizing. * * WARNING - don't use it, if user input is possible in option - * or use own sanitizing functions. Currently works only with - * SMOPT_TYPE_STRLIST. + * or use own sanitizing functions. Currently only works for SMOPT_TYPE_STRLIST. * @var bool */ var $htmlencoded=false; + /** + * Controls folder list limits in SMOPT_TYPE_FLDRLIST and + * SMOPT_TYPE_FLDRLIST_MULTI widgets. + * See $flag argument in sqimap_mailbox_option_list() function. + * @var string + * @since 1.5.1 + */ + var $folder_filter='noselect'; /** * Constructor function + * @param array $raw_option_array * @param string $name * @param string $caption * @param integer $type @@ -155,32 +214,38 @@ class SquirrelOption { * @param bool $htmlencoded */ function SquirrelOption - ($name, $caption, $type, $refresh_level, $initial_value = '', $possible_values = '', $htmlencoded = false) { + ($raw_option_array, $name, $caption, $type, $refresh_level, $initial_value = '', $possible_values = '', $htmlencoded = false) { /* Set the basic stuff. */ + $this->raw_option_array = $raw_option_array; $this->name = $name; $this->caption = $caption; $this->type = $type; $this->refresh_level = $refresh_level; $this->possible_values = $possible_values; $this->htmlencoded = $htmlencoded; - $this->size = SMOPT_SIZE_MEDIUM; + $this->size = SMOPT_SIZE_NORMAL; $this->trailing_text = ''; + $this->yes_text = ''; + $this->no_text = ''; $this->comment = ''; - $this->script = ''; + $this->layout_type = 0; + $this->use_add_widget = TRUE; + $this->use_delete_widget = TRUE; + $this->aExtraAttribs = array(); $this->post_script = ''; - /* Check for a current value. */ - if (!empty($initial_value)) { - $this->value = $initial_value; - } else if (isset($GLOBALS[$name])) { + //Check for a current value. + if (isset($GLOBALS[$name])) { $this->value = $GLOBALS[$name]; + } else if (!empty($initial_value)) { + $this->value = $initial_value; } else { $this->value = ''; } /* Check for a new value. */ if ( !sqgetGlobalVar("new_$name", $this->new_value, SQ_POST ) ) { - $this->new_value = ''; + $this->new_value = NULL; } /* Set the default save function. */ @@ -191,6 +256,14 @@ class SquirrelOption { } } + /** Convenience function that identifies which types of + widgets are stored as (serialized) array values. */ + function is_multiple_valued() { + return ($this->type == SMOPT_TYPE_FLDRLIST_MULTI + || $this->type == SMOPT_TYPE_STRLIST_MULTI + || $this->type == SMOPT_TYPE_EDIT_LIST); + } + /** * Set the value for this option. * @param mixed $value @@ -223,6 +296,40 @@ class SquirrelOption { $this->trailing_text = $trailing_text; } + /** + * Set the yes_text for this option. + * @param string $yes_text + */ + function setYesText($yes_text) { + $this->yes_text = $yes_text; + } + + /** + * Set the no_text for this option. + * @param string $no_text + */ + function setNoText($no_text) { + $this->no_text = $no_text; + } + + /* Set the "use add widget" value for this option. */ + function setUseAddWidget($use_add_widget) { + $this->use_add_widget = $use_add_widget; + } + + /* Set the "use delete widget" value for this option. */ + function setUseDeleteWidget($use_delete_widget) { + $this->use_delete_widget = $use_delete_widget; + } + + /** + * Set the layout type for this option. + * @param int $layout_type + */ + function setLayoutType($layout_type) { + $this->layout_type = $layout_type; + } + /** * Set the comment for this option. * @param string $comment @@ -232,11 +339,11 @@ class SquirrelOption { } /** - * Set the script for this option. - * @param string $script + * Set the extra attributes for this option. + * @param array $aExtraAttribs */ - function setScript($script) { - $this->script = $script; + function setExtraAttributes($aExtraAttribs) { + $this->aExtraAttribs = $aExtraAttribs; } /** @@ -255,17 +362,28 @@ class SquirrelOption { $this->save_function = $save_function; } + /** + * Set the folder_filter for this option. + * @param string $folder_filter + * @since 1.5.1 + */ + function setFolderFilter($folder_filter) { + $this->folder_filter = $folder_filter; + } + /** * Creates fields on option pages according to option type * - * Function that calls other createWidget* functions. - * @return string html formated option field + * This is the function that calls all other createWidget* functions. + * + * @return string The formated option field + * */ - function createHTMLWidget() { + function createWidget() { global $color; // Use new value if available - if (!empty($this->new_value)) { + if (!is_null($this->new_value)) { $tempValue = $this->value; $this->value = $this->new_value; } @@ -290,6 +408,12 @@ class SquirrelOption { case SMOPT_TYPE_BOOLEAN: $result = $this->createWidget_Boolean(); break; + case SMOPT_TYPE_BOOLEAN_CHECKBOX: + $result = $this->createWidget_Boolean(TRUE); + break; + case SMOPT_TYPE_BOOLEAN_RADIO: + $result = $this->createWidget_Boolean(FALSE); + break; case SMOPT_TYPE_HIDDEN: $result = $this->createWidget_Hidden(); break; @@ -299,22 +423,37 @@ class SquirrelOption { case SMOPT_TYPE_FLDRLIST: $result = $this->createWidget_FolderList(); break; + case SMOPT_TYPE_FLDRLIST_MULTI: + $result = $this->createWidget_FolderList(TRUE); + break; + case SMOPT_TYPE_EDIT_LIST: + $result = $this->createWidget_EditList(); + break; + case SMOPT_TYPE_STRLIST_MULTI: + $result = $this->createWidget_StrList(TRUE); + break; + case SMOPT_TYPE_STRLIST_RADIO: + $result = $this->createWidget_StrList(FALSE, TRUE); + break; + case SMOPT_TYPE_SUBMIT: + $result = $this->createWidget_Submit(); + break; default: - $result = '' - . sprintf(_("Option Type '%s' Not Found"), $this->type) - . ''; + error_box ( + sprintf(_("Option Type '%s' Not Found"), $this->type) + ); } /* Add the "post script" for this option. */ $result .= $this->post_script; // put correct value back if need be - if (!empty($this->new_value)) { + if (!is_null($this->new_value)) { $this->value = $tempValue; } /* Now, return the created widget. */ - return ($result); + return $result; } /** @@ -340,76 +479,136 @@ class SquirrelOption { $width = 25; } - $result = "name\" value=\"" . - htmlspecialchars($this->value) . - "\" size=\"$width\" $this->script />$this->trailing_text\n"; - return ($result); + return addInput('new_' . $this->name, $this->value, $width, 0, $this->aExtraAttribs) . htmlspecialchars($this->trailing_text); } /** - * Create selection box - * @return string html formated selection box + * Create selection box or radio button group + * + * When $this->htmlencoded is TRUE, the keys and values in + * $this->possible_values are assumed to be display-safe. + * Use with care! + * + * Note that when building radio buttons instead of a select + * widget, if the "size" attribute is SMOPT_SIZE_TINY, the + * radio buttons will be output one after another without + * linebreaks between them. Otherwise, each radio button + * goes on a line of its own. + * + * @param boolean $multiple_select When TRUE, the select widget + * will allow multiple selections + * (OPTIONAL; default is FALSE + * (single select list)) + * @param boolean $radio_buttons When TRUE, the widget will + * instead be built as a group + * of radio buttons (and + * $multiple_select will be + * forced to FALSE) (OPTIONAL; + * default is FALSE (select widget)) + * + * @return string html formated selection box or radio buttons + * */ - function createWidget_StrList() { - /* Begin the select tag. */ - $result = "$this->trailing_text\n"; - return ($result); + return addSelect('new_' . $this->name, $this->possible_values, $this->value, TRUE, $this->aExtraAttribs, $multiple_select, $height, !$this->htmlencoded) . htmlspecialchars($this->trailing_text); + } /** * Create folder selection box + * + * @param boolean $multiple_select When TRUE, the select widget + * will allow multiple selections + * (OPTIONAL; default is FALSE + * (single select list)) + * * @return string html formated selection box + * */ - function createWidget_FolderList() { - $selected = array(strtolower($this->value)); + function createWidget_FolderList($multiple_select=FALSE) { - /* Begin the select tag. */ - $result = "\n"; - return ($result); + if (empty($option_list)) + $option_list = array('ignore' => _("unavailable")); + + + return addSelect('new_' . $this->name, $option_list, $this->value, TRUE, $this->aExtraAttribs, $multiple_select, $height) . htmlspecialchars($this->trailing_text); + } /** @@ -425,10 +624,7 @@ class SquirrelOption { case SMOPT_SIZE_NORMAL: default: $rows = 5; $cols = 50; } - $result = "\n"; - return ($result); + return addTextArea('new_' . $this->name, $this->value, $cols, $rows, $this->aExtraAttribs); } /** @@ -438,17 +634,16 @@ class SquirrelOption { * @return string html formated option field */ function createWidget_Integer() { - global $javascript_on; // add onChange javascript handler to a regular string widget // which will strip out all non-numeric chars - if ($javascript_on) - return preg_replace('/\/>/', ' onChange="origVal=this.value; newVal=\'\'; ' + if (checkForJavascript()) + $this->aExtraAttribs['onchange'] = 'origVal=this.value; newVal=\'\'; ' . 'for (i=0;i=\'0\' ' . '&& origVal.charAt(i)<=\'9\') newVal += origVal.charAt(i); } ' - . 'this.value=newVal;" />', $this->createWidget_String()); - else - return $this->createWidget_String(); + . 'this.value=newVal;'; + + return $this->createWidget_String(); } /** @@ -457,48 +652,60 @@ class SquirrelOption { * @return string html formated option field */ function createWidget_Float() { - global $javascript_on; // add onChange javascript handler to a regular string widget // which will strip out all non-numeric (period also OK) chars - if ($javascript_on) - return preg_replace('/\/>/', ' onChange="origVal=this.value; newVal=\'\'; ' + if (checkForJavascript()) + $this->aExtraAttribs['onchange'] = 'origVal=this.value; newVal=\'\'; ' . 'for (i=0;i=\'0\' ' . '&& origVal.charAt(i)<=\'9\') || origVal.charAt(i)==\'.\') ' - . 'newVal += origVal.charAt(i); } this.value=newVal;" />' - , $this->createWidget_String()); - else - return $this->createWidget_String(); + . 'newVal += origVal.charAt(i); } this.value=newVal;'; + + return $this->createWidget_String(); } /** - * Creates radio field (yes/no) - * @return string html formated radio field + * Create boolean widget + * + * When creating Yes/No radio buttons, the "yes_text" + * and "no_text" option attributes are used to override + * the typical "Yes" and "No" text. + * + * @param boolean $checkbox When TRUE, the widget will be + * constructed as a checkbox, + * otherwise it will be a set of + * Yes/No radio buttons (OPTIONAL; + * default is TRUE (checkbox)). + * + * @return string html formated boolean widget + * */ - function createWidget_Boolean() { - /* Do the whole current value thing. */ - if ($this->value != SMPREF_NO) { - $yes_chk = ' checked="checked"'; - $no_chk = ''; - } else { - $yes_chk = ''; - $no_chk = ' checked="checked"'; + function createWidget_Boolean($checkbox=TRUE) { + + global $oTemplate, $nbsp; + + + // checkbox... + // + if ($checkbox) { + $result = addCheckbox('new_' . $this->name, ($this->value != SMPREF_NO), SMPREF_YES, array_merge(array('id' => 'new_' . $this->name), $this->aExtraAttribs)) . $nbsp . create_label($this->trailing_text, 'new_' . $this->name); } - /* Build the yes choice. */ - $yes_option = 'script . ' /> ' - . ''; + // radio buttons... + // + else { + + /* Build the yes choice. */ + $yes_option = addRadioBox('new_' . $this->name, ($this->value != SMPREF_NO), SMPREF_YES, array_merge(array('id' => 'new_' . $this->name . '_yes'), $this->aExtraAttribs)) . $nbsp . create_label((!empty($this->yes_text) ? $this->yes_text : _("Yes")), 'new_' . $this->name . '_yes'); - /* Build the no choice. */ - $no_option = 'script . ' /> ' - . ''; + /* Build the no choice. */ + $no_option = addRadioBox('new_' . $this->name, ($this->value == SMPREF_NO), SMPREF_NO, array_merge(array('id' => 'new_' . $this->name . '_no'), $this->aExtraAttribs)) . $nbsp . create_label((!empty($this->no_text) ? $this->no_text : _("No")), 'new_' . $this->name . '_no'); + + /* Build the combined "boolean widget". */ + $result = "$yes_option$nbsp$nbsp$nbsp$nbsp$no_option"; + + } - /* Build and return the combined "boolean widget". */ - $result = "$yes_option    $no_option"; return ($result); } @@ -507,10 +714,7 @@ class SquirrelOption { * @return string html formated hidden input field */ function createWidget_Hidden() { - $result = 'script . ' />'; - return ($result); + return addHidden('new_' . $this->name, $this->value, $this->aExtraAttribs); } /** @@ -522,6 +726,78 @@ class SquirrelOption { return ($result); } + /** + * Creates an edit list + * + * Note that multiple layout types are supported for this widget. + * $this->layout_type must be one of the SMOPT_EDIT_LIST_LAYOUT_* + * constants. + * + * @return string html formated list of edit fields and + * their associated controls + */ + function createWidget_EditList() { + + global $oTemplate; + + switch ($this->size) { + case SMOPT_SIZE_TINY: + $height = 3; + break; + case SMOPT_SIZE_SMALL: + $height = 8; + break; + case SMOPT_SIZE_MEDIUM: + $height = 15; + break; + case SMOPT_SIZE_LARGE: + $height = 25; + break; + case SMOPT_SIZE_HUGE: + $height = 40; + break; + case SMOPT_SIZE_NORMAL: + default: + $height = 5; + } + + if (empty($this->possible_values)) $this->possible_values = array(); + if (!is_array($this->possible_values)) $this->possible_values = array($this->possible_values); + +//FIXME: $this->aExtraAttribs probably should only be used in one place + $oTemplate->assign('input_widget', addInput('add_' . $this->name, '', 38, 0, $this->aExtraAttribs)); + $oTemplate->assign('use_input_widget', $this->use_add_widget); + $oTemplate->assign('use_delete_widget', $this->use_delete_widget); + + $oTemplate->assign('trailing_text', $this->trailing_text); + $oTemplate->assign('possible_values', $this->possible_values); + $oTemplate->assign('select_widget', addSelect('new_' . $this->name, $this->possible_values, $this->value, FALSE, !checkForJavascript() ? $this->aExtraAttribs : array_merge(array('onchange' => 'if (typeof(window.addinput_' . $this->name . ') == \'undefined\') { var f = document.forms.length; var i = 0; var pos = -1; while( pos == -1 && i < f ) { var e = document.forms[i].elements.length; var j = 0; while( pos == -1 && j < e ) { if ( document.forms[i].elements[j].type == \'text\' && document.forms[i].elements[j].name == \'add_' . $this->name . '\' ) { pos = j; } j++; } i++; } if( pos >= 0 ) { window.addinput_' . $this->name . ' = document.forms[i-1].elements[pos]; } } for (x = 0; x < this.length; x++) { if (this.options[x].selected) { window.addinput_' . $this->name . '.value = this.options[x].value; break; } }'), $this->aExtraAttribs), TRUE, $height)); + $oTemplate->assign('checkbox_widget', addCheckBox('delete_' . $this->name, FALSE, SMPREF_YES, array_merge(array('id' => 'delete_' . $this->name), $this->aExtraAttribs))); + $oTemplate->assign('name', $this->name); + + switch ($this->layout_type) { + case SMOPT_EDIT_LIST_LAYOUT_SELECT: + return $oTemplate->fetch('edit_list_widget.tpl'); + case SMOPT_EDIT_LIST_LAYOUT_LIST: + return $oTemplate->fetch('edit_list_widget_list_style.tpl'); + default: + error_box(sprintf(_("Edit List Layout Type '%s' Not Found"), $layout_type)); + } + + } + + /** + * Creates a submit button + * + * @return string html formated submit button widget + * + */ + function createWidget_Submit() { + + return addSubmit($this->comment, $this->name, $this->aExtraAttribs) . htmlspecialchars($this->trailing_text); + + } + /** * */ @@ -534,21 +810,89 @@ class SquirrelOption { * */ function changed() { + + // edit lists have a lot going on, so we'll always process them + // + if ($this->type == SMOPT_TYPE_EDIT_LIST) return TRUE; + return ($this->value != $this->new_value); } } /* End of SquirrelOption class*/ /** - * Saves option + * Saves the option value (this is the default save function + * unless overridden by the user) + * * @param object $option object that holds option name and new_value */ function save_option($option) { + + // Can't save the pref if we don't have the username + // if ( !sqgetGlobalVar('username', $username, SQ_SESSION ) ) { - /* Can't save the pref if we don't have the username */ return; } + global $data_dir; - setPref($data_dir, $username, $option->name, $option->new_value); + + // edit lists: first add new elements to list, then + // remove any selected ones (note that we must add + // before deleting because the javascript that populates + // the "add" textbox when selecting items in the list + // (for deletion)) + // + if ($option->type == SMOPT_TYPE_EDIT_LIST) { + + if (empty($option->possible_values)) $option->possible_values = array(); + if (!is_array($option->possible_values)) $option->possible_values = array($option->possible_values); + + // add element if given + // + if ((isset($option->use_add_widget) && $option->use_add_widget) + && sqGetGlobalVar('add_' . $option->name, $new_element, SQ_POST)) { + $new_element = trim($new_element); + if (!empty($new_element) + && !in_array($new_element, $option->possible_values)) + $option->possible_values[] = $new_element; + } + + // delete selected elements if needed + // + if ((isset($option->use_delete_widget) && $option->use_delete_widget) + && is_array($option->new_value) + && sqGetGlobalVar('delete_' . $option->name, $ignore, SQ_POST)) + $option->possible_values = array_diff($option->possible_values, $option->new_value); + + // save full list (stored in "possible_values") + // + setPref($data_dir, $username, $option->name, serialize($option->possible_values)); + + // Certain option types need to be serialized because + // they are not scalar + // + } else if ($option->is_multiple_valued()) + setPref($data_dir, $username, $option->name, serialize($option->new_value)); + + // Checkboxes, when unchecked, don't submit anything in + // the POST, so set to SMPREF_OFF if not found + // + else if (($option->type == SMOPT_TYPE_BOOLEAN + || $option->type == SMOPT_TYPE_BOOLEAN_CHECKBOX) + && empty($option->new_value)) + setPref($data_dir, $username, $option->name, SMPREF_OFF); + + else + setPref($data_dir, $username, $option->name, $option->new_value); + + + // if a checkbox or multi select is zeroed/cleared out, it + // needs to have an empty value pushed into its "new_value" slot + // + if (($option->type == SMOPT_TYPE_STRLIST_MULTI + || $option->type == SMOPT_TYPE_BOOLEAN_CHECKBOX) + && is_null($option->new_value)) + $option->new_value = ''; + } /** @@ -565,7 +909,7 @@ function save_option_noop($option) { * @return string html formated hidden input field */ function create_optpage_element($optpage) { - return create_hidden_element('optpage', $optpage); + return addHidden('optpage', $optpage); } /** @@ -574,20 +918,7 @@ function create_optpage_element($optpage) { * @return string html formated hidden input field */ function create_optmode_element($optmode) { - return create_hidden_element('optmode', $optmode); -} - -/** - * Create hidden field. - * @param string $name field name - * @param string $value field value - * @return string html formated hidden input field - */ -function create_hidden_element($name, $value) { - $result = ''; - return ($result); + return addHidden('optmode', $optmode); } /** @@ -611,14 +942,15 @@ function create_option_groups($optgrps, $optvals) { foreach ($grpopts as $optset) { /* Create a new option with all values given. */ $next_option = new SquirrelOption( - $optset['name'], - $optset['caption'], - $optset['type'], - (isset($optset['refresh']) ? $optset['refresh'] : SMOPT_REFRESH_NONE), - (isset($optset['initial_value']) ? $optset['initial_value'] : ''), - (isset($optset['posvals']) ? $optset['posvals'] : ''), - (isset($optset['htmlencoded']) ? $optset['htmlencoded'] : false) - ); + $optset, + $optset['name'], + $optset['caption'], + $optset['type'], + (isset($optset['refresh']) ? $optset['refresh'] : SMOPT_REFRESH_NONE), + (isset($optset['initial_value']) ? $optset['initial_value'] : ''), + (isset($optset['posvals']) ? $optset['posvals'] : ''), + (isset($optset['htmlencoded']) ? $optset['htmlencoded'] : false) + ); /* If provided, set the size for this option. */ if (isset($optset['size'])) { @@ -630,6 +962,31 @@ function create_option_groups($optgrps, $optvals) { $next_option->setTrailingText($optset['trailing_text']); } + /* If provided, set the yes_text for this option. */ + if (isset($optset['yes_text'])) { + $next_option->setYesText($optset['yes_text']); + } + + /* If provided, set the no_text for this option. */ + if (isset($optset['no_text'])) { + $next_option->setNoText($optset['no_text']); + } + + /* If provided, set the layout type for this option. */ + if (isset($optset['layout_type'])) { + $next_option->setLayoutType($optset['layout_type']); + } + + /* If provided, set the use_add_widget value for this option. */ + if (isset($optset['use_add_widget'])) { + $next_option->setUseAddWidget($optset['use_add_widget']); + } + + /* If provided, set the use_delete_widget value for this option. */ + if (isset($optset['use_delete_widget'])) { + $next_option->setUseDeleteWidget($optset['use_delete_widget']); + } + /* If provided, set the comment for this option. */ if (isset($optset['comment'])) { $next_option->setComment($optset['comment']); @@ -640,9 +997,9 @@ function create_option_groups($optgrps, $optvals) { $next_option->setSaveFunction($optset['save']); } - /* If provided, set the script for this option. */ - if (isset($optset['script'])) { - $next_option->setScript($optset['script']); + /* If provided, set the extra attributes for this option. */ + if (isset($optset['extra_attributes'])) { + $next_option->setExtraAttributes($optset['extra_attributes']); } /* If provided, set the "post script" for this option. */ @@ -650,6 +1007,11 @@ function create_option_groups($optgrps, $optvals) { $next_option->setPostScript($optset['post_script']); } + /* If provided, set the folder_filter for this option. */ + if (isset($optset['folder_filter'])) { + $next_option->setFolderFilter($optset['folder_filter']); + } + /* Add this option to the option array. */ $result[$grpkey]['options'][] = $next_option; } @@ -659,49 +1021,3 @@ function create_option_groups($optgrps, $optvals) { return ($result); } -/** - * @param array $option_groups - */ -function print_option_groups($option_groups) { - /* Print each option group. */ - foreach ($option_groups as $next_optgrp) { - /* If it is not blank, print the name for this option group. */ - if ($next_optgrp['name'] != '') { - echo html_tag( 'tr', "\n". - html_tag( 'td', - '' . $next_optgrp['name'] . '' , - 'center' ,'', 'valign="middle" colspan="2" style="white-space: nowrap;"' ) - ) ."\n"; - } - - /* Print each option in this option group. */ - foreach ($next_optgrp['options'] as $option) { - if ($option->type != SMOPT_TYPE_HIDDEN) { - echo html_tag( 'tr', "\n". - html_tag( 'td', $option->caption . ':', 'right' ,'', 'valign="middle"' ) . - html_tag( 'td', $option->createHTMLWidget(), 'left' ) - ) ."\n"; - } else { - echo $option->createHTMLWidget(); - } - } - - /* Print an empty row after this option group. */ - echo html_tag( 'tr', - html_tag( 'td', ' ', 'left', '', 'colspan="2"' ) - ) . "\n"; - } -} - -/** - * Create submit button inside table row. - * @param string $name - */ -function OptionSubmit( $name ) { - echo html_tag( 'tr', - html_tag( 'td', '    ', 'right', '', 'colspan="2"' ) - ) . "\n"; -} - -// vim: et ts=4 -?> \ No newline at end of file