[ticket/9831] Correctly store checkbox default value for boolean CPF.

PHPBB3-9831
This commit is contained in:
rxu 2011-01-17 00:01:04 +07:00
parent d7aa3aab5e
commit 99164cd20b
2 changed files with 25 additions and 6 deletions

View file

@ -504,11 +504,26 @@ class acp_profile
} }
} }
} }
/* else if ($field_type == FIELD_BOOL && $key == 'field_default_value') else if ($field_type == FIELD_BOOL && $key == 'field_default_value')
{ {
// Get the number of options if this key is 'field_maxlen' // 'field_length' == 1 defines radio buttons. Possible values are 1 or 2 only.
$var = request_var('field_default_value', 0); // 'field_length' == 2 defines checkbox. Possible values are 0 or 1 only.
}*/ // If we switch the type on step 2, we have to adjust field value.
// 1 is a common value for the checkbox and radio buttons.
// If we switch to the checkbox type but former radio buttons value was 2,
// which is not the case for the checkbox, set it to 0 (unchecked).
if ($cp->vars['field_length'] == 2 && $var == 2)
{
$var = 0;
}
// If we switch to the radio buttons but the former checkbox value was 0,
// which is not the case for the radio buttons, set it to 0.
else if ($cp->vars['field_length'] == 1 && $var == 0)
{
$var = 2;
}
}
else if ($field_type == FIELD_INT && $key == 'field_default_value') else if ($field_type == FIELD_INT && $key == 'field_default_value')
{ {
// Permit an empty string // Permit an empty string
@ -676,6 +691,10 @@ class acp_profile
{ {
$_new_key_ary[$key] = utf8_normalize_nfc(request_var($key, array(array('')), true)); $_new_key_ary[$key] = utf8_normalize_nfc(request_var($key, array(array('')), true));
} }
else if ($field_type == FIELD_BOOL && $key == 'field_default_value')
{
$_new_key_ary[$key] = request_var($key, $cp->vars[$key]);
}
else else
{ {
if (!isset($_REQUEST[$key])) if (!isset($_REQUEST[$key]))

View file

@ -625,10 +625,10 @@ class custom_profile
$profile_row['field_ident'] = (isset($profile_row['var_name'])) ? $profile_row['var_name'] : 'pf_' . $profile_row['field_ident']; $profile_row['field_ident'] = (isset($profile_row['var_name'])) ? $profile_row['var_name'] : 'pf_' . $profile_row['field_ident'];
$user_ident = $profile_row['field_ident']; $user_ident = $profile_row['field_ident'];
// checkbox - only testing for isset // checkbox - set the value to "true" if it has been set to 1
if ($profile_row['field_type'] == FIELD_BOOL && $profile_row['field_length'] == 2) if ($profile_row['field_type'] == FIELD_BOOL && $profile_row['field_length'] == 2)
{ {
$value = (isset($_REQUEST[$profile_row['field_ident']])) ? true : ((!isset($user->profile_fields[$user_ident]) || $preview) ? $default_value : $user->profile_fields[$user_ident]); $value = (isset($_REQUEST[$profile_row['field_ident']]) && request_var($profile_row['field_ident'], $default_value) == 1) ? true : ((!isset($user->profile_fields[$user_ident]) || $preview) ? $default_value : $user->profile_fields[$user_ident]);
} }
else if ($profile_row['field_type'] == FIELD_INT) else if ($profile_row['field_type'] == FIELD_INT)
{ {