You are here

public function LinkWidget::settingsForm in Drupal 9

Same name and namespace in other branches
  1. 8 core/modules/link/src/Plugin/Field/FieldWidget/LinkWidget.php \Drupal\link\Plugin\Field\FieldWidget\LinkWidget::settingsForm()

Returns a form to configure settings for the widget.

Invoked from \Drupal\field_ui\Form\EntityDisplayFormBase to allow administrators to configure the widget. The field_ui module takes care of handling submitted form values.

Parameters

array $form: The form where the settings form is being included in.

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

Return value

array The form definition for the widget settings.

Overrides WidgetBase::settingsForm

File

core/modules/link/src/Plugin/Field/FieldWidget/LinkWidget.php, line 351

Class

LinkWidget
Plugin implementation of the 'link' widget.

Namespace

Drupal\link\Plugin\Field\FieldWidget

Code

public function settingsForm(array $form, FormStateInterface $form_state) {
  $elements = parent::settingsForm($form, $form_state);
  $elements['placeholder_url'] = [
    '#type' => 'textfield',
    '#title' => $this
      ->t('Placeholder for URL'),
    '#default_value' => $this
      ->getSetting('placeholder_url'),
    '#description' => $this
      ->t('Text that will be shown inside the field until a value is entered. This hint is usually a sample value or a brief description of the expected format.'),
  ];
  $elements['placeholder_title'] = [
    '#type' => 'textfield',
    '#title' => $this
      ->t('Placeholder for link text'),
    '#default_value' => $this
      ->getSetting('placeholder_title'),
    '#description' => $this
      ->t('Text that will be shown inside the field until a value is entered. This hint is usually a sample value or a brief description of the expected format.'),
    '#states' => [
      'invisible' => [
        ':input[name="instance[settings][title]"]' => [
          'value' => DRUPAL_DISABLED,
        ],
      ],
    ],
  ];
  return $elements;
}