class BlockPluginId

Same name in other branches
  1. 9 core/modules/block/src/Plugin/migrate/process/BlockPluginId.php \Drupal\block\Plugin\migrate\process\BlockPluginId
  2. 8.9.x core/modules/block/src/Plugin/migrate/process/BlockPluginId.php \Drupal\block\Plugin\migrate\process\BlockPluginId
  3. 10 core/modules/block/src/Plugin/migrate/process/BlockPluginId.php \Drupal\block\Plugin\migrate\process\BlockPluginId

Hierarchy

Expanded class hierarchy of BlockPluginId

File

core/modules/block/src/Plugin/migrate/process/BlockPluginId.php, line 15

Namespace

Drupal\block\Plugin\migrate\process
View source
class BlockPluginId extends ProcessPluginBase implements ContainerFactoryPluginInterface {
    
    /**
     * The migrate lookup service.
     *
     * @var \Drupal\migrate\MigrateLookupInterface
     */
    protected $migrateLookup;
    
    /**
     * The block_content entity storage handler.
     *
     * @var \Drupal\Core\Entity\EntityStorageInterface|null
     */
    protected $blockContentStorage;
    
    /**
     * Constructs a BlockPluginId object.
     *
     * @param array $configuration
     *   The plugin configuration.
     * @param string $plugin_id
     *   The plugin ID.
     * @param array $plugin_definition
     *   The plugin definition.
     * @param \Drupal\Core\Entity\EntityStorageInterface|null $storage
     *   The block content storage object. NULL if the block_content module is
     *   not installed.
     * @param \Drupal\migrate\MigrateLookupInterface $migrate_lookup
     *   The migrate lookup service.
     */
    public function __construct(array $configuration, $plugin_id, array $plugin_definition, ?EntityStorageInterface $storage, MigrateLookupInterface $migrate_lookup) {
        parent::__construct($configuration, $plugin_id, $plugin_definition);
        $this->blockContentStorage = $storage;
        $this->migrateLookup = $migrate_lookup;
    }
    
    /**
     * {@inheritdoc}
     */
    public static function create(ContainerInterface $container, array $configuration, $plugin_id, $plugin_definition, ?MigrationInterface $migration = NULL) {
        $entity_type_manager = $container->get('entity_type.manager');
        return new static($configuration, $plugin_id, $plugin_definition, $entity_type_manager->hasDefinition('block_content') ? $entity_type_manager->getStorage('block_content') : NULL, $container->get('migrate.lookup'));
    }
    
    /**
     * {@inheritdoc}
     *
     * Set the block plugin id.
     */
    public function transform($value, MigrateExecutableInterface $migrate_executable, Row $row, $destination_property) {
        if (is_array($value)) {
            [
                $module,
                $delta,
            ] = $value;
            switch ($module) {
                case 'aggregator':
                    [
                        $type,
                    ] = explode('-', $delta);
                    if ($type == 'feed') {
                        return 'aggregator_feed_block';
                    }
                    break;
                case 'menu':
                    return "system_menu_block:{$delta}";
                case 'block':
                    if ($this->blockContentStorage) {
                        $block_id = $row->getDestinationProperty('_block_module_plugin_id');
                        // Legacy generated migrations will not have the destination
                        // property '_block_module_plugin_id'.
                        if (!$block_id) {
                            $lookup_result = $this->migrateLookup
                                ->lookup([
                                'd6_custom_block',
                                'd7_custom_block',
                            ], [
                                $delta,
                            ]);
                            if ($lookup_result) {
                                $block_id = $lookup_result[0]['id'];
                            }
                        }
                        if ($block_id) {
                            return 'block_content:' . $this->blockContentStorage
                                ->load($block_id)
                                ->uuid();
                        }
                    }
                    break;
                default:
                    break;
            }
        }
        else {
            return $value;
        }
    }

}

Members

Title Sort descending Modifiers Object type Summary Overriden Title Overrides
BlockPluginId::$blockContentStorage protected property The block_content entity storage handler.
BlockPluginId::$migrateLookup protected property The migrate lookup service.
BlockPluginId::create public static function Creates an instance of the plugin. Overrides ContainerFactoryPluginInterface::create
BlockPluginId::transform public function Set the block plugin id. Overrides ProcessPluginBase::transform
BlockPluginId::__construct public function Constructs a BlockPluginId object.
PluginInspectionInterface::getPluginDefinition public function Gets the definition of the plugin implementation. 6
PluginInspectionInterface::getPluginId public function Gets the plugin ID of the plugin instance. 2
ProcessPluginBase::$stopPipeline protected property Determines if processing of the pipeline is stopped.
ProcessPluginBase::isPipelineStopped public function Determines if the pipeline should stop processing. Overrides MigrateProcessInterface::isPipelineStopped
ProcessPluginBase::multiple public function Indicates whether the returned value requires multiple handling. Overrides MigrateProcessInterface::multiple 3
ProcessPluginBase::reset public function Resets the internal data of a plugin. Overrides MigrateProcessInterface::reset
ProcessPluginBase::stopPipeline protected function Stops pipeline processing after this plugin finishes.

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