You are here

public function BarcodeBase::storageSettingsForm in Barcode 8

Returns a form for the storage-level settings.

Invoked from \Drupal\field_ui\Form\FieldStorageConfigEditForm to allow administrators to configure storage-level settings.

Field storage might reject settings changes that affect the field storage schema if the storage already has data. When the $has_data parameter is TRUE, the form should not allow changing the settings that take part in the schema() method. It is recommended to set #access to FALSE on the corresponding elements.

Parameters

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

\Drupal\Core\Form\FormStateInterface $form_state: The form state of the (entire) configuration form.

bool $has_data: TRUE if the field already has data, FALSE if not.

Return value

array The form definition for the field settings.

Overrides FieldItemBase::storageSettingsForm

File

src/Plugin/Field/FieldType/BarcodeBase.php, line 39

Class

BarcodeBase

Namespace

Drupal\barcode\Plugin\Field\FieldType

Code

public function storageSettingsForm(array &$form, FormStateInterface $form_state, $has_data) {
  $types = $this
    ->getSetting('types');
  $element['types'] = [
    '#type' => 'textarea',
    '#title' => t('Allowed Barcode Types'),
    '#default_value' => $this
      ->getTypesString($types),
    '#rows' => 10,
    '#access' => empty($allowed_values_function),
    '#element_validate' => [
      [
        get_class($this),
        'validateTypes',
      ],
    ],
    '#field_has_data' => $has_data,
    '#field_name' => $this
      ->getFieldDefinition()
      ->getName(),
    '#entity_type' => $this
      ->getEntity()
      ->getEntityTypeId(),
    '#current_types' => $types,
  ];
  return $element;
}