protected FormValidator::doValidateForm(&$elements, FormStateInterface &$form_state, $form_id = NULL)
Performs validation on form elements.
First ensures required fields are completed, #maxlength is not exceeded, and selected options were in the list of options given to the user. Then calls user-defined validators.
Parameters
$elements: An associative array containing the structure of the form.
\Drupal\Core\Form\FormStateInterface $form_state: The current state of the form. The current user-submitted data is stored in $form_state->getValues(), though form validation functions are passed an explicit copy of the values for the sake of simplicity. Validation handlers can also $form_state to pass information on to submit handlers. For example: $form_state->set('data_for_submission', $data); This technique is useful when validation requires file parsing, web service requests, or other expensive requests that should not be repeated in the submission step.
$form_id: A unique string identifying the form for validation, submission, theming, and hook_form_alter functions.
File
- core/lib/Drupal/Core/Form/FormValidator.php, line 231
Class
- FormValidator
- Provides validation of form submissions.
Namespace
Drupal\Core\Form
Code
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 | protected function doValidateForm(& $elements , FormStateInterface & $form_state , $form_id = NULL) { // Recurse through all children. foreach (Element::children( $elements ) as $key ) { if (isset( $elements [ $key ]) && $elements [ $key ]) { $this ->doValidateForm( $elements [ $key ], $form_state ); } } // Validate the current input. if (!isset( $elements [ '#validated' ]) || ! $elements [ '#validated' ]) { // The following errors are always shown. if (isset( $elements [ '#needs_validation' ])) { $this ->performRequiredValidation( $elements , $form_state ); } // Set up the limited validation for errors. $form_state ->setLimitValidationErrors( $this ->determineLimitValidationErrors( $form_state )); // Make sure a value is passed when the field is required. if (isset( $elements [ '#needs_validation' ]) && $elements [ '#required' ]) { // A simple call to empty() will not cut it here as some fields, like // checkboxes, can return a valid value of '0'. Instead, check the // length if it's a string, and the item count if it's an array. // An unchecked checkbox has a #value of integer 0, different than // string '0', which could be a valid value. $is_empty_multiple = (! count ( $elements [ '#value' ])); $is_empty_string = ( is_string ( $elements [ '#value' ]) && Unicode:: strlen (trim( $elements [ '#value' ])) == 0); $is_empty_value = ( $elements [ '#value' ] === 0); if ( $is_empty_multiple || $is_empty_string || $is_empty_value ) { // Flag this element as #required_but_empty to allow #element_validate // handlers to set a custom required error message, but without having // to re-implement the complex logic to figure out whether the field // value is empty. $elements [ '#required_but_empty' ] = TRUE; } } // Call user-defined form level validators. if (isset( $form_id )) { $this ->executeValidateHandlers( $elements , $form_state ); } // Call any element-specific validators. These must act on the element // #value data. elseif (isset( $elements [ '#element_validate' ])) { foreach ( $elements [ '#element_validate' ] as $callback ) { $complete_form = & $form_state ->getCompleteForm(); call_user_func_array( $form_state ->prepareCallback( $callback ), array (& $elements , & $form_state , & $complete_form )); } } // Ensure that a #required form error is thrown, regardless of whether // #element_validate handlers changed any properties. If $is_empty_value // is defined, then above #required validation code ran, so the other // variables are also known to be defined and we can test them again. if (isset( $is_empty_value ) && ( $is_empty_multiple || $is_empty_string || $is_empty_value )) { if (isset( $elements [ '#required_error' ])) { $form_state ->setError( $elements , $elements [ '#required_error' ]); } // A #title is not mandatory for form elements, but without it we cannot // set a form error message. So when a visible title is undesirable, // form constructors are encouraged to set #title anyway, and then set // #title_display to 'invisible'. This improves accessibility. elseif (isset( $elements [ '#title' ])) { $form_state ->setError( $elements , $this ->t( '@name field is required.' , array ( '@name' => $elements [ '#title' ]))); } else { $form_state ->setError( $elements ); } } $elements [ '#validated' ] = TRUE; } // Done validating this element, so turn off error suppression. // self::doValidateForm() turns it on again when starting on the next // element, if it's still appropriate to do so. $form_state ->setLimitValidationErrors(NULL); } |
Please login to continue.