public function CpfItem::storageSettingsForm in CPF 8.2
Same name and namespace in other branches
- 8 src/Plugin/Field/FieldType/CpfItem.php \Drupal\cpf\Plugin\Field\FieldType\CpfItem::storageSettingsForm()
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/ CpfItem.php, line 101 - Contains \Drupal\cpf\Plugin\Field\FieldType\CpfItem.
Class
- CpfItem
- Plugin implementation of the 'cpf' field type.
Namespace
Drupal\cpf\Plugin\Field\FieldTypeCode
public function storageSettingsForm(array &$form, FormStateInterface $form_state, $has_data) {
$element = [];
$element['unique'] = [
'#type' => 'radios',
'#title' => t('Allow only unique values'),
'#default_value' => $this
->getSetting('unique'),
'#options' => [
static::SAME_VALUES => $this
->t('no'),
static::UNIQUE_VALUES => $this
->t('yes'),
],
'#disabled' => $has_data,
];
$element['ignore_bundle'] = [
'#type' => 'checkbox',
'#title' => t('Ignore bundle'),
'#default_value' => $this
->getSetting('ignore_bundle'),
'#description' => $this
->t('If this option is selected, validation of unique values will ignore the entity type (bundle).'),
'#states' => [
'visible' => [
':input[name="settings[unique]"]' => [
'value' => static::UNIQUE_VALUES,
],
],
],
'#disabled' => $has_data,
];
$element += parent::storageSettingsForm($form, $form_state, $has_data);
return $element;
}