mirror of
https://github.com/EGroupware/egroupware.git
synced 2024-12-27 09:09:04 +01:00
fixed not working selected_value attribute of checkbox and radio, server-side used (un)set_val as attribute while clientside used (un)selected_value for checkbox and set_value for radio, grrrr ;-)
This commit is contained in:
parent
2a32284616
commit
defe24b7c0
@ -14,7 +14,7 @@
|
|||||||
/**
|
/**
|
||||||
* eTemplate checkbox widget
|
* eTemplate checkbox widget
|
||||||
*
|
*
|
||||||
* Multiple checkbox widgets can have the same name ending in [], in which case an array with the set_val's of the checked boxes get returned.
|
* Multiple checkbox widgets can have the same name ending in [], in which case an array with the selected_value's of the checked boxes get returned.
|
||||||
*/
|
*/
|
||||||
class etemplate_widget_checkbox extends etemplate_widget
|
class etemplate_widget_checkbox extends etemplate_widget
|
||||||
{
|
{
|
||||||
@ -24,8 +24,8 @@ class etemplate_widget_checkbox extends etemplate_widget
|
|||||||
* @var string|array
|
* @var string|array
|
||||||
*/
|
*/
|
||||||
protected $legacy_options = array(
|
protected $legacy_options = array(
|
||||||
'checkbox' => 'set_val,unset_val,ro_true,ro_false',
|
'checkbox' => 'selected_value,unselected_value,ro_true,ro_false',
|
||||||
'radio' => 'set_val,ro_true,ro_false',
|
'radio' => 'set_value,ro_true,ro_false',
|
||||||
);
|
);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -58,35 +58,36 @@ class etemplate_widget_checkbox extends etemplate_widget
|
|||||||
{
|
{
|
||||||
self::set_validation_error($form_name,lang('Field must not be empty !!!'),'');
|
self::set_validation_error($form_name,lang('Field must not be empty !!!'),'');
|
||||||
}
|
}
|
||||||
|
$value_attr = $this->type == 'radio' ? 'set_value' : 'selected_value';
|
||||||
// defaults for set and unset values
|
// defaults for set and unset values
|
||||||
if (!$this->attrs['set_val'] && !$this->attrs['unset_val'])
|
if (!$this->attrs[$value_attr] && !$this->attrs['unselected_value'])
|
||||||
{
|
{
|
||||||
$set_val = true;
|
$selected_value = true;
|
||||||
$unset_val = false;
|
$unselected_value = false;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
// Expand any content stuff
|
// Expand any content stuff
|
||||||
$set_val = self::expand_name($this->attrs['set_val'], $expand['c'], $expand['row'], $expand['c_'], $expand['row_'],$expand['cont']);
|
$selected_value = self::expand_name($this->attrs[$value_attr], $expand['c'], $expand['row'], $expand['c_'], $expand['row_'],$expand['cont']);
|
||||||
$unset_val = self::expand_name($this->attrs['unset_val'], $expand['c'], $expand['row'], $expand['c_'], $expand['row_'],$expand['cont']);
|
$unselected_value = self::expand_name($this->attrs['unselected_value'], $expand['c'], $expand['row'], $expand['c_'], $expand['row_'],$expand['cont']);
|
||||||
}
|
}
|
||||||
if (in_array((string)$set_val, (array)$value))
|
if (in_array((string)$selected_value, (array)$value))
|
||||||
{
|
{
|
||||||
if ($multiple)
|
if ($multiple)
|
||||||
{
|
{
|
||||||
if (!isset($valid)) $valid = array();
|
if (!isset($valid)) $valid = array();
|
||||||
$valid[] = $set_val;
|
$valid[] = $selected_value;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
$valid = $set_val;
|
$valid = $selected_value;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
elseif ($this->type == 'radio')
|
elseif ($this->type == 'radio')
|
||||||
{
|
{
|
||||||
if (!isset($valid)) $valid = ''; // do not overwrite value of an other radio-button of the same group (identical name)!
|
if (!isset($valid)) $valid = ''; // do not overwrite value of an other radio-button of the same group (identical name)!
|
||||||
}
|
}
|
||||||
else // if checkbox is not checked, html returns nothing: eTemplate returns unset_val (default false)
|
else // if checkbox is not checked, html returns nothing: eTemplate returns unselected_value (default false)
|
||||||
{
|
{
|
||||||
if ($multiple)
|
if ($multiple)
|
||||||
{
|
{
|
||||||
@ -95,11 +96,11 @@ class etemplate_widget_checkbox extends etemplate_widget
|
|||||||
elseif ($value === 'true')
|
elseif ($value === 'true')
|
||||||
{
|
{
|
||||||
// 'true' != true
|
// 'true' != true
|
||||||
$valid = $set_val;
|
$valid = $selected_value;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
$valid = $unset_val;
|
$valid = $unselected_value;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
//error_log(__METHOD__.'() '.$form_name.($multiple?'[]':'').': '.array2string($value).' --> '.array2string($valid));
|
//error_log(__METHOD__.'() '.$form_name.($multiple?'[]':'').': '.array2string($value).' --> '.array2string($valid));
|
||||||
|
Loading…
Reference in New Issue
Block a user