trait ImageFieldCreationTrait

Same name in other branches
  1. 9 core/modules/image/tests/src/Kernel/ImageFieldCreationTrait.php \Drupal\Tests\image\Kernel\ImageFieldCreationTrait
  2. 8.9.x core/modules/image/tests/src/Kernel/ImageFieldCreationTrait.php \Drupal\Tests\image\Kernel\ImageFieldCreationTrait
  3. 10 core/modules/image/tests/src/Kernel/ImageFieldCreationTrait.php \Drupal\Tests\image\Kernel\ImageFieldCreationTrait

Provides a helper method for creating Image fields.

Hierarchy

8 files declare their use of ImageFieldCreationTrait
ContentTranslationLanguageChangeTest.php in core/modules/content_translation/tests/src/Functional/ContentTranslationLanguageChangeTest.php
FilterTest.php in core/modules/jsonapi/tests/src/Kernel/Query/FilterTest.php
ImageFieldTestBase.php in core/modules/image/tests/src/FunctionalJavascript/ImageFieldTestBase.php
ImageFieldTestBase.php in core/modules/image/tests/src/Functional/ImageFieldTestBase.php
ImageFieldWidgetMultipleTest.php in core/modules/image/tests/src/FunctionalJavascript/ImageFieldWidgetMultipleTest.php

... See full list

File

core/modules/image/tests/src/Kernel/ImageFieldCreationTrait.php, line 13

Namespace

Drupal\Tests\image\Kernel
View source
trait ImageFieldCreationTrait {
    
    /**
     * Create a new image field.
     *
     * @param string $field_name
     *   The name of the new field (all lowercase). The Field UI 'field_' prefix
     *   is not added to the field name.
     * @param string $entity_type
     *   The entity type that this field will be added to.
     * @param string $bundle
     *   The bundle this field will be added to.
     * @param array $storage_settings
     *   (optional) A list of field storage settings that will be added to the
     *   defaults.
     * @param array $field_settings
     *   (optional) A list of instance settings that will be added to the instance
     *   defaults.
     * @param array $widget_settings
     *   (optional) Widget settings to be added to the widget defaults.
     * @param array $formatter_settings
     *   (optional) Formatter settings to be added to the formatter defaults.
     * @param string $description
     *   (optional) A description for the field. Defaults to ''.
     */
    protected function createImageField($field_name, $entity_type, $bundle, $storage_settings = [], $field_settings = [], $widget_settings = [], $formatter_settings = [], $description = '') {
        FieldStorageConfig::create([
            'field_name' => $field_name,
            'entity_type' => $entity_type,
            'type' => 'image',
            'settings' => $storage_settings,
            'cardinality' => !empty($storage_settings['cardinality']) ? $storage_settings['cardinality'] : 1,
        ])->save();
        $field_config = FieldConfig::create([
            'field_name' => $field_name,
            'label' => $field_name,
            'entity_type' => $entity_type,
            'bundle' => $bundle,
            'required' => !empty($field_settings['required']),
            'settings' => $field_settings,
            'description' => $description,
        ]);
        $field_config->save();
        
        /** @var \Drupal\Core\Entity\EntityDisplayRepositoryInterface $display_repository */
        $display_repository = \Drupal::service('entity_display.repository');
        $display_repository->getFormDisplay($entity_type, $bundle)
            ->setComponent($field_name, [
            'type' => 'image_image',
            'settings' => $widget_settings,
        ])
            ->save();
        $display_repository->getViewDisplay($entity_type, $bundle)
            ->setComponent($field_name, [
            'type' => 'image',
            'settings' => $formatter_settings,
        ])
            ->save();
        return $field_config;
    }

}

Members

Title Sort descending Modifiers Object type Summary
ImageFieldCreationTrait::createImageField protected function Create a new image field.

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