#165013 by Eaton: fix image button behaviour by processing the right values coming in the request
parent
cf83099de1
commit
87bdc95bff
|
|
@ -947,6 +947,51 @@ function _form_builder_ie_cleanup($form, &$form_state) {
|
|||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Helper function to determine the value for an image button form element.
|
||||
*
|
||||
* @param $form
|
||||
* The form element whose value is being populated.
|
||||
* @param $edit
|
||||
* The incoming POST data to populate the form element. If this is FALSE,
|
||||
* the element's default value should be returned.
|
||||
* @return
|
||||
* The data that will appear in the $form_state['values'] collection
|
||||
* for this element. Return nothing to use the default.
|
||||
*/
|
||||
function form_type_image_button_value($form, $edit = FALSE) {
|
||||
if ($edit !== FALSE) {
|
||||
if (!empty($edit)) {
|
||||
// If we're dealing with Mozilla or Opera, we're lucky. It will
|
||||
// return a proper value, and we can get on with things.
|
||||
return $form['#return_value'];
|
||||
}
|
||||
else {
|
||||
// Unfortunately, in IE we never get back a proper value for THIS
|
||||
// form element. Instead, we get back two split values: one for the
|
||||
// X and one for the Y coordinates on which the user clicked the
|
||||
// button. We'll find this element in the #post data, and search
|
||||
// in the same spot for its name, with '_x'.
|
||||
$post = $form['#post'];
|
||||
foreach (split('\[', $form['#name']) as $element_name) {
|
||||
// chop off the ] that may exist.
|
||||
if (substr($element_name, -1) == ']') {
|
||||
$element_name = substr($element_name, 0, -1);
|
||||
}
|
||||
|
||||
if (!isset($post[$element_name])) {
|
||||
if (isset($post[$element_name .'_x'])) {
|
||||
return $form['#return_value'];
|
||||
}
|
||||
return NULL;
|
||||
}
|
||||
$post = $array[$element_name];
|
||||
}
|
||||
return $form['#return_value'];
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Helper function to determine the value for a checkbox form element.
|
||||
*
|
||||
|
|
@ -1666,7 +1711,7 @@ function theme_image_button($element) {
|
|||
(!empty($element['#value']) ? ('value="'. check_plain($element['#value']) .'" ') : '') .
|
||||
'id="' . $element['#id'] . '" ' .
|
||||
drupal_attributes($element['#attributes']) .
|
||||
' src="' . base_path() . $element['#image'] . '" ' .
|
||||
' src="' . base_path() . $element['#src'] . '" ' .
|
||||
(!empty($element['#title']) ? 'alt="' . check_plain($element['#title']) . '" title="' . check_plain($element['#title']) . '" ' : '' ).
|
||||
"/>\n";
|
||||
}
|
||||
|
|
|
|||
|
|
@ -105,7 +105,7 @@ function system_elements() {
|
|||
// Inputs
|
||||
$type['submit'] = array('#input' => TRUE, '#name' => 'op', '#button_type' => 'submit', '#executes_submit_callback' => TRUE, '#ahah_event' => 'submit', '#process' => array('form_expand_ahah'));
|
||||
$type['button'] = array('#input' => TRUE, '#name' => 'op', '#button_type' => 'submit', '#executes_submit_callback' => FALSE, '#ahah_event' => 'submit', '#process' => array('form_expand_ahah'));
|
||||
$type['image_button'] = array('#input' => TRUE, '#button_type' => 'submit','#executes_submit_callback' => TRUE, '#ahah_event' => 'submit', '#process' => array('form_expand_ahah'), '#has_garbage_value' => TRUE, '#image' => NULL);
|
||||
$type['image_button'] = array('#input' => TRUE, '#button_type' => 'submit','#executes_submit_callback' => TRUE, '#ahah_event' => 'submit', '#process' => array('form_expand_ahah'), '#return_value' => TRUE, '#has_garbage_value' => TRUE, '#src' => NULL);
|
||||
$type['textfield'] = array('#input' => TRUE, '#size' => 60, '#maxlength' => 128, '#autocomplete_path' => FALSE);
|
||||
$type['password'] = array('#input' => TRUE, '#size' => 60, '#maxlength' => 128);
|
||||
$type['password_confirm'] = array('#input' => TRUE, '#process' => array('expand_password_confirm'));
|
||||
|
|
|
|||
Loading…
Reference in New Issue