class FieldStorageConfigListBuilder

Same name in other branches
  1. 9 core/modules/field_ui/src/FieldStorageConfigListBuilder.php \Drupal\field_ui\FieldStorageConfigListBuilder
  2. 8.9.x core/modules/field_ui/src/FieldStorageConfigListBuilder.php \Drupal\field_ui\FieldStorageConfigListBuilder
  3. 10 core/modules/field_ui/src/FieldStorageConfigListBuilder.php \Drupal\field_ui\FieldStorageConfigListBuilder

Defines a class to build a listing of fields.

Hierarchy

Expanded class hierarchy of FieldStorageConfigListBuilder

See also

\Drupal\field\Entity\FieldStorageConfig

field_ui_entity_type_build()

File

core/modules/field_ui/src/FieldStorageConfigListBuilder.php, line 20

Namespace

Drupal\field_ui
View source
class FieldStorageConfigListBuilder extends ConfigEntityListBuilder {
    
    /**
     * An array of information about field types.
     *
     * @var array
     */
    protected $fieldTypes;
    
    /**
     * The entity type manager.
     *
     * @var \Drupal\Core\Entity\EntityTypeManagerInterface
     */
    protected $entityTypeManager;
    
    /**
     * An array of entity bundle information.
     *
     * @var array
     */
    protected $bundles;
    
    /**
     * The field type manager.
     *
     * @var \Drupal\Core\Field\FieldTypePluginManagerInterface
     */
    protected $fieldTypeManager;
    
    /**
     * Constructs a new FieldStorageConfigListBuilder object.
     *
     * @param \Drupal\Core\Entity\EntityTypeInterface $entity_type
     *   The entity type definition.
     * @param \Drupal\Core\Entity\EntityTypeManagerInterface $entity_type_manager
     *   The entity type manager.
     * @param \Drupal\Core\Field\FieldTypePluginManagerInterface $field_type_manager
     *   The 'field type' plugin manager.
     * @param \Drupal\Core\Entity\EntityTypeBundleInfoInterface $bundle_info_service
     *   The bundle info service.
     */
    public function __construct(EntityTypeInterface $entity_type, EntityTypeManagerInterface $entity_type_manager, FieldTypePluginManagerInterface $field_type_manager, EntityTypeBundleInfoInterface $bundle_info_service) {
        parent::__construct($entity_type, $entity_type_manager->getStorage($entity_type->id()));
        $this->entityTypeManager = $entity_type_manager;
        $this->bundles = $bundle_info_service->getAllBundleInfo();
        $this->fieldTypeManager = $field_type_manager;
        $this->fieldTypes = $this->fieldTypeManager
            ->getDefinitions();
        $this->limit = FALSE;
    }
    
    /**
     * {@inheritdoc}
     */
    public static function createInstance(ContainerInterface $container, EntityTypeInterface $entity_type) {
        return new static($entity_type, $container->get('entity_type.manager'), $container->get('plugin.manager.field.field_type'), $container->get('entity_type.bundle.info'));
    }
    
    /**
     * {@inheritdoc}
     */
    public function render() {
        $build = parent::render();
        $build['#attached']['library'][] = 'field_ui/drupal.field_ui';
        return $build;
    }
    
    /**
     * {@inheritdoc}
     */
    public function buildHeader() {
        $header['id'] = $this->t('Field name');
        $header['entity_type'] = $this->t('Entity type');
        $header['type'] = [
            'data' => $this->t('Field type'),
            'class' => [
                RESPONSIVE_PRIORITY_MEDIUM,
            ],
        ];
        $header['usage'] = $this->t('Used in');
        $header['settings_summary'] = $this->t('Summary');
        return $header;
    }
    
    /**
     * {@inheritdoc}
     */
    public function buildRow(EntityInterface $field_storage) {
        if ($field_storage->isLocked()) {
            $row['class'] = [
                'menu-disabled',
            ];
            $row['data']['id'] = $this->t('@field_name (Locked)', [
                '@field_name' => $field_storage->getName(),
            ]);
        }
        else {
            $row['data']['id'] = $field_storage->getName();
        }
        $entity_type_id = $field_storage->getTargetEntityTypeId();
        // Adding the entity type.
        $row['data']['entity_type'] = $entity_type_id;
        $field_type = $this->fieldTypes[$field_storage->getType()];
        $row['data']['type'] = $this->t('@type (module: @module)', [
            '@type' => $field_type['label'],
            '@module' => $field_type['provider'],
        ]);
        $usage = [];
        foreach ($field_storage->getBundles() as $bundle) {
            if ($route_info = FieldUI::getOverviewRouteInfo($entity_type_id, $bundle)) {
                $usage[] = Link::fromTextAndUrl($this->bundles[$entity_type_id][$bundle]['label'], $route_info)
                    ->toRenderable();
            }
            else {
                $usage[] = $this->bundles[$entity_type_id][$bundle]['label'];
            }
        }
        $row['data']['usage']['data'] = [
            '#theme' => 'item_list',
            '#items' => $usage,
            '#context' => [
                'list_style' => 'comma-list',
            ],
        ];
        $summary = $this->fieldTypeManager
            ->getStorageSettingsSummary($field_storage);
        $row['data']['settings_summary'] = empty($summary) ? '' : [
            'data' => [
                '#theme' => 'item_list',
                '#items' => $summary,
            ],
            'class' => [
                'storage-settings-summary-cell',
            ],
        ];
        return $row;
    }

}

