switch html5 form validation off for cancel buttons and in etemplate editor (or whenever any $ignore_validation expression is given)

This commit is contained in:
Ralf Becker 2011-07-07 12:54:11 +00:00
parent 4f60da9af5
commit 2b0278fbbd

View File

@ -247,6 +247,9 @@ class etemplate extends boetemplate
self::$request->ignore_validation = $ignore_validation; self::$request->ignore_validation = $ignore_validation;
self::$request->name_vars = self::$name_vars; self::$request->name_vars = self::$name_vars;
// tell html5 form validation NOT to validate
if ($ignore_validation) self::$form_options .= ' novalidate="novalidate"';
if((int) $output_mode == 3) if((int) $output_mode == 3)
{ {
self::$styles_included[$this->name] = True; self::$styles_included[$this->name] = True;
@ -1419,6 +1422,7 @@ class etemplate extends boetemplate
case 'button': case 'button':
case 'buttononly': case 'buttononly':
case 'cancel': // cancel button case 'cancel': // cancel button
if ($name == 'cancel' || stripos($name,'[cancel]') !== false) $type = 'cancel';
list($app) = explode('.',$this->name); list($app) = explode('.',$this->name);
list($img,$ro_img) = explode(',',$cell_options); list($img,$ro_img) = explode(',',$cell_options);
if ($img[0] != '/' && strpos($img,'/') !== false && count($img_parts = explode('/',$img)) == 2) if ($img[0] != '/' && strpos($img,'/') !== false && count($img_parts = explode('/',$img)) == 2)
@ -1458,6 +1462,7 @@ class etemplate extends boetemplate
{ {
$onclick = ($onclick ? preg_replace('/^return(.*);$/','if (\\1) ',$onclick) : '').$cell['onchange']; $onclick = ($onclick ? preg_replace('/^return(.*);$/','if (\\1) ',$onclick) : '').$cell['onchange'];
} }
if ($type == 'cancel') $options .= ' novalidate="novalidate"'; // tell html5 form validation NOT to validate
$html .= !$readonly ? html::submit_button($form_name,$label,$onclick, $html .= !$readonly ? html::submit_button($form_name,$label,$onclick,
strlen($label) <= 1 || $cell['no_lang'],$options,$img,$app,$type == 'buttononly' ? 'button' : 'submit') : strlen($label) <= 1 || $cell['no_lang'],$options,$img,$app,$type == 'buttononly' ? 'button' : 'submit') :
html::image($app,$ro_img,'',$options); html::image($app,$ro_img,'',$options);
@ -1465,11 +1470,7 @@ class etemplate extends boetemplate
$extra_label = False; $extra_label = False;
if (!$readonly && $type != 'buttononly') // input button, are never submitted back! if (!$readonly && $type != 'buttononly') // input button, are never submitted back!
{ {
self::$request->set_to_process($form_name,$cell['type']); self::$request->set_to_process($form_name,$type);
if ($name == 'cancel' || stripos($name,'[cancel]') !== false)
{
self::$request->set_to_process($form_name,'cancel');
}
} }
break; break;
case 'hrule': case 'hrule':