Code Coverage |
||||||||||
Classes and Traits |
Functions and Methods |
Lines |
||||||||
Total | |
0.00% |
0 / 1 |
|
0.00% |
0 / 3 |
CRAP | |
0.00% |
0 / 25 |
BlockTheme | |
0.00% |
0 / 1 |
|
0.00% |
0 / 3 |
42 | |
0.00% |
0 / 25 |
__construct | |
0.00% |
0 / 1 |
2 | |
0.00% |
0 / 4 |
|||
create | |
0.00% |
0 / 1 |
2 | |
0.00% |
0 / 9 |
|||
transform | |
0.00% |
0 / 1 |
20 | |
0.00% |
0 / 12 |
<?php | |
/** | |
* @file | |
* Contains \Drupal\block\Plugin\migrate\process\BlockTheme. | |
*/ | |
namespace Drupal\block\Plugin\migrate\process; | |
use Drupal\migrate\Entity\MigrationInterface; | |
use Drupal\migrate\MigrateExecutableInterface; | |
use Drupal\migrate\ProcessPluginBase; | |
use Drupal\migrate\Row; | |
use Drupal\Core\Config\Config; | |
use Drupal\Core\Plugin\ContainerFactoryPluginInterface; | |
use Symfony\Component\DependencyInjection\ContainerInterface; | |
/** | |
* @MigrateProcessPlugin( | |
* id = "block_theme" | |
* ) | |
*/ | |
class BlockTheme extends ProcessPluginBase implements ContainerFactoryPluginInterface { | |
/** | |
* Contains the configuration object factory. | |
* | |
* @var \Drupal\Core\Config\ConfigFactoryInterface | |
*/ | |
protected $configFactory; | |
/** | |
* Contains the system.theme configuration object. | |
* | |
* @var \Drupal\Core\Config\Config | |
*/ | |
protected $themeConfig; | |
/** | |
* Constructs a BlockTheme object. | |
* | |
* @param array $configuration | |
* A configuration array containing information about the plugin instance. | |
* @param string $plugin_id | |
* The plugin ID for the plugin instance. | |
* @param mixed $plugin_definition | |
* The plugin implementation definition. | |
* @param \Drupal\migrate\Entity\MigrationInterface $migration | |
* The migration entity. | |
* @param \Drupal\Core\Config\Config $theme_config | |
* The system.theme configuration factory object. | |
* @param array $themes | |
* The list of themes available on the destination. | |
*/ | |
public function __construct(array $configuration, $plugin_id, $plugin_definition, MigrationInterface $migration, Config $theme_config, array $themes) { | |
parent::__construct($configuration, $plugin_id, $plugin_definition, $migration); | |
$this->themeConfig = $theme_config; | |
$this->themes = $themes; | |
} | |
/** | |
* {@inheritdoc} | |
*/ | |
public static function create(ContainerInterface $container, array $configuration, $plugin_id, $plugin_definition, MigrationInterface $migration = NULL) { | |
return new static( | |
$configuration, | |
$plugin_id, | |
$plugin_definition, | |
$migration, | |
$container->get('config.factory')->get('system.theme'), | |
$container->get('theme_handler')->listInfo() | |
); | |
} | |
/** | |
* {@inheritdoc} | |
*/ | |
public function transform($value, MigrateExecutableInterface $migrate_executable, Row $row, $destination_property) { | |
list($theme, $default_theme, $admin_theme) = $value; | |
// If the source theme exists on the destination, we're good. | |
if (isset($this->themes[$theme])) { | |
return $theme; | |
} | |
// If the source block is assigned to a region in the source default theme, | |
// then assign it to the destination default theme. | |
if (strtolower($theme) == strtolower($default_theme)) { | |
return $this->themeConfig->get('default'); | |
} | |
// If the source block is assigned to a region in the source admin theme, | |
// then assign it to the destination admin theme. | |
if (strtolower($theme) == strtolower($admin_theme)) { | |
return $this->themeConfig->get('admin'); | |
} | |
// We couldn't map it to a D8 theme so just return the incoming theme. | |
return $theme; | |
} | |
} |