You are here

public function GeocoderWidget::errorElement in Geocoder 8

Assigns a field-level validation error to the right widget sub-element.

Depending on the widget's internal structure, a field-level validation error needs to be flagged on the right sub-element.

Parameters

array $element: An array containing the form element for the widget, as generated by formElement().

\Symfony\Component\Validator\ConstraintViolationInterface $violation: A constraint violation reported during the validation phase.

array $form: The form structure where field elements are attached to. This might be a full form structure, or a sub-element of a larger form.

\Drupal\Core\Form\FormStateInterface $form_state: The current state of the form.

Return value

array|bool The element on which the error should be flagged, or FALSE to completely ignore the violation (use with care!).

Overrides WidgetBase::errorElement

File

src/Plugin/Field/FieldWidget/GeocoderWidget.php, line 135
Contains \Drupal\geocoder\Plugin\Field\FieldWidget\GeocoderWidget.

Class

GeocoderWidget
Plugin implementation of the 'geocoder_default' widget.

Namespace

Drupal\geocoder\Plugin\Field\FieldWidget

Code

public function errorElement(array $element, ConstraintViolationInterface $violation, array $form, FormStateInterface $form_state) {
  if ($violation->arrayPropertyPath == array(
    'format',
  ) && isset($element['format']['#access']) && !$element['format']['#access']) {

    // Ignore validation errors for formats if formats may not be changed,
    // i.e. when existing formats become invalid. See filter_process_format().
    return FALSE;
  }
  return $element;
}