interface TypedDataInterface
Same name in other branches
- 9 core/lib/Drupal/Core/TypedData/TypedDataInterface.php \Drupal\Core\TypedData\TypedDataInterface
- 8.9.x core/lib/Drupal/Core/TypedData/TypedDataInterface.php \Drupal\Core\TypedData\TypedDataInterface
- 10 core/lib/Drupal/Core/TypedData/TypedDataInterface.php \Drupal\Core\TypedData\TypedDataInterface
Interface for typed data objects.
Hierarchy
- interface \Drupal\Core\TypedData\TypedDataInterface
Expanded class hierarchy of TypedDataInterface
All classes that implement TypedDataInterface
See also
\Drupal\Core\TypedData\DataDefinitionInterface
Related topics
32 files declare their use of TypedDataInterface
- ComplexDataConstraintValidator.php in core/
lib/ Drupal/ Core/ Validation/ Plugin/ Validation/ Constraint/ ComplexDataConstraintValidator.php - ConfigEntityValidationTestBase.php in core/
tests/ Drupal/ KernelTests/ Core/ Config/ ConfigEntityValidationTestBase.php - ConfigMapperManager.php in core/
modules/ config_translation/ src/ ConfigMapperManager.php - ConfigMapperManagerTest.php in core/
modules/ config_translation/ tests/ src/ Unit/ ConfigMapperManagerTest.php - ConfigTranslationFormBase.php in core/
modules/ config_translation/ src/ Form/ ConfigTranslationFormBase.php
File
-
core/
lib/ Drupal/ Core/ TypedData/ TypedDataInterface.php, line 12
Namespace
Drupal\Core\TypedDataView source
interface TypedDataInterface {
/**
* Constructs a TypedData object given its definition and context.
*
* @param \Drupal\Core\TypedData\DataDefinitionInterface $definition
* The data definition.
* @param string|null $name
* (optional) The name of the created property, or NULL if it is the root
* of a typed data tree. Defaults to NULL.
* @param \Drupal\Core\TypedData\TraversableTypedDataInterface $parent
* (optional) The parent object of the data property, or NULL if it is the
* root of a typed data tree. Defaults to NULL.
*
* @todo When \Drupal\Core\Config\TypedConfigManager has been fixed to use
* class-based definitions, type-hint $definition to
* DataDefinitionInterface. https://www.drupal.org/node/1928868
*
* @see \Drupal\Core\TypedData\TypedDataManager::create()
*/
public static function createInstance($definition, $name = NULL, ?TraversableTypedDataInterface $parent = NULL);
/**
* Gets the data definition.
*
* @return \Drupal\Core\TypedData\DataDefinitionInterface
* The data definition object.
*/
public function getDataDefinition();
/**
* Gets the data value.
*
* @return mixed
* The data value.
*/
public function getValue();
/**
* Sets the data value.
*
* @param mixed|null $value
* The value to set in the format as documented for the data type or NULL to
* unset the data value.
* @param bool $notify
* (optional) Whether to notify the parent object of the change. Defaults to
* TRUE. If a property is updated from a parent object, set it to FALSE to
* avoid being notified again.
*
* @throws \InvalidArgumentException
* If the value input is inappropriate.
* @throws \Drupal\Core\TypedData\Exception\ReadOnlyException
* If the data is read-only.
*/
public function setValue($value, $notify = TRUE);
/**
* Returns a string representation of the data.
*
* @return string
* The string representation of the data.
*/
public function getString();
/**
* Gets a list of validation constraints.
*
* @return array
* Array of constraints, each being an instance of
* \Symfony\Component\Validator\Constraint.
*/
public function getConstraints();
/**
* Validates the currently set data value.
*
* @return \Symfony\Component\Validator\ConstraintViolationListInterface
* A list of constraint violations. If the list is empty, validation
* succeeded.
*/
public function validate();
/**
* Applies the default value.
*
* @param bool $notify
* (optional) Whether to notify the parent object of the change. Defaults to
* TRUE. If a property is updated from a parent object, set it to FALSE to
* avoid being notified again.
*
* @return $this
* Returns itself to allow for chaining.
*/
public function applyDefaultValue($notify = TRUE);
/**
* Returns the name of a property or item.
*
* @return string|int|null
* If the data is a property of some complex data, the name of the property.
* If the data is an item of a list, the name is the numeric position of the
* item in the list, starting with 0. Otherwise, NULL is returned.
*/
public function getName();
/**
* Returns the parent data structure; i.e. either complex data or a list.
*
* @return \Drupal\Core\TypedData\TraversableTypedDataInterface|null
* The parent data structure, either complex data or a list; or NULL if this
* is the root of the typed data tree.
*/
public function getParent();
/**
* Returns the root of the typed data tree.
*
* Returns the root data for a tree of typed data objects; e.g. for an entity
* field item the root of the tree is its parent entity object.
*
* @return \Drupal\Core\TypedData\TraversableTypedDataInterface
* The root data structure, either complex data or a list.
*/
public function getRoot();
/**
* Returns the property path of the data.
*
* The trail of property names relative to the root of the typed data tree,
* separated by dots; e.g. 'field_text.0.format'.
*
* @return string
* The property path relative to the root of the typed tree, or an empty
* string if this is the root.
*/
public function getPropertyPath();
/**
* Sets the context of a property or item via a context aware parent.
*
* This method is supposed to be called by the factory only.
*
* @param string|null $name
* (optional) The name of the property or the delta of the list item,
* or NULL if it is the root of a typed data tree. Defaults to NULL.
* @param \Drupal\Core\TypedData\TraversableTypedDataInterface|null $parent
* (optional) The parent object of the data property, or NULL if it is the
* root of a typed data tree. Defaults to NULL.
*/
public function setContext($name = NULL, ?TraversableTypedDataInterface $parent = NULL);
}
Members
Title Sort descending | Modifiers | Object type | Summary | Overrides |
---|---|---|---|---|
TypedDataInterface::applyDefaultValue | public | function | Applies the default value. | 1 |
TypedDataInterface::createInstance | public static | function | Constructs a TypedData object given its definition and context. | 1 |
TypedDataInterface::getConstraints | public | function | Gets a list of validation constraints. | 1 |
TypedDataInterface::getDataDefinition | public | function | Gets the data definition. | 3 |
TypedDataInterface::getName | public | function | Returns the name of a property or item. | 1 |
TypedDataInterface::getParent | public | function | Returns the parent data structure; i.e. either complex data or a list. | 1 |
TypedDataInterface::getPropertyPath | public | function | Returns the property path of the data. | 1 |
TypedDataInterface::getRoot | public | function | Returns the root of the typed data tree. | 1 |
TypedDataInterface::getString | public | function | Returns a string representation of the data. | 1 |
TypedDataInterface::getValue | public | function | Gets the data value. | 1 |
TypedDataInterface::setContext | public | function | Sets the context of a property or item via a context aware parent. | 1 |
TypedDataInterface::setValue | public | function | Sets the data value. | 1 |
TypedDataInterface::validate | public | function | Validates the currently set data value. | 1 |
Buggy or inaccurate documentation? Please file an issue. Need support? Need help programming? Connect with the Drupal community.