ds-8.x-3.9/src/Form/FieldFormBase.php
src/Form/FieldFormBase.php
<?php
namespace Drupal\ds\Form;
use Drupal\Component\Utility\Unicode;
use Drupal\Core\Cache\CacheTagsInvalidatorInterface;
use Drupal\Core\Config\ConfigFactory;
use Drupal\Core\Config\TypedConfigManagerInterface;
use Drupal\Core\DependencyInjection\ContainerInjectionInterface;
use Drupal\Core\Entity\EntityTypeManagerInterface;
use Drupal\Core\Extension\ModuleHandlerInterface;
use Drupal\Core\Form\ConfigFormBase;
use Drupal\Core\Form\FormStateInterface;
use Drupal\Core\Url;
use Symfony\Component\DependencyInjection\ContainerInterface;
/**
* Base form for fields.
*/
class FieldFormBase extends ConfigFormBase implements ContainerInjectionInterface {
/**
* Holds the entity type manager.
*
* @var \Drupal\Core\Entity\EntityTypeManager
*/
protected $entityTypeManager;
/**
* Holds the cache invalidator.
*
* @var \Drupal\Core\Cache\CacheTagsInvalidatorInterface
*/
protected $cacheInvalidator;
/**
* Drupal module handler.
*
* @var \Drupal\Core\Extension\ModuleHandlerInterface
*/
protected $moduleHandler;
/**
* The field properties.
*
* @var array
*/
protected $field;
/**
* Constructs a \Drupal\system\CustomFieldFormBase object.
*
* @param \Drupal\Core\Config\ConfigFactory $config_factory
* The factory for configuration objects.
* @param \Drupal\Core\Entity\EntityTypeManagerInterface $entity_type_manager
* The entity type manager.
* @param \Drupal\Core\Cache\CacheTagsInvalidatorInterface $cache_invalidator
* The cache invalidator.
* @param \Drupal\Core\Extension\ModuleHandlerInterface $module_handler
* The module handler.
* @param \Drupal\Core\Config\TypedConfigManagerInterface $typed_config_manager
* The typed config manager.
*/
public function __construct(ConfigFactory $config_factory, EntityTypeManagerInterface $entity_type_manager, CacheTagsInvalidatorInterface $cache_invalidator, ModuleHandlerInterface $module_handler, TypedConfigManagerInterface $typed_config_manager) {
parent::__construct($config_factory, $typed_config_manager);
$this->entityTypeManager = $entity_type_manager;
$this->cacheInvalidator = $cache_invalidator;
$this->moduleHandler = $module_handler;
}
/**
* {@inheritdoc}
*/
public static function create(ContainerInterface $container) {
return new static(
$container->get('config.factory'),
$container->get('entity_type.manager'),
$container->get('cache_tags.invalidator'),
$container->get('module_handler'),
$container->get('config.typed')
);
}
/**
* {@inheritdoc}
*/
public function getFormId() {
return 'ds_custom_field_form';
}
/**
* {@inheritdoc}
*/
public function buildForm(array $form, FormStateInterface $form_state, $field_key = '') {
// Initialize field.
$field = [];
// Fetch field if it already exists.
if (!empty($field_key)) {
$field = $this->config('ds.field.' . $field_key)->get();
}
// Save the field for future reuse.
$this->field = $field;
$form['name'] = [
'#title' => $this->t('Label'),
'#type' => 'textfield',
'#default_value' => $field['label'] ?? '',
'#description' => $this->t('The human-readable label of the field.'),
'#maxlength' => 128,
'#required' => TRUE,
'#size' => 30,
];
$form['id'] = [
'#type' => 'machine_name',
'#default_value' => $field['id'] ?? '',
'#maxlength' => 32,
'#description' => $this->t('The machine-readable name of this field. This name must contain only lowercase letters and underscores. This name must be unique.'),
'#disabled' => !empty($field['id']),
'#machine_name' => [
'exists' => [$this, 'uniqueFieldName'],
'source' => ['name'],
],
];
$entity_options = [];
$entities = $this->entityTypeManager->getDefinitions();
foreach ($entities as $entity_type => $entity_info) {
if ($entity_info->get('field_ui_base_route') || $entity_type == 'ds_views') {
$entity_options[$entity_type] = Unicode::ucfirst(str_replace('_', ' ', $entity_type));
}
}
$form['entities'] = [
'#title' => $this->t('Entities'),
'#description' => $this->t('Select the entities for which this field will be made available.'),
'#type' => 'checkboxes',
'#required' => TRUE,
'#options' => $entity_options,
'#default_value' => $field['entities'] ?? [],
];
$form['ui_limit'] = [
'#title' => $this->t('Limit field'),
'#description' => $this->t('Limit this field on field UI per bundles and/or view modes. The values are in the form of $bundle|$view_mode, where $view_mode may be either a view mode set to use custom settings, or \'default\'. You may use * to select all, e.g article|*, *|full or *|*. Enter one value per line.'),
'#type' => 'textarea',
'#default_value' => $field['ui_limit'] ?? '',
];
$form['submit'] = [
'#type' => 'submit',
'#value' => $this->t('Save'),
'#weight' => 100,
];
return $form;
}
/**
* {@inheritdoc}
*/
public function submitForm(array &$form, FormStateInterface $form_state) {
$field = [];
$field['id'] = $form_state->getValue('id');
$field['label'] = $form_state->getValue('name');
$field['ui_limit'] = $form_state->getValue('ui_limit');
$field['properties'] = $this->getProperties($form_state);
$field['type'] = $this->getType();
$field['type_label'] = $this->getTypeLabel();
$entities = $form_state->getValue('entities');
foreach ($entities as $key => $value) {
if ($key !== $value) {
unset($entities[$key]);
}
}
$field['entities'] = $entities;
// Save field to property.
$this->field = $field;
// Save field values.
$this->config('ds.field.' . $field['id'])->setData($field)->save();
// Clear caches and redirect.
$this->finishSubmitForm($form, $form_state);
}
/**
* {@inheritdoc}
*/
protected function getEditableConfigNames() {
if (isset($this->field, $this->field['id'])) {
return [
'ds.field.' . $this->field['id'],
];
}
else {
return [];
}
}
/**
* Returns the properties for the custom field.
*/
public function getProperties(FormStateInterface $form_state) {
return [];
}
/**
* Returns the type of the field.
*/
public function getType() {
return '';
}
/**
* Returns the admin label for the field on the field overview page.
*/
public function getTypeLabel() {
return '';
}
/**
* Returns whether a field machine name is unique.
*/
public function uniqueFieldName($name) {
$value = strtr($name, ['-' => '_']);
$config = $this->configFactory()->get('ds.field.' . $value);
if ($config->get()) {
return TRUE;
}
return FALSE;
}
/**
* Finishes the submit.
*/
public function finishSubmitForm(array &$form, FormStateInterface $form_state) {
$field = $this->field;
// Save field and clear ds_fields_info cache.
$this->cacheInvalidator->invalidateTags(['ds_fields_info']);
// Also clear the ds plugin cache.
\Drupal::service('plugin.manager.ds')->clearCachedDefinitions();
// Redirect.
$url = new Url('ds.fields_list');
$form_state->setRedirectUrl($url);
$this->messenger()->addMessage($this->t('The field %field has been saved.', ['%field' => $field['label']]));
}
}