Members

Title Sort descending Modifiers Object type Summary Overriden Title Overrides
ConfigEntityListBuilder::$storage protected property The config entity storage class. Overrides EntityListBuilder::$storage
ConfigEntityListBuilder::getDefaultOperations public function Gets this list's default operations. Overrides EntityListBuilder::getDefaultOperations 15
ConfigEntityListBuilder::getStorage public function Gets the config entity storage. Overrides EntityListBuilder::getStorage
ConfigEntityListBuilder::load public function Loads entities of this type from storage for listing. Overrides EntityListBuilder::load 6
DependencySerializationTrait::$_entityStorages protected property
DependencySerializationTrait::$_serviceIds protected property
DependencySerializationTrait::__sleep public function 1
DependencySerializationTrait::__wakeup public function 2
EntityHandlerBase::$moduleHandler protected property The module handler to invoke hooks on. 5
EntityHandlerBase::moduleHandler protected function Gets the module handler. 5
EntityHandlerBase::setModuleHandler public function Sets the module handler for this handler.
EntityListBuilder::$entityType protected property Information about the entity type.
EntityListBuilder::$entityTypeId protected property The entity type ID.
EntityListBuilder::$limit protected property The number of entities to list per page, or FALSE to list all entities.
EntityListBuilder::buildOperations public function Builds a renderable list of operation links for the entity. 2
EntityListBuilder::ensureDestination protected function Ensures that a destination is present on the given URL. 1
EntityListBuilder::getEntityIds protected function Loads entity IDs using a pager sorted by the entity id. 4
EntityListBuilder::getEntityListQuery protected function Returns a query object for loading entity IDs from the storage.
EntityListBuilder::getOperations public function Provides an array of information to build a list of operation links. Overrides EntityListBuilderInterface::getOperations 3
EntityListBuilder::getTitle protected function Gets the title of the page. 1
EntityListBuilder::SORT_KEY protected constant The entity key to sort the list by. 1
FieldStorageConfigListBuilder::$bundles protected property An array of entity bundle information.
FieldStorageConfigListBuilder::$entityTypeManager protected property The entity type manager.
FieldStorageConfigListBuilder::$fieldTypeManager protected property The field type manager.
FieldStorageConfigListBuilder::$fieldTypes protected property An array of information about field types.
FieldStorageConfigListBuilder::buildHeader public function Builds the header row for the entity listing. Overrides EntityListBuilder::buildHeader
FieldStorageConfigListBuilder::buildRow public function Builds a row for an entity in the entity listing. Overrides EntityListBuilder::buildRow
FieldStorageConfigListBuilder::createInstance public static function Instantiates a new instance of this entity handler. Overrides EntityListBuilder::createInstance
FieldStorageConfigListBuilder::render public function Builds the entity listing as renderable array for table.html.twig. Overrides EntityListBuilder::render
FieldStorageConfigListBuilder::__construct public function Constructs a new FieldStorageConfigListBuilder object. Overrides EntityListBuilder::__construct
MessengerTrait::$messenger protected property The messenger. 16
MessengerTrait::messenger public function Gets the messenger. 16
MessengerTrait::setMessenger public function Sets the messenger.
RedirectDestinationTrait::$redirectDestination protected property The redirect destination service. 2
RedirectDestinationTrait::getDestinationArray protected function Prepares a 'destination' URL query parameter for use with \Drupal\Core\Url.
RedirectDestinationTrait::getRedirectDestination protected function Returns the redirect destination service.
RedirectDestinationTrait::setRedirectDestination public function Sets the redirect destination service.
StringTranslationTrait::$stringTranslation protected property The string translation service. 3
StringTranslationTrait::formatPlural protected function Formats a string containing a count of items.
StringTranslationTrait::getNumberOfPlurals protected function Returns the number of plurals supported by a given language.
StringTranslationTrait::getStringTranslation protected function Gets the string translation service.
StringTranslationTrait::setStringTranslation public function Sets the string translation service to use. 2
StringTranslationTrait::t protected function Translates a string to the current language or to a given language.

Buggy or inaccurate documentation? Please file an issue. Need support? Need help programming? Connect with the Drupal community.