class EntityReferenceRevisionsItem in Multiversion 8
Alternative entity reference revisions base field item type class.
Hierarchy
- class \Drupal\Core\TypedData\TypedData implements PluginInspectionInterface, TypedDataInterface uses DependencySerializationTrait, StringTranslationTrait, TypedDataTrait
- class \Drupal\Core\TypedData\Plugin\DataType\Map implements \Drupal\Core\TypedData\Plugin\DataType\IteratorAggregate, ComplexDataInterface
- class \Drupal\Core\Field\FieldItemBase implements FieldItemInterface
- class \Drupal\Core\Field\Plugin\Field\FieldType\EntityReferenceItem implements PreconfiguredFieldUiOptionsInterface, OptionsProviderInterface
- class \Drupal\entity_reference_revisions\Plugin\Field\FieldType\EntityReferenceRevisionsItem implements PreconfiguredFieldUiOptionsInterface, OptionsProviderInterface
- class \Drupal\multiversion\EntityReferenceRevisionsItem uses EntityReferenceFieldTrait
- class \Drupal\entity_reference_revisions\Plugin\Field\FieldType\EntityReferenceRevisionsItem implements PreconfiguredFieldUiOptionsInterface, OptionsProviderInterface
- class \Drupal\Core\Field\Plugin\Field\FieldType\EntityReferenceItem implements PreconfiguredFieldUiOptionsInterface, OptionsProviderInterface
- class \Drupal\Core\Field\FieldItemBase implements FieldItemInterface
- class \Drupal\Core\TypedData\Plugin\DataType\Map implements \Drupal\Core\TypedData\Plugin\DataType\IteratorAggregate, ComplexDataInterface
Expanded class hierarchy of EntityReferenceRevisionsItem
File
- src/
EntityReferenceRevisionsItem.php, line 11
Namespace
Drupal\multiversionView source
class EntityReferenceRevisionsItem extends ContribEntityReferenceRevisionsItem {
use EntityReferenceFieldTrait {
preSave as entityReferencePreSave;
}
/**
* Change the logic around saving auto-created entities.
*
* @see \Drupal\multiversion\EntityReferenceFieldTrait::preSave()
* @see \Drupal\entity_reference_revisions\Plugin\Field\FieldType\EntityReferenceRevisionsItem::preSave()
*/
public function preSave() {
if (!$this
->parentIsEnabledEntityType()) {
// Call source class method if parent entity isn't supported by Multiversion.
parent::preSave();
return;
}
$has_new = $this
->hasNewEntity();
// If it is a new entity, parent will save it.
$this
->entityReferencePreSave();
if (!$has_new) {
// Create a new revision if it is a composite entity in a host with a new
// revision.
$host = $this
->getEntity();
$needs_save = $this->entity instanceof EntityNeedsSaveInterface && $this->entity
->needsSave();
if (!$host
->isNew() && $host
->isNewRevision() && $this->entity && $this->entity
->getEntityType()
->get('entity_revision_parent_id_field')) {
$this->entity
->setNewRevision();
if ($host
->isDefaultRevision()) {
$this->entity
->isDefaultRevision(TRUE);
}
$needs_save = TRUE;
}
if ($needs_save) {
// Delete the paragraph when the host entity is deleted.
if ($host->_deleted->value == TRUE) {
$this->entity
->delete();
}
elseif ($host->_rev->new_edit == FALSE) {
/** @var \Drupal\multiversion\MultiversionManagerInterface $multiversion_manager */
$multiversion_manager = \Drupal::service('multiversion.manager');
$entity_type = $this->entity
->getEntityType();
if ($multiversion_manager
->isEnabledEntityType($entity_type)) {
/** @var \Drupal\Core\Entity\EntityTypeManagerInterface $entity_type_manager */
$entity_type_manager = \Drupal::service('entity_type.manager');
/** @var \Drupal\multiversion\Entity\Storage\ContentEntityStorageInterface $storage */
$storage = $entity_type_manager
->getStorage($this->entity
->getEntityTypeId());
$entities = $storage
->loadByProperties([
'uuid' => $this->entity
->uuid(),
]);
$entity = reset($entities);
if ($entity) {
$parent_id = $this->entity
->getEntityType()
->get('entity_revision_parent_id_field');
$entity
->set($parent_id, $this->entity
->id());
$entity
->setNewRevision(FALSE);
$this->entity = $entity;
}
$storage
->saveWithoutForcingNewRevision($this->entity);
}
}
else {
$this->entity
->save();
}
}
}
if ($this->entity) {
$this->target_revision_id = $this->entity
->getRevisionId();
}
}
/**
* Change the logic around revisions handling.
*
* By default multiversion storage forces new revision on entity save.
* But this should be not done on "postSave" call, as we will finish the save
* process only after this method call.
*
* @see \Drupal\entity_reference_revisions\Plugin\Field\FieldType\EntityReferenceRevisionsItem::postSave()
* @see \Drupal\multiversion\Entity\Storage\ContentEntityStorageTrait::saveWithoutForcingNewRevision()
*/
public function postSave($update) {
$needs_save = FALSE;
// If any of entity, parent type or parent id is missing then return.
if (!$this->entity || !$this->entity
->getEntityType()
->get('entity_revision_parent_type_field') || !$this->entity
->getEntityType()
->get('entity_revision_parent_id_field')) {
return;
}
if (!$this
->parentIsEnabledEntityType()) {
// Call source class method if parent entity isn't supported by Multiversion.
parent::postSave($update);
return;
}
$entity = $this->entity;
$parent_entity = $this
->getEntity();
// If the entity has a parent field name get the key.
if ($entity
->getEntityType()
->get('entity_revision_parent_field_name_field')) {
$parent_field_name = $entity
->getEntityType()
->get('entity_revision_parent_field_name_field');
// If parent field name has changed then set it.
if ($entity
->get($parent_field_name)->value != $this
->getFieldDefinition()
->getName()) {
$entity
->set($parent_field_name, $this
->getFieldDefinition()
->getName());
$needs_save = TRUE;
}
}
$parent_type = $entity
->getEntityType()
->get('entity_revision_parent_type_field');
$parent_id = $entity
->getEntityType()
->get('entity_revision_parent_id_field');
// If the parent type has changed then set it.
if ($entity
->get($parent_type)->value != $parent_entity
->getEntityTypeId()) {
$entity
->set($parent_type, $parent_entity
->getEntityTypeId());
$needs_save = TRUE;
}
// If the parent id has changed then set it.
if ($entity
->get($parent_id)->value != $parent_entity
->id()) {
$entity
->set($parent_id, $parent_entity
->id());
$needs_save = TRUE;
}
if ($needs_save) {
// Check if any of the keys has changed, save it, do not create a new
// revision.
$entity
->setNewRevision(FALSE);
/** @var \Drupal\Core\Entity\EntityTypeManagerInterface $entity_type_manager */
$entity_type_manager = \Drupal::service('entity_type.manager');
/** @var \Drupal\multiversion\MultiversionManagerInterface $multiversion_manager */
$multiversion_manager = \Drupal::service('multiversion.manager');
$entity_type_id = $entity
->getEntityTypeId();
$entity_type = $entity_type_manager
->getDefinition($entity_type_id);
if ($multiversion_manager
->isEnabledEntityType($entity_type)) {
/** @var \Drupal\multiversion\Entity\Storage\ContentEntityStorageInterface $storage */
$storage = $entity_type_manager
->getStorage($entity_type_id);
$storage
->saveWithoutForcingNewRevision($entity);
}
}
}
/**
* Checks whether parent entity is supported by Multiversion or not.
*
* @return bool
* TRUE if parent entity is supported by Multiversion, FALSE otherwise.
*/
protected function parentIsEnabledEntityType() {
$parent_entity = $this
->getEntity();
$parent_entity_type = $parent_entity
->getEntityType();
if (\Drupal::service('multiversion.manager')
->isEnabledEntityType($parent_entity_type)) {
return TRUE;
}
return FALSE;
}
}
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 | |
EntityReferenceFieldTrait:: |
public | function | Aliased as: entityReferencePreSave | |
EntityReferenceItem:: |
public static | function |
Calculates dependencies for field items. Overrides FieldItemBase:: |
|
EntityReferenceItem:: |
public static | function |
Calculates dependencies for field items on the storage level. Overrides FieldItemBase:: |
|
EntityReferenceItem:: |
public static | function |
Defines the field-level settings for this plugin. Overrides FieldItemBase:: |
1 |
EntityReferenceItem:: |
public static | function |
Defines the storage-level settings for this plugin. Overrides FieldItemBase:: |
1 |
EntityReferenceItem:: |
public static | function | Render API callback: Processes the field settings form and allows access to the form state. | |
EntityReferenceItem:: |
public static | function | Adds entity_reference specific properties to AJAX form elements from the field settings form. | |
EntityReferenceItem:: |
public | function |
Returns a form for the field-level settings. Overrides FieldItemBase:: |
1 |
EntityReferenceItem:: |
public static | function | Form element validation handler; Invokes selection plugin's validation. | |
EntityReferenceItem:: |
public static | function | Render API callback: Moves entity_reference specific Form API elements (i.e. 'handler_settings') up a level for easier processing by the validation and submission handlers. | |
EntityReferenceItem:: |
public | function |
Gets a list of validation constraints. Overrides TypedData:: |
|
EntityReferenceItem:: |
public | function |
Returns an array of possible values with labels for display. Overrides OptionsProviderInterface:: |
|
EntityReferenceItem:: |
public | function |
Returns an array of possible values. Overrides OptionsProviderInterface:: |
|
EntityReferenceItem:: |
protected static | function | Gets a bundle for a given entity type and selection options. | |
EntityReferenceItem:: |
public | function |
Returns an array of settable values with labels for display. Overrides OptionsProviderInterface:: |
|
EntityReferenceItem:: |
public | function |
Returns an array of settable values. Overrides OptionsProviderInterface:: |
|
EntityReferenceItem:: |
public | function | Determines whether the item holds an unsaved entity. | |
EntityReferenceItem:: |
public static | function |
Returns the name of the main property, if any. Overrides FieldItemBase:: |
|
EntityReferenceItem:: |
public static | function | Ajax callback for the handler settings form. | |
EntityReferenceItem:: |
public static | function | Submit handler for the non-JS case. | |
EntityReferenceRevisionsItem:: |
public | function |
Defines custom delete behavior for field values. Overrides FieldItemBase:: |
|
EntityReferenceRevisionsItem:: |
public | function |
Defines custom revision delete behavior for field values. Overrides FieldItemBase:: |
|
EntityReferenceRevisionsItem:: |
public static | function |
Generates placeholder field values. Overrides EntityReferenceItem:: |
|
EntityReferenceRevisionsItem:: |
public static | function |
Returns preconfigured field options for a field type. Overrides EntityReferenceItem:: |
|
EntityReferenceRevisionsItem:: |
public | function |
Gets the data value. Overrides EntityReferenceItem:: |
|
EntityReferenceRevisionsItem:: |
public | function |
Determines whether the data structure is empty. Overrides EntityReferenceItem:: |
|
EntityReferenceRevisionsItem:: |
public | function |
React to changes to a child property or item. Overrides EntityReferenceItem:: |
|
EntityReferenceRevisionsItem:: |
public static | function |
Informs the plugin that a dependency of the field will be deleted. Overrides EntityReferenceItem:: |
|
EntityReferenceRevisionsItem:: |
protected | function | Checks whether parent entity is supported by Multiversion or not. | |
EntityReferenceRevisionsItem:: |
public | function |
Change the logic around revisions handling. Overrides EntityReferenceRevisionsItem:: |
|
EntityReferenceRevisionsItem:: |
public | function |
Change the logic around saving auto-created entities. Overrides EntityReferenceRevisionsItem:: |
|
EntityReferenceRevisionsItem:: |
public static | function |
Defines field item properties. Overrides EntityReferenceItem:: |
|
EntityReferenceRevisionsItem:: |
public static | function |
Returns the schema for the field. Overrides EntityReferenceItem:: |
|
EntityReferenceRevisionsItem:: |
public | function |
Sets the data value. Overrides EntityReferenceItem:: |
|
EntityReferenceRevisionsItem:: |
public | function |
Returns a form for the storage-level settings. Overrides EntityReferenceItem:: |
|
FieldItemBase:: |
public static | function |
Returns a settings array in the field type's canonical representation. Overrides FieldItemInterface:: |
1 |
FieldItemBase:: |
public static | function |
Returns a settings array that can be stored as a configuration value. Overrides FieldItemInterface:: |
1 |
FieldItemBase:: |
public | function |
Gets the entity that field belongs to. Overrides FieldItemInterface:: |
|
FieldItemBase:: |
public | function |
Gets the field definition. Overrides FieldItemInterface:: |
|
FieldItemBase:: |
public | function |
Gets the langcode of the field values held in the object. Overrides FieldItemInterface:: |
|
FieldItemBase:: |
protected | function | Returns the value of a field setting. | |
FieldItemBase:: |
protected | function | Returns the array of field settings. | |
FieldItemBase:: |
public static | function |
Returns a settings array in the field type's canonical representation. Overrides FieldItemInterface:: |
2 |
FieldItemBase:: |
public static | function |
Returns a settings array that can be stored as a configuration value. Overrides FieldItemInterface:: |
2 |
FieldItemBase:: |
public | function |
Returns a renderable array for a single field item. Overrides FieldItemInterface:: |
|
FieldItemBase:: |
protected | function |
Different to the parent Map class, we avoid creating property objects as
far as possible in order to optimize performance. Thus we just update
$this->values if no property object has been created yet. Overrides Map:: |
|
FieldItemBase:: |
public | function |
Constructs a TypedData object given its definition and context. Overrides TypedData:: |
1 |
FieldItemBase:: |
public | function |
Magic method: Gets a property value. Overrides FieldItemInterface:: |
2 |
FieldItemBase:: |
public | function |
Magic method: Determines whether a property is set. Overrides FieldItemInterface:: |
|
FieldItemBase:: |
public | function |
Magic method: Sets a property value. Overrides FieldItemInterface:: |
1 |
FieldItemBase:: |
public | function |
Magic method: Unsets a property. Overrides FieldItemInterface:: |
|
Map:: |
protected | property |
The data definition. Overrides TypedData:: |
|
Map:: |
protected | property | The array of properties. | |
Map:: |
protected | property | An array of values for the contained properties. | |
Map:: |
public | function |
Applies the default value. Overrides TypedData:: |
4 |
Map:: |
public | function |
Gets a property object. Overrides ComplexDataInterface:: |
|
Map:: |
public | function | ||
Map:: |
public | function |
Gets an array of property objects. Overrides ComplexDataInterface:: |
|
Map:: |
public | function |
Returns a string representation of the data. Overrides TypedData:: |
|
Map:: |
public | function |
Sets a property value. Overrides ComplexDataInterface:: |
|
Map:: |
public | function |
Returns an array of all property values. Overrides ComplexDataInterface:: |
1 |
Map:: |
public | function | Magic method: Implements a deep clone. | |
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. | |
TypedData:: |
protected | property | The property name. | |
TypedData:: |
protected | property | The parent typed data object. | |
TypedData:: |
public static | function |
Constructs a TypedData object given its definition and context. Overrides TypedDataInterface:: |
|
TypedData:: |
public | function |
Gets the data definition. Overrides TypedDataInterface:: |
|
TypedData:: |
public | function |
Returns the name of a property or item. Overrides TypedDataInterface:: |
|
TypedData:: |
public | function |
Returns the parent data structure; i.e. either complex data or a list. Overrides TypedDataInterface:: |
|
TypedData:: |
public | function |
Gets the definition of the plugin implementation. Overrides PluginInspectionInterface:: |
|
TypedData:: |
public | function |
Gets the plugin_id of the plugin instance. Overrides PluginInspectionInterface:: |
|
TypedData:: |
public | function |
Returns the property path of the data. Overrides TypedDataInterface:: |
|
TypedData:: |
public | function |
Returns the root of the typed data tree. Overrides TypedDataInterface:: |
|
TypedData:: |
public | function |
Sets the context of a property or item via a context aware parent. Overrides TypedDataInterface:: |
|
TypedData:: |
public | function |
Validates the currently set data value. Overrides TypedDataInterface:: |
|
TypedDataTrait:: |
protected | property | The typed data manager used for creating the data types. | |
TypedDataTrait:: |
public | function | Gets the typed data manager. | 2 |
TypedDataTrait:: |
public | function | Sets the typed data manager. | 2 |