class ParagraphsProcessOnValue in Paragraphs 8
Runs a migration process on a value if a condition is met.
The process will run if a source value is equal to an expected value. Otherwise returns the original value unchanged.
Configuration Keys:
source_value: (required) string. The source property to check against. expected_value: (required) string. The value to check against. If the source property described by source_value matches this value, the process will be executed. process: (required) array. The process array to execute if the source property matches the expected value.
Plugin annotation
@MigrateProcessPlugin(
id = "paragraphs_process_on_value"
)
Hierarchy
- class \Drupal\Component\Plugin\PluginBase implements DerivativeInspectionInterface, PluginInspectionInterface
- class \Drupal\Core\Plugin\PluginBase uses DependencySerializationTrait, MessengerTrait, StringTranslationTrait
- class \Drupal\migrate\ProcessPluginBase implements MigrateProcessInterface
- class \Drupal\paragraphs\Plugin\migrate\process\ProcessPluginBase implements ConfigurableInterface, ContainerFactoryPluginInterface
- class \Drupal\paragraphs\Plugin\migrate\process\ParagraphsProcessOnValue
- class \Drupal\paragraphs\Plugin\migrate\process\ProcessPluginBase implements ConfigurableInterface, ContainerFactoryPluginInterface
- class \Drupal\migrate\ProcessPluginBase implements MigrateProcessInterface
- class \Drupal\Core\Plugin\PluginBase uses DependencySerializationTrait, MessengerTrait, StringTranslationTrait
Expanded class hierarchy of ParagraphsProcessOnValue
See also
\Drupal\migrate\Plugin\MigrateProcessInterface
1 file declares its use of ParagraphsProcessOnValue
- ParagraphsProcessOnValueTest.php in tests/
src/ Unit/ migrate/ ParagraphsProcessOnValueTest.php
File
- src/
Plugin/ migrate/ process/ ParagraphsProcessOnValue.php, line 29
Namespace
Drupal\paragraphs\Plugin\migrate\processView source
class ParagraphsProcessOnValue extends ProcessPluginBase {
/**
* {@inheritdoc}
*/
public function transform($value, MigrateExecutableInterface $migrate_executable, Row $row, $destination_property) {
if (empty($this->configuration['source_value'])) {
throw new \InvalidArgumentException("Required argument 'source_value' not set for paragraphs_process_on_value plugin");
}
if (!isset($this->configuration['expected_value'])) {
throw new \InvalidArgumentException("Required argument 'expected_value' not set for paragraphs_process_on_value plugin");
}
if (empty($this->configuration['process']) || !is_array($this->configuration['process'])) {
throw new \InvalidArgumentException("Required argument 'process' not set or invalid for paragraphs_process_on_value plugin");
}
$source_value = $row
->getSourceProperty($this->configuration['source_value']);
if (is_null($source_value)) {
// This is probably a migration that shouldn't be touched by Paragraphs.
// For example, throwing an exception here would prevent the migration of
// the comment field configurations.
return $value;
}
if ($source_value === $this->configuration['expected_value']) {
$process = $this->configuration['process'];
// Append the current working value to the new source we are creating.
$source = $row
->getSource();
$source['paragraphs_process_on_value_source_field'] = $value;
// If there is a single process plugin, add the source field. If there
// is an array of process plugins, add the source field to the first one.
if (array_key_exists('plugin', $process)) {
if (empty($process['source'])) {
$process['source'] = 'paragraphs_process_on_value_source_field';
}
}
else {
if (empty($process[0]['source'])) {
$process[0]['source'] = 'paragraphs_process_on_value_source_field';
}
}
$source = $row
->getSource();
$source['paragraphs_process_on_value_source_field'] = $value;
$new_row = new Row($source, []);
$migrate_executable
->processRow($new_row, [
$destination_property => $process,
]);
return $new_row
->getDestinationProperty($destination_property);
}
else {
return $value;
}
}
/**
* {@inheritdoc}
*/
public function defaultConfiguration() {
return [
'source_value' => '',
'expected_value' => '',
'process' => [],
] + parent::defaultConfiguration();
}
}
Members
Name | Modifiers | Type | Description | Overrides |
---|---|---|---|---|
DependencySerializationTrait:: |
protected | property | An array of entity type IDs keyed by the property name of their storages. | |
DependencySerializationTrait:: |
protected | property | An array of service IDs keyed by property name used for serialization. | |
DependencySerializationTrait:: |
public | function | 1 | |
DependencySerializationTrait:: |
public | function | 2 | |
MessengerTrait:: |
protected | property | The messenger. | 29 |
MessengerTrait:: |
public | function | Gets the messenger. | 29 |
MessengerTrait:: |
public | function | Sets the messenger. | |
ParagraphsProcessOnValue:: |
public | function |
Gets default configuration for this plugin. Overrides ProcessPluginBase:: |
|
ParagraphsProcessOnValue:: |
public | function |
Performs the associated process. Overrides ProcessPluginBase:: |
|
PluginBase:: |
protected | property | Configuration information passed into the plugin. | 1 |
PluginBase:: |
protected | property | The plugin implementation definition. | 1 |
PluginBase:: |
protected | property | The plugin_id. | |
PluginBase:: |
constant | A string which is used to separate base plugin IDs from the derivative ID. | ||
PluginBase:: |
public | function |
Gets the base_plugin_id of the plugin instance. Overrides DerivativeInspectionInterface:: |
|
PluginBase:: |
public | function |
Gets the derivative_id of the plugin instance. Overrides DerivativeInspectionInterface:: |
|
PluginBase:: |
public | function |
Gets the definition of the plugin implementation. Overrides PluginInspectionInterface:: |
3 |
PluginBase:: |
public | function |
Gets the plugin_id of the plugin instance. Overrides PluginInspectionInterface:: |
|
PluginBase:: |
public | function | Determines if the plugin is configurable. | |
ProcessPluginBase:: |
protected | property | The entity bundle info service. | |
ProcessPluginBase:: |
public static | function |
Creates an instance of the plugin. Overrides ContainerFactoryPluginInterface:: |
|
ProcessPluginBase:: |
public | function |
Gets this plugin's configuration. Overrides ConfigurableInterface:: |
|
ProcessPluginBase:: |
public | function |
Indicates whether the returned value requires multiple handling. Overrides MigrateProcessInterface:: |
3 |
ProcessPluginBase:: |
public | function |
Sets the configuration for this plugin instance. Overrides ConfigurableInterface:: |
|
ProcessPluginBase:: |
public | function |
Constructs a \Drupal\Component\Plugin\PluginBase object. Overrides PluginBase:: |
|
StringTranslationTrait:: |
protected | property | The string translation service. | 1 |
StringTranslationTrait:: |
protected | function | Formats a string containing a count of items. | |
StringTranslationTrait:: |
protected | function | Returns the number of plurals supported by a given language. | |
StringTranslationTrait:: |
protected | function | Gets the string translation service. | |
StringTranslationTrait:: |
public | function | Sets the string translation service to use. | 2 |
StringTranslationTrait:: |
protected | function | Translates a string to the current language or to a given language. |