Issue #1818556 by das-peter, plach, fago, Berdir, vijaycs85: Change notice: Convert nodes to the new Entity Field API.
parent
6bcbd0ae86
commit
37afef0004
|
@ -96,6 +96,8 @@ class DatabaseStorageControllerNG extends DatabaseStorageController {
|
|||
*/
|
||||
public function create(array $values) {
|
||||
// We have to determine the bundle first.
|
||||
// @todo Throw an exception if no bundle is passed and we have a bundle key
|
||||
// defined.
|
||||
$bundle = $this->bundleKey ? $values[$this->bundleKey] : FALSE;
|
||||
$entity = new $this->entityClass(array(), $this->entityType, $bundle);
|
||||
|
||||
|
@ -154,7 +156,7 @@ class DatabaseStorageControllerNG extends DatabaseStorageController {
|
|||
// Map the loaded stdclass records into entity objects and according fields.
|
||||
$queried_entities = $this->mapFromStorageRecords($queried_entities, $load_revision);
|
||||
|
||||
// Attach fields.
|
||||
// Activate backward-compatibility mode to attach fields.
|
||||
if ($this->entityInfo['fieldable']) {
|
||||
// Prepare BC compatible entities before passing them to the field API.
|
||||
$bc_entities = array();
|
||||
|
@ -251,7 +253,10 @@ class DatabaseStorageControllerNG extends DatabaseStorageController {
|
|||
foreach ($field_definition as $name => $definition) {
|
||||
// Set translatable properties only.
|
||||
if (isset($data_fields[$name]) && !empty($definition['translatable'])) {
|
||||
$translation->{$name}->value = $values[$name];
|
||||
// @todo Figure out how to determine which property has to be set.
|
||||
// Currently it's guessing, and guessing is evil!
|
||||
$property_definition = $translation->{$name}->getPropertyDefinitions();
|
||||
$translation->{$name}->{key($property_definition)} = $values[$name];
|
||||
}
|
||||
// Avoid initializing configurable fields before loading them.
|
||||
elseif (!empty($definition['configurable'])) {
|
||||
|
@ -270,6 +275,12 @@ class DatabaseStorageControllerNG extends DatabaseStorageController {
|
|||
public function save(EntityInterface $entity) {
|
||||
$transaction = db_transaction();
|
||||
try {
|
||||
// Ensure we are dealing with the actual entity.
|
||||
$entity = $entity->getOriginalEntity();
|
||||
|
||||
// Sync the changes made in the fields array to the internal values array.
|
||||
$entity->updateOriginalValues();
|
||||
|
||||
// Load the stored entity, if any.
|
||||
if (!$entity->isNew() && !isset($entity->original)) {
|
||||
$entity->original = entity_load_unchanged($this->entityType, $entity->id());
|
||||
|
@ -279,7 +290,7 @@ class DatabaseStorageControllerNG extends DatabaseStorageController {
|
|||
$this->invokeHook('presave', $entity);
|
||||
|
||||
// Create the storage record to be saved.
|
||||
$record = $this->maptoStorageRecord($entity);
|
||||
$record = $this->mapToStorageRecord($entity);
|
||||
|
||||
if (!$entity->isNew()) {
|
||||
if ($entity->isDefaultRevision()) {
|
||||
|
@ -446,7 +457,9 @@ class DatabaseStorageControllerNG extends DatabaseStorageController {
|
|||
protected function mapToRevisionStorageRecord(EntityInterface $entity) {
|
||||
$record = new \stdClass();
|
||||
foreach ($this->entityInfo['schema_fields_sql']['revision_table'] as $name) {
|
||||
$record->$name = $entity->$name->value;
|
||||
if (isset($entity->$name->value)) {
|
||||
$record->$name = $entity->$name->value;
|
||||
}
|
||||
}
|
||||
return $record;
|
||||
}
|
||||
|
@ -489,6 +502,11 @@ class DatabaseStorageControllerNG extends DatabaseStorageController {
|
|||
|
||||
$transaction = db_transaction();
|
||||
try {
|
||||
// Ensure we are dealing with the actual entities.
|
||||
foreach ($entities as $id => $entity) {
|
||||
$entities[$id] = $entity->getOriginalEntity();
|
||||
}
|
||||
|
||||
$this->preDelete($entities);
|
||||
foreach ($entities as $id => $entity) {
|
||||
$this->invokeHook('predelete', $entity);
|
||||
|
|
|
@ -45,14 +45,24 @@ class EntityBCDecorator implements IteratorAggregate, EntityInterface {
|
|||
*/
|
||||
protected $decorated;
|
||||
|
||||
/**
|
||||
* Local cache for field definitions.
|
||||
*
|
||||
* @var array
|
||||
*/
|
||||
protected $definitions;
|
||||
|
||||
/**
|
||||
* Constructs a Drupal\Core\Entity\EntityCompatibilityDecorator object.
|
||||
*
|
||||
* @param \Drupal\Core\Entity\EntityInterface $decorated
|
||||
* The decorated entity.
|
||||
* @param array &$definitions
|
||||
* An array of field definitions.
|
||||
*/
|
||||
function __construct(EntityNG $decorated) {
|
||||
function __construct(EntityNG $decorated, array &$definitions) {
|
||||
$this->decorated = $decorated;
|
||||
$this->definitions = &$definitions;
|
||||
}
|
||||
|
||||
/**
|
||||
|
@ -75,6 +85,11 @@ class EntityBCDecorator implements IteratorAggregate, EntityInterface {
|
|||
* Directly accesses the plain field values, as done in Drupal 7.
|
||||
*/
|
||||
public function &__get($name) {
|
||||
// Directly return the original property.
|
||||
if ($name == 'original') {
|
||||
return $this->decorated->values[$name];
|
||||
}
|
||||
|
||||
// We access the protected 'values' and 'fields' properties of the decorated
|
||||
// entity via the magic getter - which returns them by reference for us. We
|
||||
// do so, as providing references to these arrays would make $entity->values
|
||||
|
@ -88,7 +103,10 @@ class EntityBCDecorator implements IteratorAggregate, EntityInterface {
|
|||
// the field objects managed by the entity, thus we need to ensure
|
||||
// $this->decorated->values reflects the latest values first.
|
||||
foreach ($this->decorated->fields[$name] as $langcode => $field) {
|
||||
$this->decorated->values[$name][$langcode] = $field->getValue();
|
||||
// Only set if it's not empty, otherwise there can be ghost values.
|
||||
if (!$field->isEmpty()) {
|
||||
$this->decorated->values[$name][$langcode] = $field->getValue();
|
||||
}
|
||||
}
|
||||
// The returned values might be changed by reference, so we need to remove
|
||||
// the field object to avoid the field object and the value getting out of
|
||||
|
@ -96,21 +114,39 @@ class EntityBCDecorator implements IteratorAggregate, EntityInterface {
|
|||
// receive the possibly updated value.
|
||||
unset($this->decorated->fields[$name]);
|
||||
}
|
||||
// Allow accessing field values in entity default language other than
|
||||
// LANGUAGE_DEFAULT by mapping the values to LANGUAGE_DEFAULT. This is
|
||||
// necessary as EntityNG does key values in default language always with
|
||||
// LANGUAGE_DEFAULT while field API expects them to be keyed by langcode.
|
||||
$langcode = $this->decorated->language()->langcode;
|
||||
if ($langcode != LANGUAGE_DEFAULT && isset($this->decorated->values[$name]) && is_array($this->decorated->values[$name])) {
|
||||
if (isset($this->decorated->values[$name][LANGUAGE_DEFAULT]) && !isset($this->decorated->values[$name][$langcode])) {
|
||||
$this->decorated->values[$name][$langcode] = &$this->decorated->values[$name][LANGUAGE_DEFAULT];
|
||||
// When accessing values for entity properties that have been converted to
|
||||
// an entity field, provide direct access to the plain value. This makes it
|
||||
// possible to use the BC-decorator with properties; e.g., $node->title.
|
||||
if (isset($this->definitions[$name]) && empty($this->definitions[$name]['configurable'])) {
|
||||
if (!isset($this->decorated->values[$name][LANGUAGE_DEFAULT])) {
|
||||
$this->decorated->values[$name][LANGUAGE_DEFAULT][0]['value'] = NULL;
|
||||
}
|
||||
if (is_array($this->decorated->values[$name][LANGUAGE_DEFAULT])) {
|
||||
// This will work with all defined properties that have a single value.
|
||||
// We need to ensure the key doesn't matter. Mostly it's 'value' but
|
||||
// e.g. EntityReferenceItem uses target_id.
|
||||
if (isset($this->decorated->values[$name][LANGUAGE_DEFAULT][0]) && count($this->decorated->values[$name][LANGUAGE_DEFAULT][0]) == 1) {
|
||||
return $this->decorated->values[$name][LANGUAGE_DEFAULT][0][key($this->decorated->values[$name][LANGUAGE_DEFAULT][0])];
|
||||
}
|
||||
}
|
||||
return $this->decorated->values[$name][LANGUAGE_DEFAULT];
|
||||
}
|
||||
|
||||
if (!isset($this->decorated->values[$name])) {
|
||||
$this->decorated->values[$name] = NULL;
|
||||
else {
|
||||
// Allow accessing field values in an entity default language other than
|
||||
// LANGUAGE_DEFAULT by mapping the values to LANGUAGE_DEFAULT. This is
|
||||
// necessary as EntityNG always keys default language values with
|
||||
// LANGUAGE_DEFAULT while field API expects them to be keyed by langcode.
|
||||
$langcode = $this->decorated->language()->langcode;
|
||||
if ($langcode != LANGUAGE_DEFAULT && isset($this->decorated->values[$name]) && is_array($this->decorated->values[$name])) {
|
||||
if (isset($this->decorated->values[$name][LANGUAGE_DEFAULT]) && !isset($this->decorated->values[$name][$langcode])) {
|
||||
$this->decorated->values[$name][$langcode] = &$this->decorated->values[$name][LANGUAGE_DEFAULT];
|
||||
}
|
||||
}
|
||||
if (!isset($this->decorated->values[$name])) {
|
||||
$this->decorated->values[$name] = NULL;
|
||||
}
|
||||
return $this->decorated->values[$name];
|
||||
}
|
||||
return $this->decorated->values[$name];
|
||||
}
|
||||
|
||||
/**
|
||||
|
@ -119,20 +155,29 @@ class EntityBCDecorator implements IteratorAggregate, EntityInterface {
|
|||
* Directly writes to the plain field values, as done by Drupal 7.
|
||||
*/
|
||||
public function __set($name, $value) {
|
||||
if (is_array($value) && $definition = $this->decorated->getPropertyDefinition($name)) {
|
||||
// If field API sets a value with a langcode in entity language, move it
|
||||
// to LANGUAGE_DEFAULT.
|
||||
// This is necessary as EntityNG does key values in default language always
|
||||
// with LANGUAGE_DEFAULT while field API expects them to be keyed by
|
||||
// langcode.
|
||||
foreach ($value as $langcode => $data) {
|
||||
if ($langcode != LANGUAGE_DEFAULT && $langcode == $this->decorated->language()->langcode) {
|
||||
$value[LANGUAGE_DEFAULT] = $data;
|
||||
unset($value[$langcode]);
|
||||
$defined = isset($this->definitions[$name]);
|
||||
// When updating values for entity properties that have been converted to
|
||||
// an entity field, directly write to the plain value. This makes it
|
||||
// possible to use the BC-decorator with properties; e.g., $node->title.
|
||||
if ($defined && empty($this->definitions[$name]['configurable'])) {
|
||||
$this->decorated->values[$name][LANGUAGE_DEFAULT] = $value;
|
||||
}
|
||||
else {
|
||||
if ($defined && is_array($value)) {
|
||||
// If field API sets a value with a langcode in entity language, move it
|
||||
// to LANGUAGE_DEFAULT.
|
||||
// This is necessary as EntityNG always keys default language values
|
||||
// with LANGUAGE_DEFAULT while field API expects them to be keyed by
|
||||
// langcode.
|
||||
foreach ($value as $langcode => $data) {
|
||||
if ($langcode != LANGUAGE_DEFAULT && $langcode == $this->decorated->language()->langcode) {
|
||||
$value[LANGUAGE_DEFAULT] = $data;
|
||||
unset($value[$langcode]);
|
||||
}
|
||||
}
|
||||
}
|
||||
$this->decorated->values[$name] = $value;
|
||||
}
|
||||
$this->decorated->values[$name] = $value;
|
||||
// Remove the field object to avoid the field object and the value getting
|
||||
// out of sync. That way, the next field object instantiated by EntityNG
|
||||
// will hold the updated value.
|
||||
|
@ -151,8 +196,9 @@ class EntityBCDecorator implements IteratorAggregate, EntityInterface {
|
|||
* Implements the magic method for unset().
|
||||
*/
|
||||
public function __unset($name) {
|
||||
// Set the value to NULL.
|
||||
$value = &$this->__get($name);
|
||||
$value = array();
|
||||
$value = NULL;
|
||||
}
|
||||
|
||||
/**
|
||||
|
@ -173,6 +219,10 @@ class EntityBCDecorator implements IteratorAggregate, EntityInterface {
|
|||
* Forwards the call to the decorated entity.
|
||||
*/
|
||||
public function get($property_name) {
|
||||
// Ensure this works with not yet defined fields.
|
||||
if (!isset($this->definitions[$property_name])) {
|
||||
return $this->__get($property_name);
|
||||
}
|
||||
return $this->decorated->get($property_name);
|
||||
}
|
||||
|
||||
|
@ -180,6 +230,10 @@ class EntityBCDecorator implements IteratorAggregate, EntityInterface {
|
|||
* Forwards the call to the decorated entity.
|
||||
*/
|
||||
public function set($property_name, $value) {
|
||||
// Ensure this works with not yet defined fields.
|
||||
if (!isset($this->definitions[$property_name])) {
|
||||
return $this->__set($property_name, $value);
|
||||
}
|
||||
return $this->decorated->set($property_name, $value);
|
||||
}
|
||||
|
||||
|
|
|
@ -81,6 +81,11 @@ class EntityNG extends Entity {
|
|||
$this->entityType = $entity_type;
|
||||
$this->bundle = $bundle ? $bundle : $this->entityType;
|
||||
foreach ($values as $key => $value) {
|
||||
// If the key matches an existing property set the value to the property
|
||||
// to ensure non converted properties have the correct value.
|
||||
if (property_exists($this, $key) && isset($value[LANGUAGE_DEFAULT])) {
|
||||
$this->$key = $value[LANGUAGE_DEFAULT];
|
||||
}
|
||||
$this->values[$key] = $value;
|
||||
}
|
||||
$this->init();
|
||||
|
@ -269,7 +274,7 @@ class EntityNG extends Entity {
|
|||
if ($this->getPropertyDefinition('langcode')) {
|
||||
$language = $this->get('langcode')->language;
|
||||
}
|
||||
if (!isset($language)) {
|
||||
if (empty($language)) {
|
||||
// Make sure we return a proper language object.
|
||||
$language = new Language(array('langcode' => LANGUAGE_NOT_SPECIFIED));
|
||||
}
|
||||
|
@ -367,7 +372,9 @@ class EntityNG extends Entity {
|
|||
*/
|
||||
public function getBCEntity() {
|
||||
if (!isset($this->bcEntity)) {
|
||||
$this->bcEntity = new EntityBCDecorator($this);
|
||||
// Initialize field definitions so that we can pass them by reference.
|
||||
$this->getPropertyDefinitions();
|
||||
$this->bcEntity = new EntityBCDecorator($this, $this->fieldDefinitions);
|
||||
}
|
||||
return $this->bcEntity;
|
||||
}
|
||||
|
@ -483,6 +490,12 @@ class EntityNG extends Entity {
|
|||
$uuid = new Uuid();
|
||||
$duplicate->{$entity_info['entity_keys']['uuid']}->value = $uuid->generate();
|
||||
}
|
||||
|
||||
// Check whether the entity type supports revisions and initialize it if so.
|
||||
if (!empty($entity_info['entity_keys']['revision'])) {
|
||||
$duplicate->{$entity_info['entity_keys']['revision']}->value = NULL;
|
||||
}
|
||||
|
||||
return $duplicate;
|
||||
}
|
||||
|
||||
|
|
|
@ -36,6 +36,15 @@ abstract class FieldItemBase extends ContextAwareTypedData implements IteratorAg
|
|||
*/
|
||||
protected $properties = array();
|
||||
|
||||
/**
|
||||
* Holds any non-property values that get set on the object.
|
||||
*
|
||||
* @todo: Remove or refactor once EntityNG conversion is complete.
|
||||
*
|
||||
* @var array
|
||||
*/
|
||||
protected $extraValues = array();
|
||||
|
||||
/**
|
||||
* Overrides ContextAwareTypedData::__construct().
|
||||
*/
|
||||
|
@ -68,7 +77,7 @@ abstract class FieldItemBase extends ContextAwareTypedData implements IteratorAg
|
|||
foreach ($this->getProperties() as $name => $property) {
|
||||
$values[$name] = $property->getValue();
|
||||
}
|
||||
return $values;
|
||||
return $values + $this->extraValues;
|
||||
}
|
||||
|
||||
/**
|
||||
|
@ -92,9 +101,11 @@ abstract class FieldItemBase extends ContextAwareTypedData implements IteratorAg
|
|||
else {
|
||||
$property->setValue(NULL);
|
||||
}
|
||||
unset($values[$name]);
|
||||
}
|
||||
// @todo: Throw an exception for invalid values once conversion is
|
||||
// totally completed.
|
||||
$this->extraValues = $values;
|
||||
}
|
||||
|
||||
/**
|
||||
|
@ -129,7 +140,13 @@ abstract class FieldItemBase extends ContextAwareTypedData implements IteratorAg
|
|||
* Implements \Drupal\Core\Entity\Field\FieldItemInterface::__get().
|
||||
*/
|
||||
public function __get($name) {
|
||||
return $this->get($name)->getValue();
|
||||
if (isset($this->properties[$name])) {
|
||||
return $this->properties[$name]->getValue();
|
||||
}
|
||||
// The property is unknown, so try to get it from the extra values.
|
||||
elseif (isset($this->extraValues[$name])) {
|
||||
return $this->extraValues[$name];
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
|
@ -140,7 +157,13 @@ abstract class FieldItemBase extends ContextAwareTypedData implements IteratorAg
|
|||
if ($value instanceof TypedDataInterface) {
|
||||
$value = $value->getValue();
|
||||
}
|
||||
$this->get($name)->setValue($value);
|
||||
if (isset($this->properties[$name])) {
|
||||
$this->properties[$name]->setValue($value);
|
||||
}
|
||||
else {
|
||||
// The property is unknown, so set it to the extra values.
|
||||
$this->extraValues[$name] = $value;
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
|
|
|
@ -85,6 +85,21 @@ class EntityReferenceItem extends FieldItemBase {
|
|||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Overrides \Drupal\Core\Entity\Field\FieldItemBase::__set().
|
||||
*/
|
||||
public function __set($name, $value) {
|
||||
parent::__set($name, $value);
|
||||
}
|
||||
|
||||
/**
|
||||
* Overrides \Drupal\Core\Entity\Field\FieldItemBase::__get().
|
||||
*/
|
||||
public function __get($name) {
|
||||
$name = ($name == 'value') ? 'target_id' : $name;
|
||||
return parent::__get($name);
|
||||
}
|
||||
|
||||
/**
|
||||
* Overrides \Drupal\Core\Entity\Field\FieldItemBase::get().
|
||||
*/
|
||||
|
@ -92,4 +107,13 @@ class EntityReferenceItem extends FieldItemBase {
|
|||
$property_name = ($property_name == 'value') ? 'target_id' : $property_name;
|
||||
return parent::get($property_name);
|
||||
}
|
||||
|
||||
/**
|
||||
* Implements \Drupal\Core\Entity\Field\FieldItemInterface::__isset().
|
||||
*/
|
||||
public function __isset($property_name) {
|
||||
$property_name = ($property_name == 'value') ? 'target_id' : $property_name;
|
||||
return parent::__isset($property_name);
|
||||
}
|
||||
|
||||
}
|
||||
|
|
|
@ -53,6 +53,13 @@ class EntityWrapper extends ContextAwareTypedData implements IteratorAggregate,
|
|||
*/
|
||||
protected $id;
|
||||
|
||||
/**
|
||||
* If set, a new entity to create and reference.
|
||||
*
|
||||
* @var \Drupal\Core\Entity\EntityInterface
|
||||
*/
|
||||
protected $newEntity;
|
||||
|
||||
/**
|
||||
* Overrides ContextAwareTypedData::__construct().
|
||||
*/
|
||||
|
@ -65,6 +72,9 @@ class EntityWrapper extends ContextAwareTypedData implements IteratorAggregate,
|
|||
* Overrides \Drupal\Core\TypedData\TypedData::getValue().
|
||||
*/
|
||||
public function getValue() {
|
||||
if (isset($this->newEntity)) {
|
||||
return $this->newEntity;
|
||||
}
|
||||
$source = $this->getIdSource();
|
||||
$id = $source ? $source->getValue() : $this->id;
|
||||
return $id ? entity_load($this->entityType, $id) : NULL;
|
||||
|
@ -85,10 +95,17 @@ class EntityWrapper extends ContextAwareTypedData implements IteratorAggregate,
|
|||
* Both the entity ID and the entity object may be passed as value.
|
||||
*/
|
||||
public function setValue($value) {
|
||||
// Support passing in the entity object.
|
||||
if ($value instanceof EntityInterface) {
|
||||
// Support passing in the entity object. If it's not yet saved we have
|
||||
// to store the whole entity such that it could be saved later on.
|
||||
if ($value instanceof EntityInterface && $value->isNew()) {
|
||||
$this->newEntity = $value;
|
||||
$this->entityType = $value->entityType();
|
||||
$value = FALSE;
|
||||
}
|
||||
elseif ($value instanceof EntityInterface) {
|
||||
$this->entityType = $value->entityType();
|
||||
$value = $value->id();
|
||||
unset($this->newEntity);
|
||||
}
|
||||
elseif (isset($value) && !(is_scalar($value) && !empty($this->definition['constraints']['EntityType']))) {
|
||||
throw new InvalidArgumentException('Value is not a valid entity.');
|
||||
|
|
|
@ -8,6 +8,7 @@
|
|||
namespace Drupal\Core\TypedData\Type;
|
||||
|
||||
use InvalidArgumentException;
|
||||
use Drupal\Core\Language\Language as LanguageObject;
|
||||
use Drupal\Core\TypedData\ContextAwareTypedData;
|
||||
|
||||
/**
|
||||
|
@ -40,7 +41,8 @@ class Language extends ContextAwareTypedData {
|
|||
$source = $this->getLanguageCodeSource();
|
||||
$langcode = $source ? $source->getValue() : $this->langcode;
|
||||
if ($langcode) {
|
||||
return language_load($langcode);
|
||||
$language = language_load($langcode);
|
||||
return $language ?: new LanguageObject(array('langcode' => $this->langcode));
|
||||
}
|
||||
}
|
||||
|
||||
|
|
|
@ -5,7 +5,7 @@
|
|||
* Administration page callbacks for the Book module.
|
||||
*/
|
||||
|
||||
use Drupal\node\Plugin\Core\Entity\Node;
|
||||
use Drupal\Core\Entity\EntityInterface;
|
||||
|
||||
/**
|
||||
* Page callback: Returns an administrative overview of all books.
|
||||
|
@ -45,7 +45,7 @@ function book_admin_overview() {
|
|||
/**
|
||||
* Form constructor for administering a single book's hierarchy.
|
||||
*
|
||||
* @param Drupal\node\Node $node
|
||||
* @param \Drupal\Core\Entity\EntityInterface $node
|
||||
* The node of the top-level page in the book.
|
||||
*
|
||||
* @see book_menu()
|
||||
|
@ -53,7 +53,7 @@ function book_admin_overview() {
|
|||
* @see book_admin_edit_submit()
|
||||
* @ingroup forms
|
||||
*/
|
||||
function book_admin_edit($form, $form_state, Node $node) {
|
||||
function book_admin_edit($form, $form_state, EntityInterface $node) {
|
||||
drupal_set_title($node->label());
|
||||
$form['#node'] = $node;
|
||||
_book_admin_table($node, $form);
|
||||
|
@ -136,14 +136,14 @@ function book_admin_edit_submit($form, &$form_state) {
|
|||
/**
|
||||
* Builds the table portion of the form for the book administration page.
|
||||
*
|
||||
* @param Drupal\node\Node $node
|
||||
* @param \Drupal\Core\Entity\EntityInterface $node
|
||||
* The node of the top-level page in the book.
|
||||
* @param $form
|
||||
* The form that is being modified, passed by reference.
|
||||
*
|
||||
* @see book_admin_edit()
|
||||
*/
|
||||
function _book_admin_table(Node $node, &$form) {
|
||||
function _book_admin_table(EntityInterface $node, &$form) {
|
||||
$form['table'] = array(
|
||||
'#theme' => 'book_admin_table',
|
||||
'#tree' => TRUE,
|
||||
|
|
|
@ -5,7 +5,7 @@
|
|||
* Allows users to create and organize related content in an outline.
|
||||
*/
|
||||
|
||||
use Drupal\node\Plugin\Core\Entity\Node;
|
||||
use Drupal\Core\Entity\EntityInterface;
|
||||
use Drupal\entity\Plugin\Core\Entity\EntityDisplay;
|
||||
use Drupal\Core\Template\Attribute;
|
||||
use Drupal\menu_link\Plugin\Core\Entity\MenuLink;
|
||||
|
@ -89,12 +89,12 @@ function book_permission() {
|
|||
/**
|
||||
* Adds relevant book links to the node's links.
|
||||
*
|
||||
* @param Drupal\node\Node $node
|
||||
* @param \Drupal\Core\Entity\EntityInterface $node
|
||||
* The book page node to add links to.
|
||||
* @param $view_mode
|
||||
* The view mode of the node.
|
||||
*/
|
||||
function book_node_view_link(Node $node, $view_mode) {
|
||||
function book_node_view_link(EntityInterface $node, $view_mode) {
|
||||
$links = array();
|
||||
|
||||
if (isset($node->book['depth'])) {
|
||||
|
@ -199,10 +199,10 @@ function book_menu() {
|
|||
/**
|
||||
* Access callback: Determines if the book export page is accessible.
|
||||
*
|
||||
* @param \Drupal\node\Plugin\Core\Entity\Node $node
|
||||
* @param \Drupal\node\Plugin\Core\Entity\EntityInterface $node
|
||||
* The node whose export page is to be viewed.
|
||||
*/
|
||||
function book_export_access(Node $node) {
|
||||
function book_export_access(EntityInterface $node) {
|
||||
return user_access('access printer-friendly version') && node_access('view', $node);
|
||||
}
|
||||
|
||||
|
@ -213,24 +213,24 @@ function book_export_access(Node $node) {
|
|||
* - admin/content/book/%node
|
||||
* - node/%node/outline
|
||||
*
|
||||
* @param Drupal\node\Node $node
|
||||
* @param \Drupal\Core\Entity\EntityInterface $node
|
||||
* The node whose outline tab is to be viewed.
|
||||
*
|
||||
* @see book_menu()
|
||||
*/
|
||||
function _book_outline_access(Node $node) {
|
||||
function _book_outline_access(EntityInterface $node) {
|
||||
return user_access('administer book outlines') && node_access('view', $node);
|
||||
}
|
||||
|
||||
/**
|
||||
* Access callback: Determines if the user can remove nodes from the outline.
|
||||
*
|
||||
* @param Drupal\node\Node $node
|
||||
* @param \Drupal\Core\Entity\EntityInterface $node
|
||||
* The node to remove from the outline.
|
||||
*
|
||||
* @see book_menu()
|
||||
*/
|
||||
function _book_outline_remove_access(Node $node) {
|
||||
function _book_outline_remove_access(EntityInterface $node) {
|
||||
return _book_node_is_removable($node) && _book_outline_access($node);
|
||||
}
|
||||
|
||||
|
@ -240,10 +240,10 @@ function _book_outline_remove_access(Node $node) {
|
|||
* A node can be removed from a book if it is actually in a book and it either
|
||||
* is not a top-level page or is a top-level page with no children.
|
||||
*
|
||||
* @param Drupal\node\Node $node
|
||||
* @param \Drupal\Core\Entity\EntityInterface $node
|
||||
* The node to remove from the outline.
|
||||
*/
|
||||
function _book_node_is_removable($node) {
|
||||
function _book_node_is_removable(EntityInterface $node) {
|
||||
return (!empty($node->book['bid']) && (($node->book['bid'] != $node->nid) || !$node->book['has_children']));
|
||||
}
|
||||
|
||||
|
@ -420,10 +420,10 @@ function _book_parent_select($book_link) {
|
|||
/**
|
||||
* Builds the common elements of the book form for the node and outline forms.
|
||||
*
|
||||
* @param Drupal\node\Node $node
|
||||
* @param \Drupal\Core\Entity\EntityInterface $node
|
||||
* The node whose form is being viewed.
|
||||
*/
|
||||
function _book_add_form_elements(&$form, &$form_state, Node $node) {
|
||||
function _book_add_form_elements(&$form, &$form_state, EntityInterface $node) {
|
||||
// If the form is being processed during the Ajax callback of our book bid
|
||||
// dropdown, then $form_state will hold the value that was selected.
|
||||
if (isset($form_state['values']['book'])) {
|
||||
|
@ -523,13 +523,13 @@ function book_form_update($form, $form_state) {
|
|||
* outline through node addition, node editing, node deletion, or the outline
|
||||
* tab.
|
||||
*
|
||||
* @param Drupal\node\Node $node
|
||||
* @param \Drupal\Core\Entity\EntityInterface $node
|
||||
* The node that is being saved, added, deleted, or moved.
|
||||
*
|
||||
* @return
|
||||
* TRUE if the menu link was saved; FALSE otherwise.
|
||||
*/
|
||||
function _book_update_outline(Node $node) {
|
||||
function _book_update_outline(EntityInterface $node) {
|
||||
if (empty($node->book['bid'])) {
|
||||
return FALSE;
|
||||
}
|
||||
|
@ -788,7 +788,7 @@ function book_node_load($nodes, $types) {
|
|||
/**
|
||||
* Implements hook_node_view().
|
||||
*/
|
||||
function book_node_view(Node $node, EntityDisplay $display, $view_mode) {
|
||||
function book_node_view(EntityInterface $node, EntityDisplay $display, $view_mode) {
|
||||
if ($view_mode == 'full') {
|
||||
if (!empty($node->book['bid']) && empty($node->in_preview)) {
|
||||
$node->content['book_navigation'] = array(
|
||||
|
@ -820,7 +820,7 @@ function book_page_alter(&$page) {
|
|||
/**
|
||||
* Implements hook_node_presave().
|
||||
*/
|
||||
function book_node_presave(Node $node) {
|
||||
function book_node_presave(EntityInterface $node) {
|
||||
// Always save a revision for non-administrators.
|
||||
if (!empty($node->book['bid']) && !user_access('administer nodes')) {
|
||||
$node->setNewRevision();
|
||||
|
@ -834,7 +834,7 @@ function book_node_presave(Node $node) {
|
|||
/**
|
||||
* Implements hook_node_insert().
|
||||
*/
|
||||
function book_node_insert(Node $node) {
|
||||
function book_node_insert(EntityInterface $node) {
|
||||
if (!empty($node->book['bid'])) {
|
||||
if ($node->book['bid'] == 'new') {
|
||||
// New nodes that are their own book.
|
||||
|
@ -849,7 +849,7 @@ function book_node_insert(Node $node) {
|
|||
/**
|
||||
* Implements hook_node_update().
|
||||
*/
|
||||
function book_node_update(Node $node) {
|
||||
function book_node_update(EntityInterface $node) {
|
||||
if (!empty($node->book['bid'])) {
|
||||
if ($node->book['bid'] == 'new') {
|
||||
// New nodes that are their own book.
|
||||
|
@ -864,7 +864,7 @@ function book_node_update(Node $node) {
|
|||
/**
|
||||
* Implements hook_node_predelete().
|
||||
*/
|
||||
function book_node_predelete(Node $node) {
|
||||
function book_node_predelete(EntityInterface $node) {
|
||||
if (!empty($node->book['bid'])) {
|
||||
if ($node->nid == $node->book['bid']) {
|
||||
// Handle deletion of a top-level post.
|
||||
|
@ -888,7 +888,7 @@ function book_node_predelete(Node $node) {
|
|||
/**
|
||||
* Implements hook_node_prepare().
|
||||
*/
|
||||
function book_node_prepare(Node $node) {
|
||||
function book_node_prepare(EntityInterface $node) {
|
||||
// Prepare defaults for the add/edit form.
|
||||
if (empty($node->book) && (user_access('add content to books') || user_access('administer book outlines'))) {
|
||||
$node->book = array();
|
||||
|
@ -1184,7 +1184,7 @@ function book_export_traverse($tree, $visit_func) {
|
|||
/**
|
||||
* Generates printer-friendly HTML for a node.
|
||||
*
|
||||
* @param Drupal\node\Node $node
|
||||
* @param \Drupal\Core\Entity\EntityInterface $node
|
||||
* The node that will be output.
|
||||
* @param $children
|
||||
* (optional) All the rendered child nodes within the current node. Defaults
|
||||
|
@ -1195,7 +1195,7 @@ function book_export_traverse($tree, $visit_func) {
|
|||
*
|
||||
* @see book_export_traverse()
|
||||
*/
|
||||
function book_node_export(Node $node, $children = '') {
|
||||
function book_node_export(EntityInterface $node, $children = '') {
|
||||
$build = node_view($node, 'print');
|
||||
unset($build['#theme']);
|
||||
// @todo Rendering should happen in the template using render().
|
||||
|
|
|
@ -5,7 +5,7 @@
|
|||
* User page callbacks for the book module.
|
||||
*/
|
||||
|
||||
use Drupal\node\Plugin\Core\Entity\Node;
|
||||
use Drupal\Core\Entity\EntityInterface;
|
||||
use Symfony\Component\HttpKernel\Exception\AccessDeniedHttpException;
|
||||
use Symfony\Component\HttpKernel\Exception\NotFoundHttpException;
|
||||
|
||||
|
@ -39,7 +39,7 @@ function book_render() {
|
|||
* currently supported in book module:
|
||||
* - html: Printer-friendly HTML.
|
||||
* Other types may be supported in contributed modules.
|
||||
* @param \Drupal\node\Plugin\Core\Entity\Node $node
|
||||
* @param \Drupal\node\Plugin\Core\Entity\EntityInterface $node
|
||||
* The node to export.
|
||||
*
|
||||
* @return
|
||||
|
@ -50,7 +50,7 @@ function book_render() {
|
|||
*
|
||||
* @see book_menu()
|
||||
*/
|
||||
function book_export($type, Node $node) {
|
||||
function book_export($type, EntityInterface $node) {
|
||||
$type = drupal_strtolower($type);
|
||||
|
||||
$export_function = 'book_export_' . $type;
|
||||
|
@ -84,7 +84,7 @@ function book_export($type, Node $node) {
|
|||
* @throws \Symfony\Component\HttpKernel\Exception\AccessDeniedHttpException
|
||||
* @throws \Symfony\Component\HttpKernel\Exception\NotFoundHttpException
|
||||
*/
|
||||
function book_export_html(Node $node) {
|
||||
function book_export_html(EntityInterface $node) {
|
||||
if (user_access('access printer-friendly version')) {
|
||||
if (isset($node->book)) {
|
||||
$tree = book_menu_subtree_data($node->book);
|
||||
|
@ -103,7 +103,7 @@ function book_export_html(Node $node) {
|
|||
/**
|
||||
* Page callback: Shows the outline form for a single node.
|
||||
*
|
||||
* @param Drupal\node\Node $node
|
||||
* @param \Drupal\Core\Entity\EntityInterface $node
|
||||
* The book node for which to show the outline.
|
||||
*
|
||||
* @return string
|
||||
|
@ -111,7 +111,7 @@ function book_export_html(Node $node) {
|
|||
*
|
||||
* @see book_menu()
|
||||
*/
|
||||
function book_outline(Node $node) {
|
||||
function book_outline(EntityInterface $node) {
|
||||
drupal_set_title($node->label());
|
||||
return drupal_get_form('book_outline_form', $node);
|
||||
}
|
||||
|
@ -121,14 +121,14 @@ function book_outline(Node $node) {
|
|||
*
|
||||
* Allows handling of all book outline operations via the outline tab.
|
||||
*
|
||||
* @param Drupal\node\Node $node
|
||||
* @param \Drupal\Core\Entity\EntityInterface $node
|
||||
* The book node for which to show the outline.
|
||||
*
|
||||
* @see book_outline_form_submit()
|
||||
* @see book_remove_button_submit()
|
||||
* @ingroup forms
|
||||
*/
|
||||
function book_outline_form($form, &$form_state, Node $node) {
|
||||
function book_outline_form($form, &$form_state, EntityInterface $node) {
|
||||
if (!isset($node->book)) {
|
||||
// The node is not part of any book yet - set default options.
|
||||
$node->book = _book_link_defaults($node->nid);
|
||||
|
@ -208,14 +208,14 @@ function book_outline_form_submit($form, &$form_state) {
|
|||
/**
|
||||
* Form constructor to confirm removal of a node from a book.
|
||||
*
|
||||
* @param Drupal\node\Node $node
|
||||
* @param \Drupal\Core\Entity\EntityInterface $node
|
||||
* The node to delete.
|
||||
*
|
||||
* @see book_remove_form_submit()
|
||||
* @see book_menu()
|
||||
* @ingroup forms
|
||||
*/
|
||||
function book_remove_form($form, &$form_state, Node $node) {
|
||||
function book_remove_form($form, &$form_state, EntityInterface $node) {
|
||||
$form['#node'] = $node;
|
||||
$title = array('%title' => $node->label());
|
||||
|
||||
|
|
|
@ -7,7 +7,7 @@
|
|||
|
||||
namespace Drupal\book\Tests;
|
||||
|
||||
use Drupal\node\Plugin\Core\Entity\Node;
|
||||
use Drupal\Core\Entity\EntityInterface;
|
||||
use Drupal\simpletest\WebTestBase;
|
||||
|
||||
/**
|
||||
|
@ -145,7 +145,7 @@ class BookTest extends WebTestBase {
|
|||
*
|
||||
* Also checks the printer friendly version of the outline.
|
||||
*
|
||||
* @param Drupal\node\Node $node
|
||||
* @param \Drupal\Core\Entity\EntityInterface $node
|
||||
* Node to check.
|
||||
* @param $nodes
|
||||
* Nodes that should be in outline.
|
||||
|
@ -158,7 +158,7 @@ class BookTest extends WebTestBase {
|
|||
* @param array $breadcrumb
|
||||
* The nodes that should be displayed in the breadcrumb.
|
||||
*/
|
||||
function checkBookNode(Node $node, $nodes, $previous = FALSE, $up = FALSE, $next = FALSE, array $breadcrumb) {
|
||||
function checkBookNode(EntityInterface $node, $nodes, $previous = FALSE, $up = FALSE, $next = FALSE, array $breadcrumb) {
|
||||
// $number does not use drupal_static as it should not be reset
|
||||
// since it uniquely identifies each call to checkBookNode().
|
||||
static $number = 0;
|
||||
|
|
|
@ -9,7 +9,6 @@
|
|||
* book page, etc.
|
||||
*/
|
||||
|
||||
use Drupal\node\Plugin\Core\Entity\Node;
|
||||
use Drupal\entity\Plugin\Core\Entity\EntityDisplay;
|
||||
use Drupal\file\Plugin\Core\Entity\File;
|
||||
use Drupal\Core\Entity\EntityInterface;
|
||||
|
@ -491,13 +490,13 @@ function comment_get_recent($number = 10) {
|
|||
* Number of comments.
|
||||
* @param $new_replies
|
||||
* Number of new replies.
|
||||
* @param Drupal\node\Node $node
|
||||
* @param \Drupal\Core\Entity\EntityInterface $node
|
||||
* The first new comment node.
|
||||
*
|
||||
* @return
|
||||
* "page=X" if the page number is greater than zero; empty string otherwise.
|
||||
*/
|
||||
function comment_new_page_count($num_comments, $new_replies, Node $node) {
|
||||
function comment_new_page_count($num_comments, $new_replies, EntityInterface $node) {
|
||||
$mode = variable_get('comment_default_mode_' . $node->type, COMMENT_MODE_THREADED);
|
||||
$comments_per_page = variable_get('comment_default_per_page_' . $node->type, 50);
|
||||
$pagenum = NULL;
|
||||
|
@ -575,7 +574,7 @@ function theme_comment_block($variables) {
|
|||
/**
|
||||
* Implements hook_node_view().
|
||||
*/
|
||||
function comment_node_view(Node $node, EntityDisplay $display, $view_mode) {
|
||||
function comment_node_view(EntityInterface $node, EntityDisplay $display, $view_mode) {
|
||||
$links = array();
|
||||
|
||||
if ($node->comment != COMMENT_NODE_HIDDEN) {
|
||||
|
@ -683,14 +682,14 @@ function comment_node_view(Node $node, EntityDisplay $display, $view_mode) {
|
|||
/**
|
||||
* Builds the comment-related elements for node detail pages.
|
||||
*
|
||||
* @param Drupal\node\Node $node
|
||||
* @param \Drupal\Core\Entity\EntityInterface $node
|
||||
* The node entity for which to build the comment-related elements.
|
||||
*
|
||||
* @return
|
||||
* A renderable array representing the comment-related page elements for the
|
||||
* node.
|
||||
*/
|
||||
function comment_node_page_additions(Node $node) {
|
||||
function comment_node_page_additions(EntityInterface $node) {
|
||||
$additions = array();
|
||||
|
||||
// Only attempt to render comments if the node has visible comments.
|
||||
|
@ -728,7 +727,7 @@ function comment_node_page_additions(Node $node) {
|
|||
/**
|
||||
* Returns a rendered form to comment the given node.
|
||||
*
|
||||
* @param Drupal\node\Node $node
|
||||
* @param \Drupal\Core\Entity\EntityInterface $node
|
||||
* The node entity to be commented.
|
||||
* @param int $pid
|
||||
* (optional) Some comments are replies to other comments. In those cases,
|
||||
|
@ -737,7 +736,7 @@ function comment_node_page_additions(Node $node) {
|
|||
* @return array
|
||||
* The renderable array for the comment addition form.
|
||||
*/
|
||||
function comment_add(Node $node, $pid = NULL) {
|
||||
function comment_add(EntityInterface $node, $pid = NULL) {
|
||||
$values = array('nid' => $node->nid, 'pid' => $pid, 'node_type' => 'comment_node_' . $node->type);
|
||||
$comment = entity_create('comment', $values);
|
||||
return entity_get_form($comment);
|
||||
|
@ -746,7 +745,7 @@ function comment_add(Node $node, $pid = NULL) {
|
|||
/**
|
||||
* Retrieves comments for a thread.
|
||||
*
|
||||
* @param Drupal\node\Node $node
|
||||
* @param \Drupal\Core\Entity\EntityInterface $node
|
||||
* The node whose comment(s) needs rendering.
|
||||
* @param $mode
|
||||
* The comment display mode; COMMENT_MODE_FLAT or COMMENT_MODE_THREADED.
|
||||
|
@ -810,7 +809,7 @@ function comment_add(Node $node, $pid = NULL) {
|
|||
* spoil the reverse ordering, "ORDER BY thread ASC" -- here, we do not need
|
||||
* to consider the trailing "/" so we use a substring only.
|
||||
*/
|
||||
function comment_get_thread(Node $node, $mode, $comments_per_page) {
|
||||
function comment_get_thread(EntityInterface $node, $mode, $comments_per_page) {
|
||||
$query = db_select('comment', 'c')
|
||||
->extend('Drupal\Core\Database\Query\PagerSelectExtender');
|
||||
$query->addField('c', 'cid');
|
||||
|
@ -920,13 +919,13 @@ function comment_view(Comment $comment, $view_mode = 'full', $langcode = NULL) {
|
|||
*
|
||||
* @param Drupal\comment\Comment $comment
|
||||
* The comment object.
|
||||
* @param Drupal\node\Node $node
|
||||
* @param \Drupal\Core\Entity\EntityInterface $node
|
||||
* The node the comment is attached to.
|
||||
*
|
||||
* @return
|
||||
* A structured array of links.
|
||||
*/
|
||||
function comment_links(Comment $comment, Node $node) {
|
||||
function comment_links(Comment $comment, EntityInterface $node) {
|
||||
$links = array();
|
||||
if ($node->comment == COMMENT_NODE_OPEN) {
|
||||
if (user_access('administer comments') && user_access('post comments')) {
|
||||
|
@ -1200,7 +1199,7 @@ function comment_node_load($nodes, $types) {
|
|||
/**
|
||||
* Implements hook_node_prepare().
|
||||
*/
|
||||
function comment_node_prepare(Node $node) {
|
||||
function comment_node_prepare(EntityInterface $node) {
|
||||
if (!isset($node->comment)) {
|
||||
$node->comment = variable_get("comment_$node->type", COMMENT_NODE_OPEN);
|
||||
}
|
||||
|
@ -1209,7 +1208,7 @@ function comment_node_prepare(Node $node) {
|
|||
/**
|
||||
* Implements hook_node_insert().
|
||||
*/
|
||||
function comment_node_insert(Node $node) {
|
||||
function comment_node_insert(EntityInterface $node) {
|
||||
// Allow bulk updates and inserts to temporarily disable the
|
||||
// maintenance of the {node_comment_statistics} table.
|
||||
if (variable_get('comment_maintain_node_statistics', TRUE)) {
|
||||
|
@ -1229,7 +1228,7 @@ function comment_node_insert(Node $node) {
|
|||
/**
|
||||
* Implements hook_node_predelete().
|
||||
*/
|
||||
function comment_node_predelete(Node $node) {
|
||||
function comment_node_predelete(EntityInterface $node) {
|
||||
$cids = db_query('SELECT cid FROM {comment} WHERE nid = :nid', array(':nid' => $node->nid))->fetchCol();
|
||||
comment_delete_multiple($cids);
|
||||
db_delete('node_comment_statistics')
|
||||
|
@ -1240,7 +1239,7 @@ function comment_node_predelete(Node $node) {
|
|||
/**
|
||||
* Implements hook_node_update_index().
|
||||
*/
|
||||
function comment_node_update_index(Node $node, $langcode) {
|
||||
function comment_node_update_index(EntityInterface $node, $langcode) {
|
||||
$index_comments = &drupal_static(__FUNCTION__);
|
||||
|
||||
if ($index_comments === NULL) {
|
||||
|
@ -1289,7 +1288,7 @@ function comment_update_index() {
|
|||
* Formats a comment count string and returns it, for display with search
|
||||
* results.
|
||||
*/
|
||||
function comment_node_search_result(Node $node) {
|
||||
function comment_node_search_result(EntityInterface $node) {
|
||||
// Do not make a string if comments are hidden.
|
||||
if (user_access('access comments') && $node->comment != COMMENT_NODE_HIDDEN) {
|
||||
$comments = db_query('SELECT comment_count FROM {node_comment_statistics} WHERE nid = :nid', array('nid' => $node->nid))->fetchField();
|
||||
|
|
|
@ -5,7 +5,7 @@
|
|||
* User page callbacks for the Comment module.
|
||||
*/
|
||||
|
||||
use Drupal\node\Plugin\Core\Entity\Node;
|
||||
use Drupal\Core\Entity\EntityInterface;
|
||||
use Symfony\Component\HttpKernel\Exception\AccessDeniedHttpException;
|
||||
use Symfony\Component\HttpKernel\Exception\NotFoundHttpException;
|
||||
|
||||
|
@ -21,7 +21,7 @@ use Symfony\Component\HttpKernel\Exception\NotFoundHttpException;
|
|||
* The node or comment that is being replied to must appear above the comment
|
||||
* form to provide the user context while authoring the comment.
|
||||
*
|
||||
* @param Drupal\node\Node $node
|
||||
* @param \Drupal\Core\Entity\EntityInterface $node
|
||||
* Every comment belongs to a node. This is that node.
|
||||
* @param $pid
|
||||
* (optional) Some comments are replies to other comments. In those cases,
|
||||
|
@ -34,7 +34,7 @@ use Symfony\Component\HttpKernel\Exception\NotFoundHttpException;
|
|||
* - comment_parent: If the comment is a reply to another comment.
|
||||
* - comment_form: The comment form as a renderable array.
|
||||
*/
|
||||
function comment_reply(Node $node, $pid = NULL) {
|
||||
function comment_reply(EntityInterface $node, $pid = NULL) {
|
||||
// Set the breadcrumb trail.
|
||||
drupal_set_breadcrumb(array(l(t('Home'), NULL), l($node->label(), 'node/' . $node->nid)));
|
||||
$op = isset($_POST['op']) ? $_POST['op'] : '';
|
||||
|
|
|
@ -56,7 +56,7 @@ class CommentStorageController extends DatabaseStorageControllerNG {
|
|||
*/
|
||||
public function create(array $values) {
|
||||
if (empty($values['node_type']) && !empty($values['nid'])) {
|
||||
$node = node_load($values['nid']);
|
||||
$node = node_load(is_object($values['nid']) ? $values['nid']->value : $values['nid']);
|
||||
$values['node_type'] = 'comment_node_' . $node->type;
|
||||
}
|
||||
return parent::create($values);
|
||||
|
|
|
@ -80,7 +80,7 @@ abstract class CommentTestBase extends WebTestBase {
|
|||
/**
|
||||
* Posts a comment.
|
||||
*
|
||||
* @param Drupal\node\Node|null $node
|
||||
* @param \Drupal\Core\Entity\EntityInterface $node|null $node
|
||||
* Node to post comment on or NULL to post to the previusly loaded page.
|
||||
* @param $comment
|
||||
* Comment body.
|
||||
|
|
|
@ -134,9 +134,9 @@ class EditorLoadingTest extends WebTestBase {
|
|||
// to let the untrusted user edit it.
|
||||
$this->drupalCreateNode(array(
|
||||
'type' => 'article',
|
||||
'body' => array(LANGUAGE_NOT_SPECIFIED => array(
|
||||
0 => array('value' => $this->randomName(32), 'format' => 'full_html')
|
||||
)),
|
||||
'body' => array(
|
||||
array('value' => $this->randomName(32), 'format' => 'full_html')
|
||||
),
|
||||
));
|
||||
|
||||
// The untrusted user tries to edit content that is written in a text format
|
||||
|
|
|
@ -35,24 +35,32 @@ function entity_reference_field_info() {
|
|||
}
|
||||
|
||||
/**
|
||||
* Implements hook_entity_field_info().
|
||||
* Implements hook_entity_field_info_alter().
|
||||
*
|
||||
* Set the "target_type" property definition for entity reference fields.
|
||||
*
|
||||
* @see \Drupal\Core\Entity\Field\Type\EntityReferenceItem::getPropertyDefinitions()
|
||||
*
|
||||
* @param array $info
|
||||
* The property info array as returned by hook_entity_field_info().
|
||||
* @param string $entity_type
|
||||
* The entity type for which entity properties are defined.
|
||||
*/
|
||||
function entity_reference_entity_field_info($entity_type) {
|
||||
$property_info = array();
|
||||
function entity_reference_entity_field_info_alter(&$info, $entity_type) {
|
||||
foreach (field_info_instances($entity_type) as $bundle_name => $instances) {
|
||||
foreach ($instances as $field_name => $instance) {
|
||||
$field = field_info_field($field_name);
|
||||
if ($field['type'] != 'entity_reference') {
|
||||
continue;
|
||||
}
|
||||
$property_info['definitions'][$field_name]['settings']['target_type'] = $field['settings']['target_type'];
|
||||
if (isset($info['definitions'][$field_name])) {
|
||||
$info['definitions'][$field_name]['settings']['target_type'] = $field['settings']['target_type'];
|
||||
}
|
||||
elseif (isset($info['optional'][$field_name])) {
|
||||
$info['optional'][$field_name]['settings']['target_type'] = $field['settings']['target_type'];
|
||||
}
|
||||
}
|
||||
}
|
||||
return $property_info;
|
||||
}
|
||||
|
||||
/**
|
||||
|
|
|
@ -88,10 +88,8 @@ class EntityReferenceSelectionSortTest extends WebTestBase {
|
|||
'title' => 'Node published1 (<&>)',
|
||||
'uid' => 1,
|
||||
'field_text' => array(
|
||||
LANGUAGE_NOT_SPECIFIED => array(
|
||||
array(
|
||||
'value' => 1,
|
||||
),
|
||||
array(
|
||||
'value' => 1,
|
||||
),
|
||||
),
|
||||
),
|
||||
|
@ -101,10 +99,8 @@ class EntityReferenceSelectionSortTest extends WebTestBase {
|
|||
'title' => 'Node published2 (<&>)',
|
||||
'uid' => 1,
|
||||
'field_text' => array(
|
||||
LANGUAGE_NOT_SPECIFIED => array(
|
||||
array(
|
||||
'value' => 2,
|
||||
),
|
||||
array(
|
||||
'value' => 2,
|
||||
),
|
||||
),
|
||||
),
|
||||
|
|
|
@ -1086,7 +1086,7 @@ function hook_field_attach_view_alter(&$output, $context) {
|
|||
$element = &$output[$field_name];
|
||||
if ($element['#field_type'] == 'entity_reference' && $element['#formatter'] == 'entity_reference_label') {
|
||||
foreach ($element['#items'] as $delta => $item) {
|
||||
$term = $item['taxonomy_term'];
|
||||
$term = $item['entity'];
|
||||
if (!empty($term->rdf_mapping['rdftype'])) {
|
||||
$element[$delta]['#options']['attributes']['typeof'] = $term->rdf_mapping['rdftype'];
|
||||
}
|
||||
|
|
|
@ -944,7 +944,10 @@ function field_view_field(EntityInterface $entity, $field_name, $display_options
|
|||
|
||||
if ($formatter) {
|
||||
$display_langcode = field_language($entity, $field_name, $langcode);
|
||||
$items = $entity->{$field_name}[$display_langcode];
|
||||
$items = array();
|
||||
if (isset($entity->{$field_name}[$display_langcode])) {
|
||||
$items = $entity->{$field_name}[$display_langcode];
|
||||
}
|
||||
|
||||
// Invoke prepare_view steps if needed.
|
||||
if (empty($entity->_field_view_prepared)) {
|
||||
|
@ -956,7 +959,10 @@ function field_view_field(EntityInterface $entity, $field_name, $display_options
|
|||
_field_invoke_multiple('prepare_view', $entity->entityType(), array($id => $entity), $null, $null, $options);
|
||||
|
||||
// Then let the formatter do its own specific massaging.
|
||||
$items_multi = array($id => $entity->{$field_name}[$display_langcode]);
|
||||
$items_multi = array($id => array());
|
||||
if (isset($entity->{$field_name}[$display_langcode])) {
|
||||
$items_multi[$id] = $entity->{$field_name}[$display_langcode];
|
||||
}
|
||||
$formatter->prepareView(array($id => $entity), $display_langcode, $items_multi);
|
||||
$items = $items_multi[$id];
|
||||
}
|
||||
|
|
|
@ -64,7 +64,7 @@ class FieldAccessTest extends FieldTestBase {
|
|||
$settings = array();
|
||||
$settings['type'] = $this->content_type;
|
||||
$settings['title'] = 'Field view access test';
|
||||
$settings['test_view_field'] = array(LANGUAGE_NOT_SPECIFIED => array(array('value' => $this->test_view_field_value)));
|
||||
$settings['test_view_field'] = array(array('value' => $this->test_view_field_value));
|
||||
$this->node = $this->drupalCreateNode($settings);
|
||||
}
|
||||
|
||||
|
|
|
@ -28,8 +28,6 @@ class ApiDataTest extends FieldTestBase {
|
|||
function setUp() {
|
||||
parent::setUp();
|
||||
|
||||
$langcode = LANGUAGE_NOT_SPECIFIED;
|
||||
|
||||
$field_names = $this->setUpFields();
|
||||
|
||||
// The first one will be attached to nodes only.
|
||||
|
@ -65,9 +63,8 @@ class ApiDataTest extends FieldTestBase {
|
|||
// Now create some example nodes/users for the view result.
|
||||
for ($i = 0; $i < 5; $i++) {
|
||||
$edit = array(
|
||||
// @TODO Write a helper method to create such values.
|
||||
'field_name_0' => array($langcode => array((array('value' => $this->randomName())))),
|
||||
'field_name_2' => array($langcode => array((array('value' => $this->randomName())))),
|
||||
'field_name_0' => array((array('value' => $this->randomName()))),
|
||||
'field_name_2' => array((array('value' => $this->randomName()))),
|
||||
);
|
||||
$this->nodes[] = $this->drupalCreateNode($edit);
|
||||
}
|
||||
|
|
|
@ -59,13 +59,13 @@ class HandlerFieldFieldTest extends FieldTestBase {
|
|||
|
||||
for ($key = 0; $key < 3; $key++) {
|
||||
$field = $this->fields[$key];
|
||||
$edit[$field['field_name']][LANGUAGE_NOT_SPECIFIED][0]['value'] = $this->randomName(8);
|
||||
$edit[$field['field_name']][0]['value'] = $this->randomName(8);
|
||||
}
|
||||
for ($j = 0; $j < 5; $j++) {
|
||||
$edit[$this->fields[3]['field_name']][LANGUAGE_NOT_SPECIFIED][$j]['value'] = $this->randomName(8);
|
||||
$edit[$this->fields[3]['field_name']][$j]['value'] = $this->randomName(8);
|
||||
}
|
||||
// Set this field to be empty.
|
||||
$edit[$this->fields[4]['field_name']] = array(LANGUAGE_NOT_SPECIFIED => array(0 => array('value' => NULL)));
|
||||
$edit[$this->fields[4]['field_name']] = array(array('value' => NULL));
|
||||
|
||||
$this->nodes[$i] = $this->drupalCreateNode($edit);
|
||||
}
|
||||
|
|
|
@ -7,7 +7,7 @@
|
|||
|
||||
namespace Drupal\field_ui\Tests;
|
||||
|
||||
use Drupal\node\Plugin\Core\Entity\Node;
|
||||
use Drupal\Core\Entity\EntityInterface;
|
||||
|
||||
/**
|
||||
* Tests the functionality of the 'Manage display' screens.
|
||||
|
@ -111,7 +111,7 @@ class ManageDisplayTest extends FieldUiTestBase {
|
|||
$value = 12345;
|
||||
$settings = array(
|
||||
'type' => $this->type,
|
||||
'field_test' => array(LANGUAGE_NOT_SPECIFIED => array(array('value' => $value))),
|
||||
'field_test' => array(array('value' => $value)),
|
||||
);
|
||||
$node = $this->drupalCreateNode($settings);
|
||||
|
||||
|
@ -216,7 +216,7 @@ class ManageDisplayTest extends FieldUiTestBase {
|
|||
/**
|
||||
* Asserts that a string is found in the rendered node in a view mode.
|
||||
*
|
||||
* @param Node $node
|
||||
* @param EntityInterface $node
|
||||
* The node.
|
||||
* @param $view_mode
|
||||
* The view mode in which the node should be displayed.
|
||||
|
@ -228,14 +228,14 @@ class ManageDisplayTest extends FieldUiTestBase {
|
|||
* @return
|
||||
* TRUE on pass, FALSE on fail.
|
||||
*/
|
||||
function assertNodeViewText(Node $node, $view_mode, $text, $message) {
|
||||
function assertNodeViewText(EntityInterface $node, $view_mode, $text, $message) {
|
||||
return $this->assertNodeViewTextHelper($node, $view_mode, $text, $message, FALSE);
|
||||
}
|
||||
|
||||
/**
|
||||
* Asserts that a string is not found in the rendered node in a view mode.
|
||||
*
|
||||
* @param Node $node
|
||||
* @param EntityInterface $node
|
||||
* The node.
|
||||
* @param $view_mode
|
||||
* The view mode in which the node should be displayed.
|
||||
|
@ -246,7 +246,7 @@ class ManageDisplayTest extends FieldUiTestBase {
|
|||
* @return
|
||||
* TRUE on pass, FALSE on fail.
|
||||
*/
|
||||
function assertNodeViewNoText(Node $node, $view_mode, $text, $message) {
|
||||
function assertNodeViewNoText(EntityInterface $node, $view_mode, $text, $message) {
|
||||
return $this->assertNodeViewTextHelper($node, $view_mode, $text, $message, TRUE);
|
||||
}
|
||||
|
||||
|
@ -256,7 +256,7 @@ class ManageDisplayTest extends FieldUiTestBase {
|
|||
* This helper function is used by assertNodeViewText() and
|
||||
* assertNodeViewNoText().
|
||||
*
|
||||
* @param Node $node
|
||||
* @param EntityInterface $node
|
||||
* The node.
|
||||
* @param $view_mode
|
||||
* The view mode in which the node should be displayed.
|
||||
|
@ -270,7 +270,7 @@ class ManageDisplayTest extends FieldUiTestBase {
|
|||
* @return
|
||||
* TRUE on pass, FALSE on fail.
|
||||
*/
|
||||
function assertNodeViewTextHelper(Node $node, $view_mode, $text, $message, $not_exists) {
|
||||
function assertNodeViewTextHelper(EntityInterface $node, $view_mode, $text, $message, $not_exists) {
|
||||
// Make sure caches on the tester side are refreshed after changes
|
||||
// submitted on the tested side.
|
||||
field_info_cache_clear();
|
||||
|
|
|
@ -141,7 +141,8 @@ abstract class FileFieldTestBase extends WebTestBase {
|
|||
$node = $this->drupalCreateNode($extras);
|
||||
$nid = $node->nid;
|
||||
// Save at least one revision to better simulate a real site.
|
||||
$this->drupalCreateNode(get_object_vars($node));
|
||||
$node->setNewRevision();
|
||||
$node->save();
|
||||
$node = node_load($nid, TRUE);
|
||||
$this->assertNotEqual($nid, $node->vid, t('Node revision exists.'));
|
||||
}
|
||||
|
|
|
@ -6,7 +6,6 @@
|
|||
*/
|
||||
|
||||
use Drupal\Core\Entity\EntityInterface;
|
||||
use Drupal\node\Plugin\Core\Entity\Node;
|
||||
use Drupal\entity\Plugin\Core\Entity\EntityDisplay;
|
||||
use Drupal\taxonomy\Plugin\Core\Entity\Term;
|
||||
|
||||
|
@ -241,13 +240,13 @@ function forum_uri($forum) {
|
|||
/**
|
||||
* Checks whether a node can be used in a forum, based on its content type.
|
||||
*
|
||||
* @param Drupal\node\Node $node
|
||||
* @param \Drupal\Core\Entity\EntityInterface $node
|
||||
* A node entity.
|
||||
*
|
||||
* @return
|
||||
* Boolean indicating if the node can be assigned to a forum.
|
||||
*/
|
||||
function _forum_node_check_node_type(Node $node) {
|
||||
function _forum_node_check_node_type(EntityInterface $node) {
|
||||
// Fetch information about the forum field.
|
||||
$instance = field_info_instance('node', 'taxonomy_forums', $node->type);
|
||||
return !empty($instance);
|
||||
|
@ -256,7 +255,7 @@ function _forum_node_check_node_type(Node $node) {
|
|||
/**
|
||||
* Implements hook_node_view().
|
||||
*/
|
||||
function forum_node_view(Node $node, EntityDisplay $display, $view_mode) {
|
||||
function forum_node_view(EntityInterface $node, EntityDisplay $display, $view_mode) {
|
||||
$vid = config('forum.settings')->get('vocabulary');
|
||||
$vocabulary = taxonomy_vocabulary_load($vid);
|
||||
if (_forum_node_check_node_type($node)) {
|
||||
|
@ -282,7 +281,7 @@ function forum_node_view(Node $node, EntityDisplay $display, $view_mode) {
|
|||
* Checks in particular that the node is assigned only a "leaf" term in the
|
||||
* forum taxonomy.
|
||||
*/
|
||||
function forum_node_validate(Node $node, $form) {
|
||||
function forum_node_validate(EntityInterface $node, $form) {
|
||||
if (_forum_node_check_node_type($node)) {
|
||||
$langcode = $form['taxonomy_forums']['#language'];
|
||||
// vocabulary is selected, not a "container" term.
|
||||
|
@ -318,7 +317,7 @@ function forum_node_validate(Node $node, $form) {
|
|||
*
|
||||
* Assigns the forum taxonomy when adding a topic from within a forum.
|
||||
*/
|
||||
function forum_node_presave(Node $node) {
|
||||
function forum_node_presave(EntityInterface $node) {
|
||||
if (_forum_node_check_node_type($node)) {
|
||||
// Make sure all fields are set properly:
|
||||
$node->icon = !empty($node->icon) ? $node->icon : '';
|
||||
|
@ -338,7 +337,7 @@ function forum_node_presave(Node $node) {
|
|||
/**
|
||||
* Implements hook_node_update().
|
||||
*/
|
||||
function forum_node_update(Node $node) {
|
||||
function forum_node_update(EntityInterface $node) {
|
||||
if (_forum_node_check_node_type($node)) {
|
||||
// If this is not a new revision and does exist, update the forum record,
|
||||
// otherwise insert a new one.
|
||||
|
@ -388,7 +387,7 @@ function forum_node_update(Node $node) {
|
|||
/**
|
||||
* Implements hook_node_insert().
|
||||
*/
|
||||
function forum_node_insert(Node $node) {
|
||||
function forum_node_insert(EntityInterface $node) {
|
||||
if (_forum_node_check_node_type($node)) {
|
||||
if (!empty($node->forum_tid)) {
|
||||
$nid = db_insert('forum')
|
||||
|
@ -405,7 +404,7 @@ function forum_node_insert(Node $node) {
|
|||
/**
|
||||
* Implements hook_node_predelete().
|
||||
*/
|
||||
function forum_node_predelete(Node $node) {
|
||||
function forum_node_predelete(EntityInterface $node) {
|
||||
if (_forum_node_check_node_type($node)) {
|
||||
db_delete('forum')
|
||||
->condition('nid', $node->nid)
|
||||
|
@ -522,18 +521,17 @@ function forum_comment_delete($comment) {
|
|||
function forum_field_storage_pre_insert(EntityInterface $entity, &$skip_fields) {
|
||||
if ($entity->entityType() == 'node' && $entity->status && _forum_node_check_node_type($entity)) {
|
||||
$query = db_insert('forum_index')->fields(array('nid', 'title', 'tid', 'sticky', 'created', 'comment_count', 'last_comment_timestamp'));
|
||||
foreach ($entity->taxonomy_forums as $language) {
|
||||
foreach ($language as $item) {
|
||||
$query->values(array(
|
||||
'nid' => $entity->nid,
|
||||
'title' => $entity->title,
|
||||
'tid' => $item['tid'],
|
||||
'sticky' => $entity->sticky,
|
||||
'created' => $entity->created,
|
||||
'comment_count' => 0,
|
||||
'last_comment_timestamp' => $entity->created,
|
||||
));
|
||||
}
|
||||
foreach ($entity->getTranslationLanguages() as $langcode => $language) {
|
||||
$translation = $entity->getTranslation($langcode, FALSE);
|
||||
$query->values(array(
|
||||
'nid' => $entity->id(),
|
||||
'title' => $translation->title->value,
|
||||
'tid' => $translation->taxonomy_forums->tid,
|
||||
'sticky' => $entity->sticky,
|
||||
'created' => $entity->created,
|
||||
'comment_count' => 0,
|
||||
'last_comment_timestamp' => $entity->created,
|
||||
));
|
||||
}
|
||||
$query->execute();
|
||||
}
|
||||
|
@ -656,7 +654,7 @@ function forum_block_view_pre_render($elements) {
|
|||
/**
|
||||
* Implements hook_form().
|
||||
*/
|
||||
function forum_form(Node $node, &$form_state) {
|
||||
function forum_form(EntityInterface $node, &$form_state) {
|
||||
$type = node_type_load($node->type);
|
||||
$form['title'] = array(
|
||||
'#type' => 'textfield',
|
||||
|
|
|
@ -7,7 +7,7 @@
|
|||
|
||||
namespace Drupal\forum\Tests;
|
||||
|
||||
use Drupal\node\Plugin\Core\Entity\Node;
|
||||
use Drupal\Core\Entity\EntityInterface;
|
||||
use Drupal\simpletest\WebTestBase;
|
||||
|
||||
/**
|
||||
|
@ -540,14 +540,14 @@ class ForumTest extends WebTestBase {
|
|||
*
|
||||
* @param $node_user
|
||||
* The user who creates the node.
|
||||
* @param Drupal\node\Node $node
|
||||
* @param \Drupal\Core\Entity\EntityInterface $node
|
||||
* The node being checked.
|
||||
* @param $admin
|
||||
* Boolean to indicate whether the user can 'access administration pages'.
|
||||
* @param $response
|
||||
* The exptected HTTP response code.
|
||||
*/
|
||||
private function verifyForums($node_user, Node $node, $admin, $response = 200) {
|
||||
private function verifyForums($node_user, EntityInterface $node, $admin, $response = 200) {
|
||||
$response2 = ($admin) ? 200 : 403;
|
||||
|
||||
// View forum help node.
|
||||
|
|
|
@ -9,7 +9,7 @@
|
|||
* - Generic helper for node_mark().
|
||||
*/
|
||||
|
||||
use Drupal\node\Plugin\Core\Entity\Node;
|
||||
use Drupal\Core\Entity\EntityInterface;
|
||||
|
||||
/**
|
||||
* Entities changed before this time are always shown as read.
|
||||
|
@ -79,7 +79,7 @@ function history_cron() {
|
|||
/**
|
||||
* Implements hook_node_delete().
|
||||
*/
|
||||
function history_node_delete(Node $node) {
|
||||
function history_node_delete(EntityInterface $node) {
|
||||
db_delete('history')
|
||||
->condition('nid', $node->nid)
|
||||
->execute();
|
||||
|
|
|
@ -115,7 +115,7 @@ class LocaleContentTest extends WebTestBase {
|
|||
$edit = array(
|
||||
'type' => $type2->type,
|
||||
'title' => $node_title,
|
||||
'body' => array($langcode => array(array('value' => $node_body))),
|
||||
'body' => array(array('value' => $node_body)),
|
||||
'langcode' => $langcode,
|
||||
);
|
||||
$node = $this->drupalCreateNode($edit);
|
||||
|
|
|
@ -11,7 +11,7 @@
|
|||
* URLs to be added to the main site navigation menu.
|
||||
*/
|
||||
|
||||
use Drupal\node\Plugin\Core\Entity\Node;
|
||||
use Drupal\Core\Entity\EntityInterface;
|
||||
use Drupal\block\Plugin\Core\Entity\Block;
|
||||
use Drupal\system\Plugin\Core\Entity\Menu;
|
||||
use Drupal\system\Plugin\block\block\SystemMenuBlock;
|
||||
|
@ -424,21 +424,21 @@ function menu_block_view_alter(array &$build, Block $block) {
|
|||
/**
|
||||
* Implements hook_node_insert().
|
||||
*/
|
||||
function menu_node_insert(Node $node) {
|
||||
function menu_node_insert(EntityInterface $node) {
|
||||
menu_node_save($node);
|
||||
}
|
||||
|
||||
/**
|
||||
* Implements hook_node_update().
|
||||
*/
|
||||
function menu_node_update(Node $node) {
|
||||
function menu_node_update(EntityInterface $node) {
|
||||
menu_node_save($node);
|
||||
}
|
||||
|
||||
/**
|
||||
* Helper for hook_node_insert() and hook_node_update().
|
||||
*/
|
||||
function menu_node_save(Node $node) {
|
||||
function menu_node_save(EntityInterface $node) {
|
||||
if (isset($node->menu)) {
|
||||
$link = &$node->menu;
|
||||
if (empty($link['enabled'])) {
|
||||
|
@ -467,7 +467,7 @@ function menu_node_save(Node $node) {
|
|||
/**
|
||||
* Implements hook_node_predelete().
|
||||
*/
|
||||
function menu_node_predelete(Node $node) {
|
||||
function menu_node_predelete(EntityInterface $node) {
|
||||
// Delete all menu module links that point to this node.
|
||||
$query = entity_query('menu_link')
|
||||
->condition('link_path', 'node/' . $node->nid)
|
||||
|
@ -482,7 +482,7 @@ function menu_node_predelete(Node $node) {
|
|||
/**
|
||||
* Implements hook_node_prepare().
|
||||
*/
|
||||
function menu_node_prepare(Node $node) {
|
||||
function menu_node_prepare(EntityInterface $node) {
|
||||
if (empty($node->menu)) {
|
||||
// Prepare the node for the edit form so that $node->menu always exists.
|
||||
$menu_name = strtok(variable_get('menu_parent_' . $node->type, 'main:0'), ':');
|
||||
|
@ -645,7 +645,7 @@ function menu_form_node_form_alter(&$form, $form_state) {
|
|||
*
|
||||
* @see menu_form_node_form_alter()
|
||||
*/
|
||||
function menu_node_submit(Node $node, $form, $form_state) {
|
||||
function menu_node_submit(EntityInterface $node, $form, $form_state) {
|
||||
$node->menu = entity_create('menu_link', $form_state['values']['menu']);
|
||||
// Decompose the selected menu parent option into 'menu_name' and 'plid', if
|
||||
// the form used the default parent selection widget.
|
||||
|
|
|
@ -7,7 +7,7 @@
|
|||
|
||||
namespace Drupal\node;
|
||||
|
||||
use Drupal\Core\Entity\DatabaseStorageController;
|
||||
use Drupal\Core\Entity\DatabaseStorageControllerNG;
|
||||
use Drupal\Core\Entity\EntityInterface;
|
||||
|
||||
/**
|
||||
|
@ -16,31 +16,40 @@ use Drupal\Core\Entity\EntityInterface;
|
|||
* This extends the Drupal\Core\Entity\DatabaseStorageController class, adding
|
||||
* required special handling for node entities.
|
||||
*/
|
||||
class NodeStorageController extends DatabaseStorageController {
|
||||
class NodeStorageController extends DatabaseStorageControllerNG {
|
||||
|
||||
/**
|
||||
* Overrides Drupal\Core\Entity\DatabaseStorageController::create().
|
||||
*/
|
||||
public function create(array $values) {
|
||||
$node = parent::create($values);
|
||||
|
||||
// Set the created time to now.
|
||||
if (empty($node->created)) {
|
||||
$node->created = REQUEST_TIME;
|
||||
// @todo Handle this through property defaults.
|
||||
if (empty($values['created'])) {
|
||||
$values['created'] = REQUEST_TIME;
|
||||
}
|
||||
|
||||
return $node;
|
||||
return parent::create($values)->getBCEntity();
|
||||
}
|
||||
|
||||
/**
|
||||
* Overrides Drupal\Core\Entity\DatabaseStorageController::attachLoad().
|
||||
* Overrides Drupal\Core\Entity\DatabaseStorageControllerNG::attachLoad().
|
||||
*/
|
||||
protected function attachLoad(&$nodes, $load_revision = FALSE) {
|
||||
protected function attachLoad(&$queried_entities, $load_revision = FALSE) {
|
||||
$nodes = $this->mapFromStorageRecords($queried_entities, $load_revision);
|
||||
|
||||
// Create an array of nodes for each content type and pass this to the
|
||||
// object type specific callback.
|
||||
// object type specific callback. To preserve backward-compatibility we
|
||||
// pass on BC decorators to node-specific hooks, while we pass on the
|
||||
// regular entity objects else.
|
||||
$typed_nodes = array();
|
||||
foreach ($nodes as $id => $entity) {
|
||||
$typed_nodes[$entity->type][$id] = $entity;
|
||||
foreach ($nodes as $id => $node) {
|
||||
$queried_entities[$id] = $node->getBCEntity();
|
||||
$typed_nodes[$node->bundle()][$id] = $queried_entities[$id];
|
||||
}
|
||||
|
||||
if ($load_revision) {
|
||||
field_attach_load_revision($this->entityType, $queried_entities);
|
||||
}
|
||||
else {
|
||||
field_attach_load($this->entityType, $queried_entities);
|
||||
}
|
||||
|
||||
// Call object type specific callbacks on each typed array of nodes.
|
||||
|
@ -55,7 +64,19 @@ class NodeStorageController extends DatabaseStorageController {
|
|||
// hook_node_load(), containing a list of node types that were loaded.
|
||||
$argument = array_keys($typed_nodes);
|
||||
$this->hookLoadArguments = array($argument);
|
||||
parent::attachLoad($nodes, $load_revision);
|
||||
|
||||
// Call hook_entity_load().
|
||||
foreach (module_implements('entity_load') as $module) {
|
||||
$function = $module . '_entity_load';
|
||||
$function($queried_entities, $this->entityType);
|
||||
}
|
||||
// Call hook_TYPE_load(). The first argument for hook_TYPE_load() are
|
||||
// always the queried entities, followed by additional arguments set in
|
||||
// $this->hookLoadArguments.
|
||||
$args = array_merge(array($queried_entities), $this->hookLoadArguments);
|
||||
foreach (module_implements($this->entityType . '_load') as $module) {
|
||||
call_user_func_array($module . '_' . $this->entityType . '_load', $args);
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
|
@ -77,6 +98,8 @@ class NodeStorageController extends DatabaseStorageController {
|
|||
* Overrides Drupal\Core\Entity\DatabaseStorageController::invokeHook().
|
||||
*/
|
||||
protected function invokeHook($hook, EntityInterface $node) {
|
||||
$node = $node->getBCEntity();
|
||||
|
||||
if ($hook == 'insert' || $hook == 'update') {
|
||||
node_invoke($node, $hook);
|
||||
}
|
||||
|
@ -86,7 +109,23 @@ class NodeStorageController extends DatabaseStorageController {
|
|||
node_invoke($node, 'delete');
|
||||
}
|
||||
|
||||
parent::invokeHook($hook, $node);
|
||||
// Inline parent::invokeHook() to pass on BC-entities to node-specific
|
||||
// hooks.
|
||||
|
||||
$function = 'field_attach_' . $hook;
|
||||
// @todo: field_attach_delete_revision() is named the wrong way round,
|
||||
// consider renaming it.
|
||||
if ($function == 'field_attach_revision_delete') {
|
||||
$function = 'field_attach_delete_revision';
|
||||
}
|
||||
if (!empty($this->entityInfo['fieldable']) && function_exists($function)) {
|
||||
$function($node);
|
||||
}
|
||||
|
||||
// Invoke the hook.
|
||||
module_invoke_all($this->entityType . '_' . $hook, $node);
|
||||
// Invoke the respective entity-level hook.
|
||||
module_invoke_all('entity_' . $hook, $node, $this->entityType);
|
||||
}
|
||||
|
||||
/**
|
||||
|
@ -94,7 +133,7 @@ class NodeStorageController extends DatabaseStorageController {
|
|||
*/
|
||||
protected function preSave(EntityInterface $node) {
|
||||
// Before saving the node, set changed and revision times.
|
||||
$node->changed = REQUEST_TIME;
|
||||
$node->changed->value = REQUEST_TIME;
|
||||
}
|
||||
|
||||
/**
|
||||
|
@ -126,28 +165,29 @@ class NodeStorageController extends DatabaseStorageController {
|
|||
|
||||
if ($entity->isNewRevision()) {
|
||||
$record->timestamp = REQUEST_TIME;
|
||||
$record->uid = isset($record->revision_uid) ? $record->revision_uid : $GLOBALS['user']->uid;
|
||||
$record->uid = isset($entity->revision_uid->value) ? $entity->revision_uid->value : $GLOBALS['user']->uid;
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Overrides Drupal\Core\Entity\DatabaseStorageController::postSave().
|
||||
*/
|
||||
function postSave(EntityInterface $node, $update) {
|
||||
public function postSave(EntityInterface $node, $update) {
|
||||
// Update the node access table for this node, but only if it is the
|
||||
// default revision. There's no need to delete existing records if the node
|
||||
// is new.
|
||||
if ($node->isDefaultRevision()) {
|
||||
node_access_acquire_grants($node, $update);
|
||||
node_access_acquire_grants($node->getBCEntity(), $update);
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Overrides Drupal\Core\Entity\DatabaseStorageController::preDelete().
|
||||
*/
|
||||
function preDelete($entities) {
|
||||
public function preDelete($entities) {
|
||||
if (module_exists('search')) {
|
||||
foreach ($entities as $id => $entity) {
|
||||
search_reindex($entity->nid, 'node');
|
||||
search_reindex($entity->nid->value, 'node');
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@ -163,4 +203,110 @@ class NodeStorageController extends DatabaseStorageController {
|
|||
->condition('nid', $ids, 'IN')
|
||||
->execute();
|
||||
}
|
||||
|
||||
/**
|
||||
* Overrides \Drupal\Core\Entity\DataBaseStorageControllerNG::basePropertyDefinitions().
|
||||
*/
|
||||
public function baseFieldDefinitions() {
|
||||
$properties['nid'] = array(
|
||||
'label' => t('Node ID'),
|
||||
'description' => t('The node ID.'),
|
||||
'type' => 'integer_field',
|
||||
'read-only' => TRUE,
|
||||
);
|
||||
$properties['uuid'] = array(
|
||||
'label' => t('UUID'),
|
||||
'description' => t('The node UUID.'),
|
||||
'type' => 'string_field',
|
||||
'read-only' => TRUE,
|
||||
);
|
||||
$properties['vid'] = array(
|
||||
'label' => t('Revision ID'),
|
||||
'description' => t('The node revision ID.'),
|
||||
'type' => 'integer_field',
|
||||
'read-only' => TRUE,
|
||||
);
|
||||
$properties['type'] = array(
|
||||
'label' => t('Type'),
|
||||
'description' => t('The node type.'),
|
||||
'type' => 'string_field',
|
||||
'read-only' => TRUE,
|
||||
);
|
||||
$properties['langcode'] = array(
|
||||
'label' => t('Language code'),
|
||||
'description' => t('The node language code.'),
|
||||
'type' => 'language_field',
|
||||
);
|
||||
$properties['title'] = array(
|
||||
'label' => t('Title'),
|
||||
'description' => t('The title of this node, always treated as non-markup plain text.'),
|
||||
'type' => 'string_field',
|
||||
);
|
||||
$properties['uid'] = array(
|
||||
'label' => t('User ID'),
|
||||
'description' => t('The user ID of the node author.'),
|
||||
'type' => 'entity_reference_field',
|
||||
'settings' => array('target_type' => 'user'),
|
||||
);
|
||||
$properties['status'] = array(
|
||||
'label' => t('Publishing status'),
|
||||
'description' => t('A boolean indicating whether the node is published.'),
|
||||
'type' => 'boolean_field',
|
||||
);
|
||||
$properties['created'] = array(
|
||||
'label' => t('Created'),
|
||||
'description' => t('The time that the node was created.'),
|
||||
'type' => 'integer_field',
|
||||
);
|
||||
$properties['changed'] = array(
|
||||
'label' => t('Changed'),
|
||||
'description' => t('The time that the node was last edited.'),
|
||||
'type' => 'integer_field',
|
||||
);
|
||||
$properties['comment'] = array(
|
||||
'label' => t('Comment'),
|
||||
'description' => t('Whether comments are allowed on this node: 0 = no, 1 = closed (read only), 2 = open (read/write).'),
|
||||
'type' => 'integer_field',
|
||||
);
|
||||
$properties['promote'] = array(
|
||||
'label' => t('Promote'),
|
||||
'description' => t('A boolean indicating whether the node should be displayed on the front page.'),
|
||||
'type' => 'boolean_field',
|
||||
);
|
||||
$properties['sticky'] = array(
|
||||
'label' => t('Sticky'),
|
||||
'description' => t('A boolean indicating whether the node should be displayed at the top of lists in which it appears.'),
|
||||
'type' => 'boolean_field',
|
||||
);
|
||||
$properties['tnid'] = array(
|
||||
'label' => t('Translation set ID'),
|
||||
'description' => t('The translation set id for this node, which equals the node id of the source post in each set.'),
|
||||
'type' => 'integer_field',
|
||||
);
|
||||
$properties['translate'] = array(
|
||||
'label' => t('Translate'),
|
||||
'description' => t('A boolean indicating whether this translation page needs to be updated.'),
|
||||
'type' => 'boolean_field',
|
||||
);
|
||||
$properties['revision_timestamp'] = array(
|
||||
'label' => t('Revision timestamp'),
|
||||
'description' => t('The time that the current revision was created.'),
|
||||
'type' => 'integer_field',
|
||||
'queryable' => FALSE,
|
||||
);
|
||||
$properties['revision_uid'] = array(
|
||||
'label' => t('Revision user ID'),
|
||||
'description' => t('The user ID of the author of the current revision.'),
|
||||
'type' => 'entity_reference_field',
|
||||
'settings' => array('target_type' => 'user'),
|
||||
'queryable' => FALSE,
|
||||
);
|
||||
$properties['log'] = array(
|
||||
'label' => t('Log'),
|
||||
'description' => t('The log entry explaining the changes in this version.'),
|
||||
'type' => 'string_field',
|
||||
);
|
||||
return $properties;
|
||||
}
|
||||
|
||||
}
|
||||
|
|
|
@ -8,7 +8,7 @@
|
|||
namespace Drupal\node\Plugin\Core\Entity;
|
||||
|
||||
use Drupal\Core\Entity\ContentEntityInterface;
|
||||
use Drupal\Core\Entity\Entity;
|
||||
use Drupal\Core\Entity\EntityNG;
|
||||
use Drupal\Component\Annotation\Plugin;
|
||||
use Drupal\Core\Annotation\Translation;
|
||||
|
||||
|
@ -43,64 +43,54 @@ use Drupal\Core\Annotation\Translation;
|
|||
* permission_granularity = "bundle"
|
||||
* )
|
||||
*/
|
||||
class Node extends Entity implements ContentEntityInterface {
|
||||
class Node extends EntityNG implements ContentEntityInterface {
|
||||
|
||||
/**
|
||||
* The node ID.
|
||||
*
|
||||
* @var integer
|
||||
* @var \Drupal\Core\Entity\Field\FieldInterface
|
||||
*/
|
||||
public $nid;
|
||||
|
||||
/**
|
||||
* The node revision ID.
|
||||
*
|
||||
* @var integer
|
||||
* @var \Drupal\Core\Entity\Field\FieldInterface
|
||||
*/
|
||||
public $vid;
|
||||
|
||||
/**
|
||||
* Indicates whether this is the default node revision.
|
||||
*
|
||||
* The default revision of a node is the one loaded when no specific revision
|
||||
* has been specified. Only default revisions are saved to the node table.
|
||||
*
|
||||
* @var boolean
|
||||
*/
|
||||
public $isDefaultRevision = TRUE;
|
||||
|
||||
/**
|
||||
* The node UUID.
|
||||
*
|
||||
* @var string
|
||||
* @var \Drupal\Core\Entity\Field\FieldInterface
|
||||
*/
|
||||
public $uuid;
|
||||
|
||||
/**
|
||||
* The node content type (bundle).
|
||||
*
|
||||
* @var string
|
||||
* @var \Drupal\Core\Entity\Field\FieldInterface
|
||||
*/
|
||||
public $type;
|
||||
|
||||
/**
|
||||
* The node language code.
|
||||
*
|
||||
* @var string
|
||||
* @var \Drupal\Core\Entity\Field\FieldInterface
|
||||
*/
|
||||
public $langcode = LANGUAGE_NOT_SPECIFIED;
|
||||
public $langcode;
|
||||
|
||||
/**
|
||||
* The node title.
|
||||
*
|
||||
* @var string
|
||||
* @var \Drupal\Core\Entity\Field\FieldInterface
|
||||
*/
|
||||
public $title;
|
||||
|
||||
/**
|
||||
* The node owner's user ID.
|
||||
*
|
||||
* @var integer
|
||||
* @var \Drupal\Core\Entity\Field\FieldInterface
|
||||
*/
|
||||
public $uid;
|
||||
|
||||
|
@ -110,21 +100,21 @@ class Node extends Entity implements ContentEntityInterface {
|
|||
* Unpublished nodes are only visible to their authors and to administrators.
|
||||
* The value is either NODE_PUBLISHED or NODE_NOT_PUBLISHED.
|
||||
*
|
||||
* @var integer
|
||||
* @var \Drupal\Core\Entity\Field\FieldInterface
|
||||
*/
|
||||
public $status;
|
||||
|
||||
/**
|
||||
* The node creation timestamp.
|
||||
*
|
||||
* @var integer
|
||||
* @var \Drupal\Core\Entity\Field\FieldInterface
|
||||
*/
|
||||
public $created;
|
||||
|
||||
/**
|
||||
* The node modification timestamp.
|
||||
*
|
||||
* @var integer
|
||||
* @var \Drupal\Core\Entity\Field\FieldInterface
|
||||
*/
|
||||
public $changed;
|
||||
|
||||
|
@ -135,7 +125,7 @@ class Node extends Entity implements ContentEntityInterface {
|
|||
* COMMENT_NODE_CLOSED => comments are read-only
|
||||
* COMMENT_NODE_OPEN => open (read/write)
|
||||
*
|
||||
* @var integer
|
||||
* @var \Drupal\Core\Entity\Field\FieldInterface
|
||||
*/
|
||||
public $comment;
|
||||
|
||||
|
@ -145,7 +135,7 @@ class Node extends Entity implements ContentEntityInterface {
|
|||
* Promoted nodes should be displayed on the front page of the site. The value
|
||||
* is either NODE_PROMOTED or NODE_NOT_PROMOTED.
|
||||
*
|
||||
* @var integer
|
||||
* @var \Drupal\Core\Entity\Field\FieldInterface
|
||||
*/
|
||||
public $promote;
|
||||
|
||||
|
@ -155,7 +145,7 @@ class Node extends Entity implements ContentEntityInterface {
|
|||
* Sticky nodes should be displayed at the top of lists in which they appear.
|
||||
* The value is either NODE_STICKY or NODE_NOT_STICKY.
|
||||
*
|
||||
* @var integer
|
||||
* @var \Drupal\Core\Entity\Field\FieldInterface
|
||||
*/
|
||||
public $sticky;
|
||||
|
||||
|
@ -165,7 +155,7 @@ class Node extends Entity implements ContentEntityInterface {
|
|||
* Translations sets are based on the ID of the node containing the source
|
||||
* text for the translation set.
|
||||
*
|
||||
* @var integer
|
||||
* @var \Drupal\Core\Entity\Field\FieldInterface
|
||||
*/
|
||||
public $tnid;
|
||||
|
||||
|
@ -174,52 +164,61 @@ class Node extends Entity implements ContentEntityInterface {
|
|||
*
|
||||
* If the translation page needs to be updated, the value is 1; otherwise 0.
|
||||
*
|
||||
* @var integer
|
||||
* @var \Drupal\Core\Entity\Field\FieldInterface
|
||||
*/
|
||||
public $translate;
|
||||
|
||||
/**
|
||||
* The node revision creation timestamp.
|
||||
*
|
||||
* @var integer
|
||||
* @var \Drupal\Core\Entity\Field\FieldInterface
|
||||
*/
|
||||
public $revision_timestamp;
|
||||
|
||||
/**
|
||||
* The node revision author's user ID.
|
||||
*
|
||||
* @var integer
|
||||
* @var \Drupal\Core\Entity\Field\FieldInterface
|
||||
*/
|
||||
public $revision_uid;
|
||||
|
||||
/**
|
||||
* Overrides \Drupal\Core\Entity\EntityNG::init().
|
||||
*/
|
||||
protected function init() {
|
||||
parent::init();
|
||||
// We unset all defined properties, so magic getters apply.
|
||||
unset($this->nid);
|
||||
unset($this->vid);
|
||||
unset($this->uuid);
|
||||
unset($this->type);
|
||||
unset($this->title);
|
||||
unset($this->uid);
|
||||
unset($this->status);
|
||||
unset($this->created);
|
||||
unset($this->changed);
|
||||
unset($this->comment);
|
||||
unset($this->promote);
|
||||
unset($this->sticky);
|
||||
unset($this->tnid);
|
||||
unset($this->translate);
|
||||
unset($this->revision_timestamp);
|
||||
unset($this->revision_uid);
|
||||
unset($this->log);
|
||||
}
|
||||
|
||||
/**
|
||||
* Implements Drupal\Core\Entity\EntityInterface::id().
|
||||
*/
|
||||
public function id() {
|
||||
return $this->nid;
|
||||
}
|
||||
|
||||
/**
|
||||
* Implements Drupal\Core\Entity\EntityInterface::bundle().
|
||||
*/
|
||||
public function bundle() {
|
||||
return $this->type;
|
||||
}
|
||||
|
||||
/**
|
||||
* Overrides Drupal\Core\Entity\Entity::createDuplicate().
|
||||
*/
|
||||
public function createDuplicate() {
|
||||
$duplicate = parent::createDuplicate();
|
||||
$duplicate->vid = NULL;
|
||||
return $duplicate;
|
||||
return $this->get('nid')->value;
|
||||
}
|
||||
|
||||
/**
|
||||
* Overrides Drupal\Core\Entity\Entity::getRevisionId().
|
||||
*/
|
||||
public function getRevisionId() {
|
||||
return $this->vid;
|
||||
return $this->get('vid')->value;
|
||||
}
|
||||
|
||||
}
|
||||
|
|
|
@ -57,7 +57,7 @@ class NodeAccessFieldTest extends NodeTestBase {
|
|||
// Create a page node.
|
||||
$langcode = LANGUAGE_NOT_SPECIFIED;
|
||||
$field_data = array();
|
||||
$value = $field_data[$langcode][0]['value'] = $this->randomName();
|
||||
$value = $field_data[0]['value'] = $this->randomName();
|
||||
$node = $this->drupalCreateNode(array($this->field_name => $field_data));
|
||||
|
||||
// Log in as the administrator and confirm that the field value is present.
|
||||
|
|
|
@ -64,7 +64,7 @@ class NodeAccessLanguageTest extends NodeTestBase {
|
|||
|
||||
// Tests the default access provided for a published Hungarian node.
|
||||
$web_user = $this->drupalCreateUser(array('access content'));
|
||||
$node = $this->drupalCreateNode(array('body' => array('hu' => array(array())), 'langcode' => 'hu'));
|
||||
$node = $this->drupalCreateNode(array('body' => array(array()), 'langcode' => 'hu'));
|
||||
$this->assertTrue($node->langcode == 'hu', 'Node created as Hungarian.');
|
||||
$expected_node_access = array('view' => TRUE, 'update' => FALSE, 'delete' => FALSE);
|
||||
$this->assertNodeAccess($expected_node_access, $node, $web_user);
|
||||
|
|
|
@ -86,9 +86,7 @@ class NodeAccessPagerTest extends WebTestBase {
|
|||
'nid' => NULL,
|
||||
'type' => 'forum',
|
||||
'taxonomy_forums' => array(
|
||||
LANGUAGE_NOT_SPECIFIED => array(
|
||||
array('tid' => $tid, 'vid' => $vid),
|
||||
),
|
||||
array('tid' => $tid)
|
||||
),
|
||||
));
|
||||
}
|
||||
|
|
|
@ -50,7 +50,7 @@ class NodeEntityFieldQueryAlterTest extends NodeTestBase {
|
|||
'value' => 'A' . $this->randomName(32),
|
||||
'format' => filter_default_format(),
|
||||
);
|
||||
$settings['body'][LANGUAGE_NOT_SPECIFIED][0] = $body;
|
||||
$settings['body'][0] = $body;
|
||||
$this->drupalCreateNode($settings);
|
||||
}
|
||||
|
||||
|
|
|
@ -82,33 +82,30 @@ class NodeFieldMultilingualTestCase extends WebTestBase {
|
|||
$this->drupalPost('node/add/page', $edit, t('Save'));
|
||||
|
||||
// Check that the node exists in the database.
|
||||
$node = $this->drupalGetNodeByTitle($edit[$title_key]);
|
||||
$node = $this->drupalGetNodeByTitle($edit[$title_key])->getOriginalEntity();
|
||||
$this->assertTrue($node, 'Node found in database.');
|
||||
|
||||
$assert = isset($node->body['en']) && !isset($node->body[LANGUAGE_NOT_SPECIFIED]) && $node->body['en'][0]['value'] == $body_value;
|
||||
$this->assertTrue($assert, 'Field language correctly set.');
|
||||
$this->assertTrue($node->language()->langcode == $langcode && $node->body->value == $body_value, 'Field language correctly set.');
|
||||
|
||||
// Change node language.
|
||||
$this->drupalGet("node/$node->nid/edit");
|
||||
$langcode = 'it';
|
||||
$this->drupalGet("node/{$node->id()}/edit");
|
||||
$edit = array(
|
||||
$title_key => $this->randomName(8),
|
||||
'langcode' => 'it'
|
||||
'langcode' => $langcode,
|
||||
);
|
||||
$this->drupalPost(NULL, $edit, t('Save'));
|
||||
$node = $this->drupalGetNodeByTitle($edit[$title_key], TRUE);
|
||||
$node = $this->drupalGetNodeByTitle($edit[$title_key], TRUE)->getOriginalEntity();
|
||||
$this->assertTrue($node, 'Node found in database.');
|
||||
|
||||
$assert = isset($node->body['it']) && !isset($node->body['en']) && $node->body['it'][0]['value'] == $body_value;
|
||||
$this->assertTrue($assert, 'Field language correctly changed.');
|
||||
$this->assertTrue($node->language()->langcode == $langcode && $node->body->value == $body_value, 'Field language correctly changed.');
|
||||
|
||||
// Enable content language URL detection.
|
||||
language_negotiation_set(LANGUAGE_TYPE_CONTENT, array(LANGUAGE_NEGOTIATION_URL => 0));
|
||||
|
||||
// Test multilingual field language fallback logic.
|
||||
$this->drupalGet("it/node/$node->nid");
|
||||
$this->drupalGet("it/node/{$node->id()}");
|
||||
$this->assertRaw($body_value, 'Body correctly displayed using Italian as requested language');
|
||||
|
||||
$this->drupalGet("node/$node->nid");
|
||||
$this->drupalGet("node/{$node->id()}");
|
||||
$this->assertRaw($body_value, 'Body correctly displayed using English as requested language');
|
||||
}
|
||||
|
||||
|
|
|
@ -49,7 +49,7 @@ class NodeRevisionPermissionsTest extends NodeTestBase {
|
|||
for ($i = 0; $i < 3; $i++) {
|
||||
// Create a revision for the same nid and settings with a random log.
|
||||
$revision = clone $nodes[$type];
|
||||
$revision->revision = 1;
|
||||
$revision->setNewRevision();
|
||||
$revision->log = $this->randomName(32);
|
||||
node_save($revision);
|
||||
$this->node_revisions[$type][] = $revision;
|
||||
|
|
|
@ -48,18 +48,24 @@ class NodeRevisionsAllTestCase extends NodeTestBase {
|
|||
$logs = array();
|
||||
|
||||
// Get the original node.
|
||||
$nodes[] = $node;
|
||||
$nodes[] = clone $node;
|
||||
|
||||
// Create three revisions.
|
||||
$revision_count = 3;
|
||||
for ($i = 0; $i < $revision_count; $i++) {
|
||||
$logs[] = $settings['log'] = $this->randomName(32);
|
||||
$logs[] = $node->log = $this->randomName(32);
|
||||
|
||||
// Create revision with a random title and body and update variables.
|
||||
$this->drupalCreateNode($settings);
|
||||
$node = node_load($node->nid); // Make sure we get revision information.
|
||||
$settings = get_object_vars($node);
|
||||
$nodes[] = $node;
|
||||
$node->title = $this->randomName();
|
||||
$node->body[$node->language()->langcode][0] = array(
|
||||
'value' => $this->randomName(32),
|
||||
'format' => filter_default_format(),
|
||||
);
|
||||
$node->setNewRevision();
|
||||
$node->save();
|
||||
|
||||
$node = node_load($node->nid, TRUE); // Make sure we get revision information.
|
||||
$nodes[] = clone $node;
|
||||
}
|
||||
|
||||
$this->nodes = $nodes;
|
||||
|
@ -110,7 +116,7 @@ class NodeRevisionsAllTestCase extends NodeTestBase {
|
|||
'%revision-date' => format_date($nodes[1]->revision_timestamp)
|
||||
)),
|
||||
'Revision reverted.');
|
||||
$reverted_node = node_load($node->nid);
|
||||
$reverted_node = node_load($node->nid, TRUE);
|
||||
$this->assertTrue(($nodes[1]->body[LANGUAGE_NOT_SPECIFIED][0]['value'] == $reverted_node->body[LANGUAGE_NOT_SPECIFIED][0]['value']), t('Node reverted correctly.'));
|
||||
|
||||
// Confirm that this is not the current version.
|
||||
|
|
|
@ -48,20 +48,24 @@ class NodeRevisionsTest extends NodeTestBase {
|
|||
$logs = array();
|
||||
|
||||
// Get original node.
|
||||
$nodes[] = $node;
|
||||
$nodes[] = clone $node;
|
||||
|
||||
// Create three revisions.
|
||||
$revision_count = 3;
|
||||
for ($i = 0; $i < $revision_count; $i++) {
|
||||
$logs[] = $settings['log'] = $this->randomName(32);
|
||||
$logs[] = $node->log = $this->randomName(32);
|
||||
|
||||
// Create revision with a random title and body and update variables.
|
||||
$node->title = $this->randomName();
|
||||
$node->body[$node->language()->langcode][0] = array(
|
||||
'value' => $this->randomName(32),
|
||||
'format' => filter_default_format(),
|
||||
);
|
||||
$node->setNewRevision();
|
||||
$node->save();
|
||||
|
||||
// Create revision with random title and body and update variables.
|
||||
$this->drupalCreateNode($settings);
|
||||
$node = node_load($node->nid); // Make sure we get revision information.
|
||||
$settings = get_object_vars($node);
|
||||
$settings['isDefaultRevision'] = TRUE;
|
||||
|
||||
$nodes[] = $node;
|
||||
$nodes[] = clone $node;
|
||||
}
|
||||
|
||||
$this->nodes = $nodes;
|
||||
|
@ -96,7 +100,7 @@ class NodeRevisionsTest extends NodeTestBase {
|
|||
$this->assertRaw(t('@type %title has been reverted back to the revision from %revision-date.',
|
||||
array('@type' => 'Basic page', '%title' => $nodes[1]->label(),
|
||||
'%revision-date' => format_date($nodes[1]->revision_timestamp))), 'Revision reverted.');
|
||||
$reverted_node = node_load($node->nid);
|
||||
$reverted_node = node_load($node->nid, TRUE);
|
||||
$this->assertTrue(($nodes[1]->body[LANGUAGE_NOT_SPECIFIED][0]['value'] == $reverted_node->body[LANGUAGE_NOT_SPECIFIED][0]['value']), 'Node reverted correctly.');
|
||||
|
||||
// Confirm that this is not the default version.
|
||||
|
|
|
@ -51,13 +51,13 @@ class NodeSaveTest extends NodeTestBase {
|
|||
$title = $this->randomName(8);
|
||||
$node = array(
|
||||
'title' => $title,
|
||||
'body' => array(LANGUAGE_NOT_SPECIFIED => array(array('value' => $this->randomName(32)))),
|
||||
'body' => array(array('value' => $this->randomName(32))),
|
||||
'uid' => $this->web_user->uid,
|
||||
'type' => 'article',
|
||||
'nid' => $test_nid,
|
||||
'enforceIsNew' => TRUE,
|
||||
);
|
||||
$node = node_submit(entity_create('node', $node));
|
||||
$node->enforceIsNew();
|
||||
|
||||
// Verify that node_submit did not overwrite the user ID.
|
||||
$this->assertEqual($node->uid, $this->web_user->uid, 'Function node_submit() preserves user ID');
|
||||
|
|
|
@ -35,7 +35,7 @@ class NodeTokenReplaceTest extends NodeTestBase {
|
|||
'type' => 'article',
|
||||
'uid' => $account->uid,
|
||||
'title' => '<blink>Blinking Text</blink>',
|
||||
'body' => array(LANGUAGE_NOT_SPECIFIED => array(array('value' => $this->randomName(32), 'summary' => $this->randomName(16)))),
|
||||
'body' => array(array('value' => $this->randomName(32), 'summary' => $this->randomName(16))),
|
||||
);
|
||||
$node = $this->drupalCreateNode($settings);
|
||||
|
||||
|
@ -83,7 +83,7 @@ class NodeTokenReplaceTest extends NodeTestBase {
|
|||
}
|
||||
|
||||
// Repeat for a node without a summary.
|
||||
$settings['body'] = array(LANGUAGE_NOT_SPECIFIED => array(array('value' => $this->randomName(32), 'summary' => '')));
|
||||
$settings['body'] = array(array('value' => $this->randomName(32), 'summary' => ''));
|
||||
$node = $this->drupalCreateNode($settings);
|
||||
|
||||
// Load node (without summary) so that the body and summary fields are
|
||||
|
|
|
@ -7,6 +7,7 @@
|
|||
|
||||
namespace Drupal\node\Tests;
|
||||
|
||||
use Drupal\Core\Entity\EntityInterface;
|
||||
use Drupal\translation_entity\Tests\EntityTranslationUITest;
|
||||
|
||||
/**
|
||||
|
@ -67,7 +68,10 @@ class NodeTranslationUITest extends EntityTranslationUITest {
|
|||
/**
|
||||
* Overrides \Drupal\translation_entity\Tests\EntityTranslationUITest::getFormSubmitAction().
|
||||
*/
|
||||
protected function getFormSubmitAction() {
|
||||
protected function getFormSubmitAction(EntityInterface $entity) {
|
||||
if ($entity->status) {
|
||||
return t('Save and unpublish');
|
||||
}
|
||||
return t('Save and keep unpublished');
|
||||
}
|
||||
|
||||
|
@ -124,7 +128,7 @@ class NodeTranslationUITest extends EntityTranslationUITest {
|
|||
'date[date]' => format_date($values[$langcode]['created'], 'custom', 'Y-m-d'),
|
||||
'date[time]' => format_date($values[$langcode]['created'], 'custom', 'H:i:s'),
|
||||
);
|
||||
$this->drupalPost($path, $edit, $this->getFormSubmitAction(), array('language' => $languages[$langcode]));
|
||||
$this->drupalPost($path, $edit, $this->getFormSubmitAction($entity), array('language' => $languages[$langcode]));
|
||||
}
|
||||
|
||||
$entity = entity_load($this->entityType, $this->entityId, TRUE);
|
||||
|
|
|
@ -25,7 +25,7 @@ class SummaryLengthTest extends NodeTestBase {
|
|||
function testSummaryLength() {
|
||||
// Create a node to view.
|
||||
$settings = array(
|
||||
'body' => array(LANGUAGE_NOT_SPECIFIED => array(array('value' => 'Lorem ipsum dolor sit amet, consectetur adipiscing elit. Etiam vitae arcu at leo cursus laoreet. Curabitur dui tortor, adipiscing malesuada tempor in, bibendum ac diam. Cras non tellus a libero pellentesque condimentum. What is a Drupalism? Suspendisse ac lacus libero. Ut non est vel nisl faucibus interdum nec sed leo. Pellentesque sem risus, vulputate eu semper eget, auctor in libero. Ut fermentum est vitae metus convallis scelerisque. Phasellus pellentesque rhoncus tellus, eu dignissim purus posuere id. Quisque eu fringilla ligula. Morbi ullamcorper, lorem et mattis egestas, tortor neque pretium velit, eget eleifend odio turpis eu purus. Donec vitae metus quis leo pretium tincidunt a pulvinar sem. Morbi adipiscing laoreet mauris vel placerat. Nullam elementum, nisl sit amet scelerisque malesuada, dolor nunc hendrerit quam, eu ultrices erat est in orci. Curabitur feugiat egestas nisl sed accumsan.'))),
|
||||
'body' => array(array('value' => 'Lorem ipsum dolor sit amet, consectetur adipiscing elit. Etiam vitae arcu at leo cursus laoreet. Curabitur dui tortor, adipiscing malesuada tempor in, bibendum ac diam. Cras non tellus a libero pellentesque condimentum. What is a Drupalism? Suspendisse ac lacus libero. Ut non est vel nisl faucibus interdum nec sed leo. Pellentesque sem risus, vulputate eu semper eget, auctor in libero. Ut fermentum est vitae metus convallis scelerisque. Phasellus pellentesque rhoncus tellus, eu dignissim purus posuere id. Quisque eu fringilla ligula. Morbi ullamcorper, lorem et mattis egestas, tortor neque pretium velit, eget eleifend odio turpis eu purus. Donec vitae metus quis leo pretium tincidunt a pulvinar sem. Morbi adipiscing laoreet mauris vel placerat. Nullam elementum, nisl sit amet scelerisque malesuada, dolor nunc hendrerit quam, eu ultrices erat est in orci. Curabitur feugiat egestas nisl sed accumsan.')),
|
||||
'promote' => 1,
|
||||
);
|
||||
$node = $this->drupalCreateNode($settings);
|
||||
|
|
|
@ -256,7 +256,7 @@ function hook_node_grants($account, $op) {
|
|||
*
|
||||
* Note: a deny all grant is not written to the database; denies are implicit.
|
||||
*
|
||||
* @param Drupal\node\Node $node
|
||||
* @param \Drupal\Core\Entity\EntityInterface $node
|
||||
* The node that has just been saved.
|
||||
*
|
||||
* @return
|
||||
|
@ -266,7 +266,7 @@ function hook_node_grants($account, $op) {
|
|||
* @see hook_node_access_records_alter()
|
||||
* @ingroup node_access
|
||||
*/
|
||||
function hook_node_access_records(Drupal\node\Node $node) {
|
||||
function hook_node_access_records(\Drupal\Core\Entity\EntityInterface $node) {
|
||||
// We only care about the node if it has been marked private. If not, it is
|
||||
// treated just like any other node and we completely ignore it.
|
||||
if ($node->private) {
|
||||
|
@ -317,7 +317,7 @@ function hook_node_access_records(Drupal\node\Node $node) {
|
|||
*
|
||||
* @param $grants
|
||||
* The $grants array returned by hook_node_access_records().
|
||||
* @param Drupal\node\Node $node
|
||||
* @param \Drupal\Core\Entity\EntityInterface $node
|
||||
* The node for which the grants were acquired.
|
||||
*
|
||||
* The preferred use of this hook is in a module that bridges multiple node
|
||||
|
@ -329,7 +329,7 @@ function hook_node_access_records(Drupal\node\Node $node) {
|
|||
* @see hook_node_grants_alter()
|
||||
* @ingroup node_access
|
||||
*/
|
||||
function hook_node_access_records_alter(&$grants, Drupal\node\Node $node) {
|
||||
function hook_node_access_records_alter(&$grants, Drupal\Core\Entity\EntityInterface $node) {
|
||||
// Our module allows editors to mark specific articles with the 'is_preview'
|
||||
// field. If the node being saved has a TRUE value for that field, then only
|
||||
// our grants are retained, and other grants are removed. Doing so ensures
|
||||
|
@ -459,14 +459,14 @@ function hook_node_operations() {
|
|||
* field_attach_delete() are called, and before the node is removed from the
|
||||
* node table in the database.
|
||||
*
|
||||
* @param Drupal\node\Node $node
|
||||
* @param \Drupal\Core\Entity\EntityInterface $node
|
||||
* The node that is about to be deleted.
|
||||
*
|
||||
* @see hook_node_predelete()
|
||||
* @see node_delete_multiple()
|
||||
* @ingroup node_api_hooks
|
||||
*/
|
||||
function hook_node_predelete(Drupal\node\Node $node) {
|
||||
function hook_node_predelete(\Drupal\Core\Entity\EntityInterface $node) {
|
||||
db_delete('mytable')
|
||||
->condition('nid', $node->nid)
|
||||
->execute();
|
||||
|
@ -478,14 +478,14 @@ function hook_node_predelete(Drupal\node\Node $node) {
|
|||
* This hook is invoked from node_delete_multiple() after field_attach_delete()
|
||||
* has been called and after the node has been removed from the database.
|
||||
*
|
||||
* @param Drupal\node\Node $node
|
||||
* @param \Drupal\Core\Entity\EntityInterface $node
|
||||
* The node that has been deleted.
|
||||
*
|
||||
* @see hook_node_predelete()
|
||||
* @see node_delete_multiple()
|
||||
* @ingroup node_api_hooks
|
||||
*/
|
||||
function hook_node_delete(Drupal\node\Node $node) {
|
||||
function hook_node_delete(\Drupal\Core\Entity\EntityInterface $node) {
|
||||
drupal_set_message(t('Node: @title has been deleted', array('@title' => $node->label())));
|
||||
}
|
||||
|
||||
|
@ -496,12 +496,12 @@ function hook_node_delete(Drupal\node\Node $node) {
|
|||
* removed from the node_revision table, and before
|
||||
* field_attach_delete_revision() is called.
|
||||
*
|
||||
* @param Drupal\node\Node $node
|
||||
* @param \Drupal\Core\Entity\EntityInterface $node
|
||||
* The node revision (node object) that is being deleted.
|
||||
*
|
||||
* @ingroup node_api_hooks
|
||||
*/
|
||||
function hook_node_revision_delete(Drupal\node\Node $node) {
|
||||
function hook_node_revision_delete(\Drupal\Core\Entity\EntityInterface $node) {
|
||||
db_delete('mytable')
|
||||
->condition('vid', $node->vid)
|
||||
->execute();
|
||||
|
@ -523,12 +523,12 @@ function hook_node_revision_delete(Drupal\node\Node $node) {
|
|||
* write/update database queries executed from this hook are also not committed
|
||||
* immediately. Check node_save() and db_transaction() for more info.
|
||||
*
|
||||
* @param Drupal\node\Node $node
|
||||
* @param \Drupal\Core\Entity\EntityInterface $node
|
||||
* The node that is being created.
|
||||
*
|
||||
* @ingroup node_api_hooks
|
||||
*/
|
||||
function hook_node_insert(Drupal\node\Node $node) {
|
||||
function hook_node_insert(\Drupal\Core\Entity\EntityInterface $node) {
|
||||
db_insert('mytable')
|
||||
->fields(array(
|
||||
'nid' => $node->nid,
|
||||
|
@ -543,12 +543,12 @@ function hook_node_insert(Drupal\node\Node $node) {
|
|||
* This hook runs after a new node object has just been instantiated. It can be
|
||||
* used to set initial values, e.g. to provide defaults.
|
||||
*
|
||||
* @param \Drupal\node\Plugin\Core\Entity\Node $node
|
||||
* @param \Drupal\Core\Entity\EntityInterface $node
|
||||
* The node object.
|
||||
*
|
||||
* @ingroup node_api_hooks
|
||||
*/
|
||||
function hook_node_create(\Drupal\node\Plugin\Core\Entity\Node $node) {
|
||||
function hook_node_create(\Drupal\Core\Entity\EntityInterface $node) {
|
||||
if (!isset($node->foo)) {
|
||||
$node->foo = 'some_initial_value';
|
||||
}
|
||||
|
@ -615,7 +615,7 @@ function hook_node_load($nodes, $types) {
|
|||
* the default home page at path 'node', a recent content block, etc.) See
|
||||
* @link node_access Node access rights @endlink for a full explanation.
|
||||
*
|
||||
* @param Drupal\node\Node|string $node
|
||||
* @param Drupal\Core\Entity\EntityInterface|string $node
|
||||
* Either a node entity or the machine name of the content type on which to
|
||||
* perform the access check.
|
||||
* @param string $op
|
||||
|
@ -669,12 +669,12 @@ function hook_node_access($node, $op, $account, $langcode) {
|
|||
* This hook is invoked from NodeFormController::prepareEntity() after the
|
||||
* type-specific hook_prepare() is invoked.
|
||||
*
|
||||
* @param Drupal\node\Node $node
|
||||
* @param \Drupal\Core\Entity\EntityInterface $node
|
||||
* The node that is about to be shown on the add/edit form.
|
||||
*
|
||||
* @ingroup node_api_hooks
|
||||
*/
|
||||
function hook_node_prepare(Drupal\node\Node $node) {
|
||||
function hook_node_prepare(\Drupal\Core\Entity\EntityInterface $node) {
|
||||
if (!isset($node->comment)) {
|
||||
$node->comment = variable_get("comment_$node->type", COMMENT_NODE_OPEN);
|
||||
}
|
||||
|
@ -686,7 +686,7 @@ function hook_node_prepare(Drupal\node\Node $node) {
|
|||
* This hook is invoked from node_search_execute(), after node_load() and
|
||||
* node_view() have been called.
|
||||
*
|
||||
* @param Drupal\node\Node $node
|
||||
* @param \Drupal\Core\Entity\EntityInterface $node
|
||||
* The node being displayed in a search result.
|
||||
* @param $langcode
|
||||
* Language code of result being displayed.
|
||||
|
@ -702,7 +702,7 @@ function hook_node_prepare(Drupal\node\Node $node) {
|
|||
*
|
||||
* @ingroup node_api_hooks
|
||||
*/
|
||||
function hook_node_search_result(Drupal\node\Node $node, $langcode) {
|
||||
function hook_node_search_result(\Drupal\Core\Entity\EntityInterface $node, $langcode) {
|
||||
$comments = db_query('SELECT comment_count FROM {node_comment_statistics} WHERE nid = :nid', array('nid' => $node->nid))->fetchField();
|
||||
return array('comment' => format_plural($comments, '1 comment', '@count comments'));
|
||||
}
|
||||
|
@ -713,12 +713,12 @@ function hook_node_search_result(Drupal\node\Node $node, $langcode) {
|
|||
* This hook is invoked from node_save() before the node is saved to the
|
||||
* database.
|
||||
*
|
||||
* @param Drupal\node\Node $node
|
||||
* @param \Drupal\Core\Entity\EntityInterface $node
|
||||
* The node that is being inserted or updated.
|
||||
*
|
||||
* @ingroup node_api_hooks
|
||||
*/
|
||||
function hook_node_presave(Drupal\node\Node $node) {
|
||||
function hook_node_presave(\Drupal\Core\Entity\EntityInterface $node) {
|
||||
if ($node->nid && $node->moderate) {
|
||||
// Reset votes when node is updated:
|
||||
$node->score = 0;
|
||||
|
@ -743,12 +743,12 @@ function hook_node_presave(Drupal\node\Node $node) {
|
|||
* write/update database queries executed from this hook are also not committed
|
||||
* immediately. Check node_save() and db_transaction() for more info.
|
||||
*
|
||||
* @param Drupal\node\Node $node
|
||||
* @param \Drupal\Core\Entity\EntityInterface $node
|
||||
* The node that is being updated.
|
||||
*
|
||||
* @ingroup node_api_hooks
|
||||
*/
|
||||
function hook_node_update(Drupal\node\Node $node) {
|
||||
function hook_node_update(\Drupal\Core\Entity\EntityInterface $node) {
|
||||
db_update('mytable')
|
||||
->fields(array('extra' => $node->extra))
|
||||
->condition('nid', $node->nid)
|
||||
|
@ -761,7 +761,7 @@ function hook_node_update(Drupal\node\Node $node) {
|
|||
* This hook is invoked during search indexing, after node_load(), and after the
|
||||
* result of node_view() is added as $node->rendered to the node object.
|
||||
*
|
||||
* @param Drupal\node\Node $node
|
||||
* @param \Drupal\Core\Entity\EntityInterface $node
|
||||
* The node being indexed.
|
||||
* @param $langcode
|
||||
* Language code of the variant of the node being indexed.
|
||||
|
@ -771,7 +771,7 @@ function hook_node_update(Drupal\node\Node $node) {
|
|||
*
|
||||
* @ingroup node_api_hooks
|
||||
*/
|
||||
function hook_node_update_index(Drupal\node\Node $node, $langcode) {
|
||||
function hook_node_update_index(\Drupal\Core\Entity\EntityInterface $node, $langcode) {
|
||||
$text = '';
|
||||
$comments = db_query('SELECT subject, comment, format FROM {comment} WHERE nid = :nid AND status = :status', array(':nid' => $node->nid, ':status' => COMMENT_PUBLISHED));
|
||||
foreach ($comments as $comment) {
|
||||
|
@ -795,7 +795,7 @@ function hook_node_update_index(Drupal\node\Node $node, $langcode) {
|
|||
* hook_node_presave() instead. If it is really necessary to change the node at
|
||||
* the validate stage, you can use form_set_value().
|
||||
*
|
||||
* @param Drupal\node\Node $node
|
||||
* @param \Drupal\Core\Entity\EntityInterface $node
|
||||
* The node being validated.
|
||||
* @param $form
|
||||
* The form being used to edit the node.
|
||||
|
@ -804,7 +804,7 @@ function hook_node_update_index(Drupal\node\Node $node, $langcode) {
|
|||
*
|
||||
* @ingroup node_api_hooks
|
||||
*/
|
||||
function hook_node_validate(Drupal\node\Node $node, $form, &$form_state) {
|
||||
function hook_node_validate(\Drupal\Core\Entity\EntityInterface $node, $form, &$form_state) {
|
||||
if (isset($node->end) && isset($node->start)) {
|
||||
if ($node->start > $node->end) {
|
||||
form_set_error('time', t('An event may not end before it starts.'));
|
||||
|
@ -823,7 +823,7 @@ function hook_node_validate(Drupal\node\Node $node, $form, &$form_state) {
|
|||
* properties. See hook_field_attach_extract_form_values() for customizing
|
||||
* field-related properties.
|
||||
*
|
||||
* @param Drupal\node\Node $node
|
||||
* @param \Drupal\Core\Entity\EntityInterface $node
|
||||
* The node entity being updated in response to a form submission.
|
||||
* @param $form
|
||||
* The form being used to edit the node.
|
||||
|
@ -832,7 +832,7 @@ function hook_node_validate(Drupal\node\Node $node, $form, &$form_state) {
|
|||
*
|
||||
* @ingroup node_api_hooks
|
||||
*/
|
||||
function hook_node_submit(Drupal\node\Node $node, $form, &$form_state) {
|
||||
function hook_node_submit(\Drupal\Core\Entity\EntityInterface $node, $form, &$form_state) {
|
||||
// Decompose the selected menu parent option into 'menu_name' and 'plid', if
|
||||
// the form used the default parent selection widget.
|
||||
if (!empty($form_state['values']['menu']['parent'])) {
|
||||
|
@ -852,7 +852,7 @@ function hook_node_submit(Drupal\node\Node $node, $form, &$form_state) {
|
|||
* the RSS item generated for this node.
|
||||
* For details on how this is used, see node_feed().
|
||||
*
|
||||
* @param \Drupal\node\Plugin\Core\Entity\Node $node
|
||||
* @param \Drupal\Core\Entity\EntityInterface $node
|
||||
* The node that is being assembled for rendering.
|
||||
* @param \Drupal\entity\Plugin\Core\Entity\EntityDisplay $display
|
||||
* The entity_display object holding the display options configured for the
|
||||
|
@ -868,7 +868,7 @@ function hook_node_submit(Drupal\node\Node $node, $form, &$form_state) {
|
|||
*
|
||||
* @ingroup node_api_hooks
|
||||
*/
|
||||
function hook_node_view(\Drupal\node\Plugin\Core\Entity\Node $node, \Drupal\entity\Plugin\Core\Entity\EntityDisplay $display, $view_mode, $langcode) {
|
||||
function hook_node_view(\Drupal\Core\Entity\EntityInterface $node, \Drupal\entity\Plugin\Core\Entity\EntityDisplay $display, $view_mode, $langcode) {
|
||||
// Only do the extra work if the component is configured to be displayed.
|
||||
// This assumes a 'mymodule_addition' extra field has been defined for the
|
||||
// node type in hook_field_extra_fields().
|
||||
|
@ -895,7 +895,7 @@ function hook_node_view(\Drupal\node\Plugin\Core\Entity\Node $node, \Drupal\enti
|
|||
*
|
||||
* @param $build
|
||||
* A renderable array representing the node content.
|
||||
* @param \Drupal\node\Plugin\Core\Entity\Node $node
|
||||
* @param \Drupal\Core\Entity\EntityInterface $node
|
||||
* The node being rendered.
|
||||
* @param \Drupal\entity\Plugin\Core\Entity\EntityDisplay $display
|
||||
* The entity_display object holding the display options configured for the
|
||||
|
@ -906,7 +906,7 @@ function hook_node_view(\Drupal\node\Plugin\Core\Entity\Node $node, \Drupal\enti
|
|||
*
|
||||
* @ingroup node_api_hooks
|
||||
*/
|
||||
function hook_node_view_alter(&$build, \Drupal\node\Plugin\Core\Entity\Node $node, \Drupal\entity\Plugin\Core\Entity\EntityDisplay $display) {
|
||||
function hook_node_view_alter(&$build, \Drupal\Core\Entity\EntityInterface $node, \Drupal\entity\Plugin\Core\Entity\EntityDisplay $display) {
|
||||
if ($build['#view_mode'] == 'full' && isset($build['an_additional_field'])) {
|
||||
// Change its weight.
|
||||
$build['an_additional_field']['#weight'] = -10;
|
||||
|
@ -1088,12 +1088,12 @@ function hook_node_type_delete($info) {
|
|||
* removed from the node table in the database, before hook_node_delete() is
|
||||
* invoked, and before field_attach_delete() is called.
|
||||
*
|
||||
* @param Drupal\node\Node $node
|
||||
* @param \Drupal\Core\Entity\EntityInterface $node
|
||||
* The node that is being deleted.
|
||||
*
|
||||
* @ingroup node_api_hooks
|
||||
*/
|
||||
function hook_delete(Drupal\node\Node $node) {
|
||||
function hook_delete(\Drupal\Core\Entity\EntityInterface $node) {
|
||||
db_delete('mytable')
|
||||
->condition('nid', $node->nid)
|
||||
->execute();
|
||||
|
@ -1108,12 +1108,12 @@ function hook_delete(Drupal\node\Node $node) {
|
|||
* This hook is invoked from NodeFormController::prepareEntity() before the
|
||||
* general hook_node_prepare() is invoked.
|
||||
*
|
||||
* @param Drupal\node\Node $node
|
||||
* @param \Drupal\Core\Entity\EntityInterface $node
|
||||
* The node that is about to be shown on the add/edit form.
|
||||
*
|
||||
* @ingroup node_api_hooks
|
||||
*/
|
||||
function hook_prepare(Drupal\node\Node $node) {
|
||||
function hook_prepare(\Drupal\Core\Entity\EntityInterface $node) {
|
||||
if ($file = file_check_upload($field_name)) {
|
||||
$file = file_save_upload($field_name, _image_filename($file->filename, NULL, TRUE));
|
||||
if ($file) {
|
||||
|
@ -1144,7 +1144,7 @@ function hook_prepare(Drupal\node\Node $node) {
|
|||
* displayed automatically by the node module. This hook just needs to
|
||||
* return the node title and form editing fields specific to the node type.
|
||||
*
|
||||
* @param Drupal\node\Node $node
|
||||
* @param \Drupal\Core\Entity\EntityInterface $node
|
||||
* The node being added or edited.
|
||||
* @param $form_state
|
||||
* The form state array.
|
||||
|
@ -1155,7 +1155,7 @@ function hook_prepare(Drupal\node\Node $node) {
|
|||
*
|
||||
* @ingroup node_api_hooks
|
||||
*/
|
||||
function hook_form(Drupal\node\Node $node, &$form_state) {
|
||||
function hook_form(\Drupal\Core\Entity\EntityInterface $node, &$form_state) {
|
||||
$type = node_type_load($node->type);
|
||||
|
||||
$form['title'] = array(
|
||||
|
@ -1196,12 +1196,12 @@ function hook_form(Drupal\node\Node $node, &$form_state) {
|
|||
* node table in the database, before field_attach_insert() is called, and
|
||||
* before hook_node_insert() is invoked.
|
||||
*
|
||||
* @param Drupal\node\Node $node
|
||||
* @param \Drupal\Core\Entity\EntityInterface $node
|
||||
* The node that is being created.
|
||||
*
|
||||
* @ingroup node_api_hooks
|
||||
*/
|
||||
function hook_insert(Drupal\node\Node $node) {
|
||||
function hook_insert(\Drupal\Core\Entity\EntityInterface $node) {
|
||||
db_insert('mytable')
|
||||
->fields(array(
|
||||
'nid' => $node->nid,
|
||||
|
@ -1255,12 +1255,12 @@ function hook_load($nodes) {
|
|||
* node table in the database, before field_attach_update() is called, and
|
||||
* before hook_node_update() is invoked.
|
||||
*
|
||||
* @param Drupal\node\Node $node
|
||||
* @param \Drupal\Core\Entity\EntityInterface $node
|
||||
* The node that is being updated.
|
||||
*
|
||||
* @ingroup node_api_hooks
|
||||
*/
|
||||
function hook_update(Drupal\node\Node $node) {
|
||||
function hook_update(\Drupal\Core\Entity\EntityInterface $node) {
|
||||
db_update('mytable')
|
||||
->fields(array('extra' => $node->extra))
|
||||
->condition('nid', $node->nid)
|
||||
|
@ -1284,7 +1284,7 @@ function hook_update(Drupal\node\Node $node) {
|
|||
* have no effect. The preferred method to change a node's content is to use
|
||||
* hook_node_presave() instead.
|
||||
*
|
||||
* @param Drupal\node\Node $node
|
||||
* @param \Drupal\Core\Entity\EntityInterface $node
|
||||
* The node being validated.
|
||||
* @param $form
|
||||
* The form being used to edit the node.
|
||||
|
@ -1293,7 +1293,7 @@ function hook_update(Drupal\node\Node $node) {
|
|||
*
|
||||
* @ingroup node_api_hooks
|
||||
*/
|
||||
function hook_validate(Drupal\node\Node $node, $form, &$form_state) {
|
||||
function hook_validate(\Drupal\Core\Entity\EntityInterface $node, $form, &$form_state) {
|
||||
if (isset($node->end) && isset($node->start)) {
|
||||
if ($node->start > $node->end) {
|
||||
form_set_error('time', t('An event may not end before it starts.'));
|
||||
|
@ -1311,7 +1311,7 @@ function hook_validate(Drupal\node\Node $node, $form, &$form_state) {
|
|||
* that the node type module can define a custom method for display, or add to
|
||||
* the default display.
|
||||
*
|
||||
* @param \Drupal\node\Plugin\Core\Entity\Node $node
|
||||
* @param \Drupal\Core\Entity\EntityInterface $node
|
||||
* The node to be displayed, as returned by node_load().
|
||||
* @param \Drupal\entity\Plugin\Core\Entity\EntityDisplay $display
|
||||
* The entity_display object holding the display options configured for the
|
||||
|
@ -1332,7 +1332,7 @@ function hook_validate(Drupal\node\Node $node, $form, &$form_state) {
|
|||
*
|
||||
* @ingroup node_api_hooks
|
||||
*/
|
||||
function hook_view(\Drupal\node\Plugin\Core\Entity\Node $node, \Drupal\entity\Plugin\Core\Entity\EntityDisplay $display, $view_mode) {
|
||||
function hook_view(\Drupal\Core\Entity\EntityInterface $node, \Drupal\entity\Plugin\Core\Entity\EntityDisplay $display, $view_mode) {
|
||||
if ($view_mode == 'full' && node_is_page($node)) {
|
||||
$breadcrumb = array();
|
||||
$breadcrumb[] = l(t('Home'), NULL);
|
||||
|
|
|
@ -15,11 +15,10 @@ use Drupal\Core\Database\Query\AlterableInterface;
|
|||
use Drupal\Core\Database\Query\SelectExtender;
|
||||
use Drupal\Core\Database\Query\SelectInterface;
|
||||
use Drupal\Core\Datetime\DrupalDateTime;
|
||||
use Drupal\Core\Template\Attribute;
|
||||
use Drupal\node\Plugin\Core\Entity\Node;
|
||||
use Drupal\file\Plugin\Core\Entity\File;
|
||||
use Drupal\Core\Entity\EntityInterface;
|
||||
use Drupal\Core\Template\Attribute;
|
||||
use Drupal\entity\Plugin\Core\Entity\EntityDisplay;
|
||||
use Drupal\file\Plugin\Core\Entity\File;
|
||||
|
||||
/**
|
||||
* Denotes that the node is not published.
|
||||
|
@ -255,15 +254,15 @@ function node_entity_display_alter(EntityDisplay $display, $context) {
|
|||
/**
|
||||
* Entity URI callback.
|
||||
*
|
||||
* @param Drupal\node\Node $node
|
||||
* @param \Drupal\Core\Entity\EntityInterface $node
|
||||
* A node entity.
|
||||
*
|
||||
* @return array
|
||||
* An array with 'path' as the key and the path to the node as its value.
|
||||
*/
|
||||
function node_uri(Node $node) {
|
||||
function node_uri(EntityInterface $node) {
|
||||
return array(
|
||||
'path' => 'node/' . $node->nid,
|
||||
'path' => 'node/' . $node->nid->value,
|
||||
);
|
||||
}
|
||||
|
||||
|
@ -412,13 +411,13 @@ function node_type_get_label($name) {
|
|||
/**
|
||||
* Returns the node type label for the passed node.
|
||||
*
|
||||
* @param Drupal\node\Node $node
|
||||
* @param \Drupal\Core\Entity\EntityInterface $node
|
||||
* A node entity to return the node type's label for.
|
||||
*
|
||||
* @return string|false
|
||||
* The node type label or FALSE if the node type is not found.
|
||||
*/
|
||||
function node_get_type_label($node) {
|
||||
function node_get_type_label(EntityInterface $node) {
|
||||
$types = _node_types_build()->names;
|
||||
return isset($types[$node->type]) ? $types[$node->type] : FALSE;
|
||||
}
|
||||
|
@ -911,7 +910,7 @@ function node_hook($type, $hook) {
|
|||
/**
|
||||
* Invokes a node hook.
|
||||
*
|
||||
* @param Drupal\node\Node $node
|
||||
* @param \Drupal\Core\Entity\EntityInterface $node
|
||||
* A Node entity.
|
||||
* @param $hook
|
||||
* A string containing the name of the hook.
|
||||
|
@ -922,7 +921,7 @@ function node_hook($type, $hook) {
|
|||
* @return
|
||||
* The returned value of the invoked hook.
|
||||
*/
|
||||
function node_invoke($node, $hook, $a2 = NULL, $a3 = NULL, $a4 = NULL) {
|
||||
function node_invoke(EntityInterface $node, $hook, $a2 = NULL, $a3 = NULL, $a4 = NULL) {
|
||||
if ($function = node_hook($node->type, $hook)) {
|
||||
return $function($node, $a2, $a3, $a4);
|
||||
}
|
||||
|
@ -948,7 +947,12 @@ function node_invoke($node, $hook, $a2 = NULL, $a3 = NULL, $a4 = NULL) {
|
|||
* @see Drupal\Core\Entity\Query\EntityQueryInterface
|
||||
*/
|
||||
function node_load_multiple(array $nids = NULL, $reset = FALSE) {
|
||||
return entity_load_multiple('node', $nids, $reset);
|
||||
$entities = entity_load_multiple('node', $nids, $reset);
|
||||
// Return BC-entities.
|
||||
foreach ($entities as $id => $entity) {
|
||||
$entities[$id] = $entity->getBCEntity();
|
||||
}
|
||||
return $entities;
|
||||
}
|
||||
|
||||
/**
|
||||
|
@ -964,7 +968,8 @@ function node_load_multiple(array $nids = NULL, $reset = FALSE) {
|
|||
* A fully-populated node entity, or FALSE if the node is not found.
|
||||
*/
|
||||
function node_load($nid = NULL, $reset = FALSE) {
|
||||
return entity_load('node', $nid, $reset);
|
||||
$entity = entity_load('node', $nid, $reset);
|
||||
return $entity ? $entity->getBCEntity() : FALSE;
|
||||
}
|
||||
|
||||
/**
|
||||
|
@ -983,13 +988,13 @@ function node_revision_load($vid = NULL) {
|
|||
/**
|
||||
* Prepares a node for saving by populating the author and creation date.
|
||||
*
|
||||
* @param Drupal\node\Node $node
|
||||
* @param \Drupal\Core\Entity\EntityInterface $node
|
||||
* A node object.
|
||||
*
|
||||
* @return Drupal\node\Node
|
||||
* An updated node object.
|
||||
*/
|
||||
function node_submit(Node $node) {
|
||||
function node_submit(EntityInterface $node) {
|
||||
global $user;
|
||||
|
||||
// A user might assign the node author by entering a user name in the node
|
||||
|
@ -1017,11 +1022,11 @@ function node_submit(Node $node) {
|
|||
/**
|
||||
* Saves changes to a node or adds a new node.
|
||||
*
|
||||
* @param Drupal\node\Node $node
|
||||
* @param \Drupal\Core\Entity\EntityInterface $node
|
||||
* The $node entity to be saved. If $node->nid is
|
||||
* omitted (or $node->is_new is TRUE), a new node will be added.
|
||||
*/
|
||||
function node_save(Node $node) {
|
||||
function node_save(EntityInterface $node) {
|
||||
$node->save();
|
||||
}
|
||||
|
||||
|
@ -1064,7 +1069,7 @@ function node_revision_delete($revision_id) {
|
|||
/**
|
||||
* Page callback: Generates an array which displays a node detail page.
|
||||
*
|
||||
* @param Drupal\node\Node $node
|
||||
* @param \Drupal\Core\Entity\EntityInterface $node
|
||||
* A node entity.
|
||||
* @param $message
|
||||
* (optional) A flag which sets a page title relevant to the revision being
|
||||
|
@ -1075,7 +1080,7 @@ function node_revision_delete($revision_id) {
|
|||
*
|
||||
* @see node_menu()
|
||||
*/
|
||||
function node_show(Node $node, $message = FALSE) {
|
||||
function node_show(EntityInterface $node, $message = FALSE) {
|
||||
if ($message) {
|
||||
drupal_set_title(t('Revision of %title from %date', array('%title' => $node->label(), '%date' => format_date($node->revision_timestamp))), PASS_THROUGH);
|
||||
}
|
||||
|
@ -1094,13 +1099,13 @@ function node_show(Node $node, $message = FALSE) {
|
|||
/**
|
||||
* Checks whether the current page is the full page view of the passed-in node.
|
||||
*
|
||||
* @param Drupal\node\Node $node
|
||||
* @param \Drupal\Core\Entity\EntityInterface $node
|
||||
* A node entity.
|
||||
*
|
||||
* @return
|
||||
* The ID of the node if this is a full page view, otherwise FALSE.
|
||||
*/
|
||||
function node_is_page(Node $node) {
|
||||
function node_is_page(EntityInterface $node) {
|
||||
$page_node = menu_get_object();
|
||||
return (!empty($page_node) ? $page_node->nid == $node->nid : FALSE);
|
||||
}
|
||||
|
@ -1408,7 +1413,7 @@ function node_search_execute($keys = NULL, $conditions = NULL) {
|
|||
'type' => check_plain(node_get_type_label($node)),
|
||||
'title' => $node->label($item->langcode),
|
||||
'user' => theme('username', array('account' => $node)),
|
||||
'date' => $node->get('changed', $item->langcode),
|
||||
'date' => $node->changed,
|
||||
'node' => $node,
|
||||
'extra' => $extra,
|
||||
'score' => $item->calculated_score,
|
||||
|
@ -1539,7 +1544,7 @@ function theme_node_search_admin($variables) {
|
|||
/**
|
||||
* Access callback: Checks node revision access.
|
||||
*
|
||||
* @param Drupal\node\Node $node
|
||||
* @param \Drupal\Core\Entity\EntityInterface $node
|
||||
* The node to check.
|
||||
* @param $op
|
||||
* (optional) The specific operation being checked. Defaults to 'view.'
|
||||
|
@ -1557,7 +1562,7 @@ function theme_node_search_admin($variables) {
|
|||
*
|
||||
* @see node_menu()
|
||||
*/
|
||||
function _node_revision_access(Node $node, $op = 'view', $account = NULL, $langcode = NULL) {
|
||||
function _node_revision_access(EntityInterface $node, $op = 'view', $account = NULL, $langcode = NULL) {
|
||||
$access = &drupal_static(__FUNCTION__, array());
|
||||
|
||||
$map = array(
|
||||
|
@ -1839,7 +1844,7 @@ function node_type_page_title($type) {
|
|||
/**
|
||||
* Title callback: Displays the node's title.
|
||||
*
|
||||
* @param Drupal\node\Node $node
|
||||
* @param \Drupal\Core\Entity\EntityInterface $node
|
||||
* The node entity.
|
||||
*
|
||||
* @return
|
||||
|
@ -1847,7 +1852,7 @@ function node_type_page_title($type) {
|
|||
*
|
||||
* @see node_menu()
|
||||
*/
|
||||
function node_page_title(Node $node) {
|
||||
function node_page_title(EntityInterface $node) {
|
||||
return $node->label();
|
||||
}
|
||||
|
||||
|
@ -1867,13 +1872,13 @@ function node_last_changed($nid) {
|
|||
/**
|
||||
* Returns a list of all the existing revision numbers for the node passed in.
|
||||
*
|
||||
* @param Drupal\node\Node $node
|
||||
* @param \Drupal\Core\Entity\EntityInterface $node
|
||||
* The node entity.
|
||||
*
|
||||
* @return
|
||||
* An associative array keyed by node revision number.
|
||||
*/
|
||||
function node_revision_list(Node $node) {
|
||||
function node_revision_list(EntityInterface $node) {
|
||||
$revisions = array();
|
||||
$result = db_query('SELECT r.vid, r.title, r.log, r.uid, n.vid AS current_vid, r.timestamp, u.name FROM {node_revision} r LEFT JOIN {node} n ON n.vid = r.vid INNER JOIN {users} u ON u.uid = r.uid WHERE r.nid = :nid ORDER BY r.vid DESC', array(':nid' => $node->nid));
|
||||
foreach ($result as $revision) {
|
||||
|
@ -2148,7 +2153,7 @@ function node_feed($nids = FALSE, $channel = array()) {
|
|||
/**
|
||||
* Generates an array for rendering the given node.
|
||||
*
|
||||
* @param Drupal\node\Node $node
|
||||
* @param \Drupal\Core\Entity\EntityInterface $node
|
||||
* A node entity.
|
||||
* @param $view_mode
|
||||
* (optional) View mode, e.g., 'full', 'teaser'... Defaults to 'full.'
|
||||
|
@ -2159,7 +2164,7 @@ function node_feed($nids = FALSE, $channel = array()) {
|
|||
* @return
|
||||
* An array as expected by drupal_render().
|
||||
*/
|
||||
function node_view(Node $node, $view_mode = 'full', $langcode = NULL) {
|
||||
function node_view(EntityInterface $node, $view_mode = 'full', $langcode = NULL) {
|
||||
return entity_view($node, $view_mode, $langcode);
|
||||
}
|
||||
|
||||
|
@ -2184,7 +2189,7 @@ function node_view_multiple($nodes, $view_mode = 'teaser', $langcode = NULL) {
|
|||
/**
|
||||
* Page callback: Displays a single node.
|
||||
*
|
||||
* @param Drupal\node\Node $node
|
||||
* @param \Drupal\Core\Entity\EntityInterface $node
|
||||
* The node entity.
|
||||
*
|
||||
* @return
|
||||
|
@ -2192,7 +2197,7 @@ function node_view_multiple($nodes, $view_mode = 'teaser', $langcode = NULL) {
|
|||
*
|
||||
* @see node_menu()
|
||||
*/
|
||||
function node_page_view(Node $node) {
|
||||
function node_page_view(EntityInterface $node) {
|
||||
// If there is a menu link to this node, the link becomes the last part
|
||||
// of the active trail, and the link name becomes the page title.
|
||||
// Thus, we must explicitly set the page title to be the node title.
|
||||
|
@ -2233,10 +2238,10 @@ function node_update_index() {
|
|||
/**
|
||||
* Indexes a single node.
|
||||
*
|
||||
* @param Drupal\node\Node $node
|
||||
* @param \Drupal\Core\Entity\EntityInterface $node
|
||||
* The node to index.
|
||||
*/
|
||||
function _node_index_node(Node $node) {
|
||||
function _node_index_node(EntityInterface $node) {
|
||||
|
||||
// Save the changed time of the most recent indexed node, for the search
|
||||
// results half-life calculation.
|
||||
|
@ -2492,7 +2497,7 @@ function node_form_system_themes_admin_form_submit($form, &$form_state) {
|
|||
* - "update"
|
||||
* - "delete"
|
||||
* - "create"
|
||||
* @param Drupal\node\Node|string|stdClass $node
|
||||
* @param Drupal\Core\Entity\EntityInterface|string|stdClass $node
|
||||
* The node entity on which the operation is to be performed, or the node type
|
||||
* object, or node type string (e.g., 'forum') for the 'create' operation.
|
||||
* @param $account
|
||||
|
@ -2537,6 +2542,19 @@ function node_access($op, $node, $account = NULL, $langcode = NULL) {
|
|||
$langcode = (is_object($node) && isset($node->nid)) ? $node->langcode : '';
|
||||
}
|
||||
|
||||
// Fetch information from the node object if possible.
|
||||
$node_status = NULL;
|
||||
$node_uid = NULL;
|
||||
if (is_object($node)) {
|
||||
$node_status = (isset($node->status)) ? $node->status : $node_status;
|
||||
$node_uid = (isset($node->uid)) ? $node->uid : $node_uid;
|
||||
// If it is a proper EntityNG object, use the proper methods.
|
||||
if ($node instanceof \Drupal\Core\Entity\EntityNG){
|
||||
$node_status = $node->get('status', $langcode)->value;
|
||||
$node_uid = $node->get('uid', $langcode)->value ;
|
||||
}
|
||||
}
|
||||
|
||||
// If we've already checked access for this node, user and op, return from
|
||||
// cache.
|
||||
if (isset($rights[$account->uid][$cid][$langcode][$op])) {
|
||||
|
@ -2568,14 +2586,14 @@ function node_access($op, $node, $account = NULL, $langcode = NULL) {
|
|||
}
|
||||
|
||||
// Check if authors can view their own unpublished nodes.
|
||||
if ($op == 'view' && !$node->get('status', $langcode) && user_access('view own unpublished content', $account) && $account->uid == $node->get('uid', $langcode) && $account->uid != 0) {
|
||||
if ($op == 'view' && empty($node_status) && user_access('view own unpublished content', $account) && $account->uid === $node_uid && $account->uid != 0) {
|
||||
$rights[$account->uid][$cid][$langcode][$op] = TRUE;
|
||||
return TRUE;
|
||||
}
|
||||
|
||||
// If the module did not override the access rights, use those set in the
|
||||
// node_access table.
|
||||
if ($op != 'create' && $node->nid) {
|
||||
if ($op != 'create' && !empty($node->nid)) {
|
||||
if (module_implements('node_grants')) {
|
||||
$query = db_select('node_access');
|
||||
$query->addExpression('1');
|
||||
|
@ -2605,7 +2623,7 @@ function node_access($op, $node, $account = NULL, $langcode = NULL) {
|
|||
$rights[$account->uid][$cid][$langcode][$op] = $result;
|
||||
return $result;
|
||||
}
|
||||
elseif (is_object($node) && $op == 'view' && $node->get('status', $langcode)) {
|
||||
elseif (is_object($node) && $op == 'view' && !empty($node_status)) {
|
||||
// If no modules implement hook_node_grants(), the default behavior is to
|
||||
// allow all users to view published nodes, so reflect that here.
|
||||
$rights[$account->uid][$cid][$langcode][$op] = TRUE;
|
||||
|
@ -2919,13 +2937,13 @@ function node_query_node_access_alter(AlterableInterface $query) {
|
|||
* via hook_node_access_records_alter() implementations, and saves the collected
|
||||
* and altered grants to the database.
|
||||
*
|
||||
* @param Drupal\node\Node $node
|
||||
* @param \Drupal\Core\Entity\EntityInterface $node
|
||||
* The $node to acquire grants for.
|
||||
* @param $delete
|
||||
* (optional) Whether to delete existing node access records before inserting
|
||||
* new ones. Defaults to TRUE.
|
||||
*/
|
||||
function node_access_acquire_grants(Node $node, $delete = TRUE) {
|
||||
function node_access_acquire_grants(EntityInterface $node, $delete = TRUE) {
|
||||
$grants = module_invoke_all('node_access_records', $node);
|
||||
// Let modules alter the grants.
|
||||
drupal_alter('node_access_records', $grants, $node);
|
||||
|
@ -2947,7 +2965,7 @@ function node_access_acquire_grants(Node $node, $delete = TRUE) {
|
|||
* Note: Don't call this function directly from a contributed module. Call
|
||||
* node_access_acquire_grants() instead.
|
||||
*
|
||||
* @param Drupal\node\Node $node
|
||||
* @param \Drupal\Core\Entity\EntityInterface $node
|
||||
* The node whose grants are being written.
|
||||
* @param $grants
|
||||
* A list of grants to write. Each grant is an array that must contain the
|
||||
|
@ -2965,7 +2983,7 @@ function node_access_acquire_grants(Node $node, $delete = TRUE) {
|
|||
*
|
||||
* @see node_access_acquire_grants()
|
||||
*/
|
||||
function _node_access_write_grants(Node $node, $grants, $realm = NULL, $delete = TRUE) {
|
||||
function _node_access_write_grants(EntityInterface $node, $grants, $realm = NULL, $delete = TRUE) {
|
||||
if ($delete) {
|
||||
$query = db_delete('node_access')->condition('nid', $node->nid);
|
||||
if ($realm) {
|
||||
|
@ -3168,7 +3186,7 @@ function _node_access_rebuild_batch_finished($success, $results, $operations) {
|
|||
/**
|
||||
* Implements hook_form().
|
||||
*/
|
||||
function node_content_form(Node $node, $form_state) {
|
||||
function node_content_form(EntityInterface $node, $form_state) {
|
||||
// @todo It is impossible to define a content type without implementing
|
||||
// hook_form(). Remove this requirement.
|
||||
$form = array();
|
||||
|
@ -3264,7 +3282,7 @@ function node_action_info() {
|
|||
/**
|
||||
* Sets the status of a node to 1 (published).
|
||||
*
|
||||
* @param Drupal\node\Node $node
|
||||
* @param \Drupal\Core\Entity\EntityInterface $node
|
||||
* A node entity.
|
||||
* @param $context
|
||||
* (optional) Array of additional information about what triggered the action.
|
||||
|
@ -3272,7 +3290,7 @@ function node_action_info() {
|
|||
*
|
||||
* @ingroup actions
|
||||
*/
|
||||
function node_publish_action(Node $node, $context = array()) {
|
||||
function node_publish_action(EntityInterface $node, $context = array()) {
|
||||
$node->status = NODE_PUBLISHED;
|
||||
watchdog('action', 'Set @type %title to published.', array('@type' => node_get_type_label($node), '%title' => $node->label()));
|
||||
}
|
||||
|
@ -3280,7 +3298,7 @@ function node_publish_action(Node $node, $context = array()) {
|
|||
/**
|
||||
* Sets the status of a node to 0 (unpublished).
|
||||
*
|
||||
* @param Drupal\node\Node $node
|
||||
* @param \Drupal\Core\Entity\EntityInterface $node
|
||||
* A node entity.
|
||||
* @param $context
|
||||
* (optional) Array of additional information about what triggered the action.
|
||||
|
@ -3288,7 +3306,7 @@ function node_publish_action(Node $node, $context = array()) {
|
|||
*
|
||||
* @ingroup actions
|
||||
*/
|
||||
function node_unpublish_action(Node $node, $context = array()) {
|
||||
function node_unpublish_action(EntityInterface $node, $context = array()) {
|
||||
$node->status = NODE_NOT_PUBLISHED;
|
||||
watchdog('action', 'Set @type %title to unpublished.', array('@type' => node_get_type_label($node), '%title' => $node->label()));
|
||||
}
|
||||
|
@ -3296,7 +3314,7 @@ function node_unpublish_action(Node $node, $context = array()) {
|
|||
/**
|
||||
* Sets the sticky-at-top-of-list property of a node to 1.
|
||||
*
|
||||
* @param Drupal\node\Node $node
|
||||
* @param \Drupal\Core\Entity\EntityInterface $node
|
||||
* A node entity.
|
||||
* @param $context
|
||||
* (optional) Array of additional information about what triggered the action.
|
||||
|
@ -3304,7 +3322,7 @@ function node_unpublish_action(Node $node, $context = array()) {
|
|||
*
|
||||
* @ingroup actions
|
||||
*/
|
||||
function node_make_sticky_action(Node $node, $context = array()) {
|
||||
function node_make_sticky_action(EntityInterface $node, $context = array()) {
|
||||
$node->sticky = NODE_STICKY;
|
||||
watchdog('action', 'Set @type %title to sticky.', array('@type' => node_get_type_label($node), '%title' => $node->label()));
|
||||
}
|
||||
|
@ -3312,7 +3330,7 @@ function node_make_sticky_action(Node $node, $context = array()) {
|
|||
/**
|
||||
* Sets the sticky-at-top-of-list property of a node to 0.
|
||||
*
|
||||
* @param Drupal\node\Node $node
|
||||
* @param \Drupal\Core\Entity\EntityInterface $node
|
||||
* A node entity.
|
||||
* @param $context
|
||||
* (optional) Array of additional information about what triggered the action.
|
||||
|
@ -3320,7 +3338,7 @@ function node_make_sticky_action(Node $node, $context = array()) {
|
|||
*
|
||||
* @ingroup actions
|
||||
*/
|
||||
function node_make_unsticky_action(Node $node, $context = array()) {
|
||||
function node_make_unsticky_action(EntityInterface $node, $context = array()) {
|
||||
$node->sticky = NODE_NOT_STICKY;
|
||||
watchdog('action', 'Set @type %title to unsticky.', array('@type' => node_get_type_label($node), '%title' => $node->label()));
|
||||
}
|
||||
|
@ -3328,7 +3346,7 @@ function node_make_unsticky_action(Node $node, $context = array()) {
|
|||
/**
|
||||
* Sets the promote property of a node to 1.
|
||||
*
|
||||
* @param Drupal\node\Node $node
|
||||
* @param \Drupal\Core\Entity\EntityInterface $node
|
||||
* A node entity.
|
||||
* @param $context
|
||||
* (optional) Array of additional information about what triggered the action.
|
||||
|
@ -3336,7 +3354,7 @@ function node_make_unsticky_action(Node $node, $context = array()) {
|
|||
*
|
||||
* @ingroup actions
|
||||
*/
|
||||
function node_promote_action(Node $node, $context = array()) {
|
||||
function node_promote_action(EntityInterface $node, $context = array()) {
|
||||
$node->promote = NODE_PROMOTED;
|
||||
watchdog('action', 'Promoted @type %title to front page.', array('@type' => node_get_type_label($node), '%title' => $node->label()));
|
||||
}
|
||||
|
@ -3344,7 +3362,7 @@ function node_promote_action(Node $node, $context = array()) {
|
|||
/**
|
||||
* Sets the promote property of a node to 0.
|
||||
*
|
||||
* @param Drupal\node\Node $node
|
||||
* @param \Drupal\Core\Entity\EntityInterface $node
|
||||
* A node entity.
|
||||
* @param $context
|
||||
* (optional) Array of additional information about what triggered the action.
|
||||
|
@ -3352,7 +3370,7 @@ function node_promote_action(Node $node, $context = array()) {
|
|||
*
|
||||
* @ingroup actions
|
||||
*/
|
||||
function node_unpromote_action(Node $node, $context = array()) {
|
||||
function node_unpromote_action(EntityInterface $node, $context = array()) {
|
||||
$node->promote = NODE_NOT_PROMOTED;
|
||||
watchdog('action', 'Removed @type %title from front page.', array('@type' => node_get_type_label($node), '%title' => $node->label()));
|
||||
}
|
||||
|
@ -3360,12 +3378,12 @@ function node_unpromote_action(Node $node, $context = array()) {
|
|||
/**
|
||||
* Saves a node.
|
||||
*
|
||||
* @param Drupal\node\Node $node
|
||||
* @param \Drupal\Core\Entity\EntityInterface $node
|
||||
* The node to be saved.
|
||||
*
|
||||
* @ingroup actions
|
||||
*/
|
||||
function node_save_action(Node $node) {
|
||||
function node_save_action(EntityInterface $node) {
|
||||
$node->save();
|
||||
watchdog('action', 'Saved @type %title', array('@type' => node_get_type_label($node), '%title' => $node->label()));
|
||||
}
|
||||
|
@ -3373,7 +3391,7 @@ function node_save_action(Node $node) {
|
|||
/**
|
||||
* Assigns ownership of a node to a user.
|
||||
*
|
||||
* @param Drupal\node\Node $node
|
||||
* @param \Drupal\Core\Entity\EntityInterface $node
|
||||
* A node entity to modify.
|
||||
* @param $context
|
||||
* Array of additional information about what triggered the action. Includes
|
||||
|
@ -3385,7 +3403,7 @@ function node_save_action(Node $node) {
|
|||
* @see node_assign_owner_action_submit()
|
||||
* @ingroup actions
|
||||
*/
|
||||
function node_assign_owner_action(Node $node, $context) {
|
||||
function node_assign_owner_action(EntityInterface $node, $context) {
|
||||
$node->uid = $context['owner_uid'];
|
||||
$owner_name = db_query("SELECT name FROM {users} WHERE uid = :uid", array(':uid' => $context['owner_uid']))->fetchField();
|
||||
watchdog('action', 'Changed owner of @type %title to uid %name.', array('@type' => node_get_type_label($node), '%title' => $node->label(), '%name' => $owner_name));
|
||||
|
@ -3494,7 +3512,7 @@ function node_unpublish_by_keyword_action_submit($form, $form_state) {
|
|||
/**
|
||||
* Unpublishes a node containing certain keywords.
|
||||
*
|
||||
* @param Drupal\node\Node $node
|
||||
* @param \Drupal\Core\Entity\EntityInterface $node
|
||||
* A node entity to modify.
|
||||
* @param $context
|
||||
* Array of additional information about what triggered the action. Includes
|
||||
|
@ -3507,7 +3525,7 @@ function node_unpublish_by_keyword_action_submit($form, $form_state) {
|
|||
*
|
||||
* @ingroup actions
|
||||
*/
|
||||
function node_unpublish_by_keyword_action(Node $node, $context) {
|
||||
function node_unpublish_by_keyword_action(EntityInterface $node, $context) {
|
||||
foreach ($context['keywords'] as $keyword) {
|
||||
$elements = node_view(clone $node);
|
||||
if (strpos(drupal_render($elements), $keyword) !== FALSE || strpos($node->label(), $keyword) !== FALSE) {
|
||||
|
|
|
@ -9,7 +9,7 @@
|
|||
* @see node_menu()
|
||||
*/
|
||||
|
||||
use Drupal\node\Plugin\Core\Entity\Node;
|
||||
use Drupal\Core\Entity\EntityInterface;
|
||||
|
||||
/**
|
||||
* Page callback: Presents the node editing form.
|
||||
|
@ -106,7 +106,7 @@ function node_add($node_type) {
|
|||
'name' => (isset($user->name) ? $user->name : ''),
|
||||
'type' => $type,
|
||||
'langcode' => $langcode ? $langcode : language_default()->langcode,
|
||||
));
|
||||
))->getBCEntity();
|
||||
drupal_set_title(t('Create @name', array('@name' => $node_type->name)), PASS_THROUGH);
|
||||
$output = entity_get_form($node);
|
||||
|
||||
|
@ -116,7 +116,7 @@ function node_add($node_type) {
|
|||
/**
|
||||
* Generates a node preview.
|
||||
*
|
||||
* @param Drupal\node\Node $node
|
||||
* @param \Drupal\Core\Entity\EntityInterface $node
|
||||
* The node to preview.
|
||||
*
|
||||
* @return
|
||||
|
@ -124,7 +124,7 @@ function node_add($node_type) {
|
|||
*
|
||||
* @see node_form_build_preview()
|
||||
*/
|
||||
function node_preview(Node $node) {
|
||||
function node_preview(EntityInterface $node) {
|
||||
if (node_access('create', $node) || node_access('update', $node)) {
|
||||
_field_invoke_multiple('load', 'node', array($node->nid => $node));
|
||||
// Load the user's name when needed.
|
||||
|
|
|
@ -9,7 +9,7 @@
|
|||
* a special 'node test view' permission.
|
||||
*/
|
||||
|
||||
use Drupal\node\Plugin\Core\Entity\Node;
|
||||
use Drupal\Core\Entity\EntityInterface;
|
||||
|
||||
/**
|
||||
* Implements hook_node_grants().
|
||||
|
@ -32,7 +32,7 @@ function node_access_test_node_grants($account, $op) {
|
|||
/**
|
||||
* Implements hook_node_access_records().
|
||||
*/
|
||||
function node_access_test_node_access_records(Node $node) {
|
||||
function node_access_test_node_access_records(EntityInterface $node) {
|
||||
$grants = array();
|
||||
// For NodeAccessBaseTableTestCase, only set records for private nodes.
|
||||
if (!state()->get('node_access_test.private') || $node->private) {
|
||||
|
@ -207,28 +207,28 @@ function node_access_test_node_load($nodes, $types) {
|
|||
* Implements hook_node_predelete().
|
||||
*/
|
||||
|
||||
function node_access_test_node_predelete(Node $node) {
|
||||
function node_access_test_node_predelete(EntityInterface $node) {
|
||||
db_delete('node_access_test')->condition('nid', $node->nid)->execute();
|
||||
}
|
||||
|
||||
/**
|
||||
* Implements hook_node_insert().
|
||||
*/
|
||||
function node_access_test_node_insert(Node $node) {
|
||||
function node_access_test_node_insert(EntityInterface $node) {
|
||||
_node_access_test_node_write($node);
|
||||
}
|
||||
|
||||
/**
|
||||
* Implements hook_nodeapi_update().
|
||||
*/
|
||||
function node_access_test_node_update(Node $node) {
|
||||
function node_access_test_node_update(EntityInterface $node) {
|
||||
_node_access_test_node_write($node);
|
||||
}
|
||||
|
||||
/**
|
||||
* Helper for node insert/update.
|
||||
*/
|
||||
function _node_access_test_node_write(Node $node) {
|
||||
function _node_access_test_node_write(EntityInterface $node) {
|
||||
if (isset($node->private)) {
|
||||
db_merge('node_access_test')
|
||||
->key(array('nid' => $node->nid))
|
||||
|
|
|
@ -8,7 +8,7 @@
|
|||
* interaction with the Node module.
|
||||
*/
|
||||
|
||||
use Drupal\node\Plugin\Core\Entity\Node;
|
||||
use Drupal\Core\Entity\EntityInterface;
|
||||
use Drupal\entity\Plugin\Core\Entity\EntityDisplay;
|
||||
|
||||
/**
|
||||
|
@ -30,7 +30,7 @@ function node_test_node_load($nodes, $types) {
|
|||
/**
|
||||
* Implements hook_node_view().
|
||||
*/
|
||||
function node_test_node_view(Node $node, EntityDisplay $display, $view_mode) {
|
||||
function node_test_node_view(EntityInterface $node, EntityDisplay $display, $view_mode) {
|
||||
if ($view_mode == 'rss') {
|
||||
// Add RSS elements and namespaces when building the RSS feed.
|
||||
$node->rss_elements[] = array(
|
||||
|
@ -71,7 +71,7 @@ function node_test_node_grants($account, $op) {
|
|||
/**
|
||||
* Implements hook_node_access_records().
|
||||
*/
|
||||
function node_test_node_access_records(Node $node) {
|
||||
function node_test_node_access_records(EntityInterface $node) {
|
||||
// Return nothing when testing for empty responses.
|
||||
if (!empty($node->disable_node_access)) {
|
||||
return;
|
||||
|
@ -105,7 +105,7 @@ function node_test_node_access_records(Node $node) {
|
|||
/**
|
||||
* Implements hook_node_access_records_alter().
|
||||
*/
|
||||
function node_test_node_access_records_alter(&$grants, Node $node) {
|
||||
function node_test_node_access_records_alter(&$grants, EntityInterface $node) {
|
||||
if (!empty($grants)) {
|
||||
foreach ($grants as $key => $grant) {
|
||||
// Alter grant from test_page_realm to test_alter_realm and modify the gid.
|
||||
|
@ -128,7 +128,7 @@ function node_test_node_grants_alter(&$grants, $account, $op) {
|
|||
/**
|
||||
* Implements hook_node_presave().
|
||||
*/
|
||||
function node_test_node_presave(Node $node) {
|
||||
function node_test_node_presave(EntityInterface $node) {
|
||||
if ($node->title == 'testing_node_presave') {
|
||||
// Sun, 19 Nov 1978 05:00:00 GMT
|
||||
$node->created = 280299600;
|
||||
|
@ -146,7 +146,7 @@ function node_test_node_presave(Node $node) {
|
|||
/**
|
||||
* Implements hook_node_update().
|
||||
*/
|
||||
function node_test_node_update(Node $node) {
|
||||
function node_test_node_update(EntityInterface $node) {
|
||||
// Determine changes on update.
|
||||
if (!empty($node->original) && $node->original->title == 'test_changes') {
|
||||
if ($node->original->title != $node->title) {
|
||||
|
@ -173,7 +173,7 @@ function node_test_entity_view_mode_alter(&$view_mode, Drupal\Core\Entity\Entity
|
|||
*
|
||||
* @see \Drupal\node\Tests\NodeSaveTest::testNodeSaveOnInsert()
|
||||
*/
|
||||
function node_test_node_insert(Node $node) {
|
||||
function node_test_node_insert(EntityInterface $node) {
|
||||
// Set the node title to the node ID and save.
|
||||
if ($node->title == 'new') {
|
||||
$node->title = 'Node '. $node->nid;
|
||||
|
|
|
@ -5,12 +5,12 @@
|
|||
* A module implementing node related hooks to test API interaction.
|
||||
*/
|
||||
|
||||
use Drupal\node\Plugin\Core\Entity\Node;
|
||||
use Drupal\Core\Entity\EntityInterface;
|
||||
|
||||
/**
|
||||
* Implements hook_node_insert().
|
||||
*/
|
||||
function node_test_exception_node_insert(Node $node) {
|
||||
function node_test_exception_node_insert(EntityInterface $node) {
|
||||
if ($node->title == 'testing_transaction_exception') {
|
||||
throw new Exception('Test exception for rollback.');
|
||||
}
|
||||
|
|
|
@ -70,7 +70,7 @@ class OptionsFieldUITest extends FieldTestBase {
|
|||
// Create a node with actual data for the field.
|
||||
$settings = array(
|
||||
'type' => $this->type,
|
||||
$this->field_name => array(LANGUAGE_NOT_SPECIFIED => array(array('value' => 1))),
|
||||
$this->field_name =>array(array('value' => 1)),
|
||||
);
|
||||
$node = $this->drupalCreateNode($settings);
|
||||
|
||||
|
@ -120,7 +120,7 @@ class OptionsFieldUITest extends FieldTestBase {
|
|||
// Create a node with actual data for the field.
|
||||
$settings = array(
|
||||
'type' => $this->type,
|
||||
$this->field_name => array(LANGUAGE_NOT_SPECIFIED => array(array('value' => .5))),
|
||||
$this->field_name => array(array('value' => .5)),
|
||||
);
|
||||
$node = $this->drupalCreateNode($settings);
|
||||
|
||||
|
@ -172,7 +172,7 @@ class OptionsFieldUITest extends FieldTestBase {
|
|||
// Create a node with actual data for the field.
|
||||
$settings = array(
|
||||
'type' => $this->type,
|
||||
$this->field_name => array(LANGUAGE_NOT_SPECIFIED => array(array('value' => 'One'))),
|
||||
$this->field_name => array(array('value' => 'One')),
|
||||
);
|
||||
$node = $this->drupalCreateNode($settings);
|
||||
|
||||
|
|
|
@ -5,7 +5,7 @@
|
|||
* Enables users to rename URLs.
|
||||
*/
|
||||
|
||||
use Drupal\node\Plugin\Core\Entity\Node;
|
||||
use Drupal\Core\Entity\EntityInterface;
|
||||
|
||||
use Drupal\taxonomy\Plugin\Core\Entity\Term;
|
||||
|
||||
|
@ -186,7 +186,7 @@ function path_form_element_validate($element, &$form_state, $complete_form) {
|
|||
/**
|
||||
* Implements hook_node_insert().
|
||||
*/
|
||||
function path_node_insert(Node $node) {
|
||||
function path_node_insert(EntityInterface $node) {
|
||||
if (isset($node->path)) {
|
||||
$alias = trim($node->path['alias']);
|
||||
// Only save a non-empty alias.
|
||||
|
@ -202,7 +202,7 @@ function path_node_insert(Node $node) {
|
|||
/**
|
||||
* Implements hook_node_update().
|
||||
*/
|
||||
function path_node_update(Node $node) {
|
||||
function path_node_update(EntityInterface $node) {
|
||||
if (isset($node->path)) {
|
||||
$path = $node->path;
|
||||
$alias = trim($path['alias']);
|
||||
|
@ -223,7 +223,7 @@ function path_node_update(Node $node) {
|
|||
/**
|
||||
* Implements hook_node_predelete().
|
||||
*/
|
||||
function path_node_predelete(Node $node) {
|
||||
function path_node_predelete(EntityInterface $node) {
|
||||
// Delete all aliases associated with this node.
|
||||
drupal_container()->get('path.crud')->delete(array('source' => 'node/' . $node->nid));
|
||||
}
|
||||
|
|
|
@ -58,6 +58,6 @@ abstract class PhpTestBase extends WebTestBase {
|
|||
* @return stdObject Node object.
|
||||
*/
|
||||
function createNodeWithCode() {
|
||||
return $this->drupalCreateNode(array('body' => array(LANGUAGE_NOT_SPECIFIED => array(array('value' => '<?php print "SimpleTest PHP was executed!"; ?>')))));
|
||||
return $this->drupalCreateNode(array('body' => array(array('value' => '<?php print "SimpleTest PHP was executed!"; ?>'))));
|
||||
}
|
||||
}
|
||||
|
|
|
@ -7,7 +7,7 @@
|
|||
|
||||
namespace Drupal\rdf\Tests;
|
||||
|
||||
use Drupal\node\Plugin\Core\Entity\Node;
|
||||
use Drupal\Core\Entity\EntityInterface;
|
||||
use Drupal\simpletest\WebTestBase;
|
||||
|
||||
/**
|
||||
|
@ -71,10 +71,10 @@ class TrackerAttributesTest extends WebTestBase {
|
|||
*
|
||||
* Tests the tracker page for RDFa markup.
|
||||
*
|
||||
* @param Node $node
|
||||
* @param \Drupal\Core\Entity\EntityInterface $node
|
||||
* The node just created.
|
||||
*/
|
||||
function _testBasicTrackerRdfaMarkup(Node $node) {
|
||||
function _testBasicTrackerRdfaMarkup(EntityInterface $node) {
|
||||
$node_uri = url('node/' . $node->nid, array('absolute' => TRUE));
|
||||
$user_uri = url('user/' . $node->uid, array('absolute' => TRUE));
|
||||
|
||||
|
|
|
@ -787,9 +787,9 @@ function rdf_field_attach_view_alter(&$output, $context) {
|
|||
foreach ($element['#items'] as $delta => $item) {
|
||||
// This function is invoked during entity preview when taxonomy term
|
||||
// reference items might contain free-tagging terms that do not exist
|
||||
// yet and thus have no $item['taxonomy_term'].
|
||||
if (isset($item['taxonomy_term'])) {
|
||||
$term = $item['taxonomy_term'];
|
||||
// yet and thus have no $item['entity'].
|
||||
if (isset($item['entity'])) {
|
||||
$term = $item['entity'];
|
||||
if (!empty($term->rdf_mapping['rdftype'])) {
|
||||
$element[$delta]['#options']['attributes']['typeof'] = $term->rdf_mapping['rdftype'];
|
||||
}
|
||||
|
|
|
@ -142,7 +142,7 @@ abstract class RESTTestBase extends WebTestBase {
|
|||
'field_test_text' => array(0 => array('value' => $this->randomString())),
|
||||
);
|
||||
case 'node':
|
||||
return array('title' => $this->randomString());
|
||||
return array('title' => $this->randomString(), 'type' => $this->randomString());
|
||||
case 'user':
|
||||
return array('name' => $this->randomName());
|
||||
default:
|
||||
|
|
|
@ -47,7 +47,7 @@ class SearchCommentCountToggleTest extends SearchTestBase {
|
|||
$this->searching_user = $this->drupalCreateUser(array('search content', 'access content', 'access comments', 'skip comment approval'));
|
||||
|
||||
// Create initial nodes.
|
||||
$node_params = array('type' => 'article', 'body' => array(LANGUAGE_NOT_SPECIFIED => array(array('value' => 'SearchCommentToggleTestCase'))));
|
||||
$node_params = array('type' => 'article', 'body' => array(array('value' => 'SearchCommentToggleTestCase')));
|
||||
|
||||
$this->searchable_nodes['1 comment'] = $this->drupalCreateNode($node_params);
|
||||
$this->searchable_nodes['0 comments'] = $this->drupalCreateNode($node_params);
|
||||
|
|
|
@ -221,7 +221,7 @@ class SearchCommentTest extends SearchTestBase {
|
|||
$settings = array(
|
||||
'type' => 'article',
|
||||
'title' => 'short title',
|
||||
'body' => array(LANGUAGE_NOT_SPECIFIED => array(array('value' => 'short body text'))),
|
||||
'body' => array(array('value' => 'short body text')),
|
||||
);
|
||||
|
||||
$user = $this->drupalCreateUser(array('search content', 'create article content', 'access content'));
|
||||
|
|
|
@ -32,12 +32,12 @@ class SearchExactTest extends SearchTestBase {
|
|||
);
|
||||
// Create nodes with exact phrase.
|
||||
for ($i = 0; $i <= 17; $i++) {
|
||||
$settings['body'] = array(LANGUAGE_NOT_SPECIFIED => array(array('value' => 'love pizza')));
|
||||
$settings['body'] = array(array('value' => 'love pizza'));
|
||||
$this->drupalCreateNode($settings);
|
||||
}
|
||||
// Create nodes containing keywords.
|
||||
for ($i = 0; $i <= 17; $i++) {
|
||||
$settings['body'] = array(LANGUAGE_NOT_SPECIFIED => array(array('value' => 'love cheesy pizza')));
|
||||
$settings['body'] = array(array('value' => 'love cheesy pizza'));
|
||||
$this->drupalCreateNode($settings);
|
||||
}
|
||||
|
||||
|
|
|
@ -57,33 +57,35 @@ class SearchMultilingualEntityTest extends SearchTestBase {
|
|||
$nodes = array(
|
||||
array(
|
||||
'type' => 'page',
|
||||
'body' => array(
|
||||
'en' => array(array('value' => $this->randomName(32), 'format' => $default_format)),
|
||||
),
|
||||
'body' => array(array('value' => $this->randomName(32), 'format' => $default_format)),
|
||||
'langcode' => 'en',
|
||||
),
|
||||
array(
|
||||
'type' => 'page',
|
||||
'body' => array(
|
||||
'en' => array(array('value' => $this->randomName(32), 'format' => $default_format)),
|
||||
'hu' => array(array('value' => $this->randomName(32), 'format' => $default_format)),
|
||||
),
|
||||
'body' => array(array('value' => $this->randomName(32), 'format' => $default_format)),
|
||||
'langcode' => 'en',
|
||||
),
|
||||
array(
|
||||
'type' => 'page',
|
||||
'body' => array(
|
||||
'en' => array(array('value' => $this->randomName(32), 'format' => $default_format)),
|
||||
'hu' => array(array('value' => $this->randomName(32), 'format' => $default_format)),
|
||||
'sv' => array(array('value' => $this->randomName(32), 'format' => $default_format)),
|
||||
),
|
||||
'body' => array(array('value' => $this->randomName(32), 'format' => $default_format)),
|
||||
'langcode' => 'en',
|
||||
),
|
||||
);
|
||||
$this->searchable_nodes = array();
|
||||
foreach ($nodes as $node) {
|
||||
$this->searchable_nodes[] = $this->drupalCreateNode($node);
|
||||
foreach ($nodes as $setting) {
|
||||
$this->searchable_nodes[] = $this->drupalCreateNode($setting);
|
||||
}
|
||||
// Add a single translation to the second node.
|
||||
$translation = $this->searchable_nodes[1]->getTranslation('hu');
|
||||
$translation->body->value = $this->randomName(32);
|
||||
$this->searchable_nodes[1]->save();
|
||||
|
||||
// Add two translations to the third node.
|
||||
$translation = $this->searchable_nodes[2]->getTranslation('hu');
|
||||
$translation->body->value = $this->randomName(32);
|
||||
$translation = $this->searchable_nodes[2]->getTranslation('sv');
|
||||
$translation->body->value = $this->randomName(32);
|
||||
$this->searchable_nodes[2]->save();
|
||||
}
|
||||
|
||||
/**
|
||||
|
|
|
@ -42,7 +42,7 @@ class SearchNodeAccessTest extends SearchTestBase {
|
|||
* Tests that search returns results with punctuation in the search phrase.
|
||||
*/
|
||||
function testPhraseSearchPunctuation() {
|
||||
$node = $this->drupalCreateNode(array('body' => array(LANGUAGE_NOT_SPECIFIED => array(array('value' => "The bunny's ears were fluffy.")))));
|
||||
$node = $this->drupalCreateNode(array('body' => array(array('value' => "The bunny's ears were fluffy."))));
|
||||
|
||||
// Update the search index.
|
||||
module_invoke_all('update_index');
|
||||
|
|
|
@ -45,7 +45,7 @@ class SearchNumberMatchingTest extends SearchTestBase {
|
|||
|
||||
foreach ($this->numbers as $num) {
|
||||
$info = array(
|
||||
'body' => array(LANGUAGE_NOT_SPECIFIED => array(array('value' => $num))),
|
||||
'body' => array(array('value' => $num)),
|
||||
'type' => 'page',
|
||||
'language' => LANGUAGE_NOT_SPECIFIED,
|
||||
);
|
||||
|
|
|
@ -51,7 +51,7 @@ class SearchNumbersTest extends SearchTestBase {
|
|||
|
||||
foreach ($this->numbers as $doc => $num) {
|
||||
$info = array(
|
||||
'body' => array(LANGUAGE_NOT_SPECIFIED => array(array('value' => $num))),
|
||||
'body' => array(array('value' => $num)),
|
||||
'type' => 'page',
|
||||
'language' => LANGUAGE_NOT_SPECIFIED,
|
||||
'title' => $doc . ' number',
|
||||
|
|
|
@ -43,7 +43,7 @@ class SearchPreprocessLangcodeTest extends SearchTestBase {
|
|||
*/
|
||||
function testPreprocessLangcode() {
|
||||
// Create a node.
|
||||
$node = $this->drupalCreateNode(array('body' => array('en' => array(array())), 'langcode' => 'en'));
|
||||
$node = $this->drupalCreateNode(array('body' => array(array()), 'langcode' => 'en'));
|
||||
|
||||
// First update the index. This does the initial processing.
|
||||
node_update_index();
|
||||
|
@ -68,7 +68,7 @@ class SearchPreprocessLangcodeTest extends SearchTestBase {
|
|||
// Create a node.
|
||||
$node = $this->drupalCreateNode(array(
|
||||
'title' => 'we are testing',
|
||||
'body' => array('en' => array(array())),
|
||||
'body' => array(array()),
|
||||
'langcode' => 'en',
|
||||
));
|
||||
|
||||
|
|
|
@ -36,7 +36,7 @@ class SearchRankingTest extends SearchTestBase {
|
|||
$settings = array(
|
||||
'type' => 'page',
|
||||
'title' => 'Drupal rocks',
|
||||
'body' => array(LANGUAGE_NOT_SPECIFIED => array(array('value' => "Drupal's search rocks"))),
|
||||
'body' => array(array('value' => "Drupal's search rocks")),
|
||||
);
|
||||
foreach (array(0, 1) as $num) {
|
||||
if ($num == 1) {
|
||||
|
@ -46,7 +46,7 @@ class SearchRankingTest extends SearchTestBase {
|
|||
$settings[$node_rank] = 1;
|
||||
break;
|
||||
case 'relevance':
|
||||
$settings['body'][LANGUAGE_NOT_SPECIFIED][0]['value'] .= " really rocks";
|
||||
$settings['body'][0]['value'] .= " really rocks";
|
||||
break;
|
||||
case 'recent':
|
||||
$settings['created'] = REQUEST_TIME + 3600;
|
||||
|
@ -128,13 +128,13 @@ class SearchRankingTest extends SearchTestBase {
|
|||
foreach ($shuffled_tags as $tag) {
|
||||
switch ($tag) {
|
||||
case 'a':
|
||||
$settings['body'] = array(LANGUAGE_NOT_SPECIFIED => array(array('value' => l('Drupal Rocks', 'node'), 'format' => 'full_html')));
|
||||
$settings['body'] = array(array('value' => l('Drupal Rocks', 'node'), 'format' => 'full_html'));
|
||||
break;
|
||||
case 'notag':
|
||||
$settings['body'] = array(LANGUAGE_NOT_SPECIFIED => array(array('value' => 'Drupal Rocks')));
|
||||
$settings['body'] = array(array('value' => 'Drupal Rocks'));
|
||||
break;
|
||||
default:
|
||||
$settings['body'] = array(LANGUAGE_NOT_SPECIFIED => array(array('value' => "<$tag>Drupal Rocks</$tag>", 'format' => 'full_html')));
|
||||
$settings['body'] = array(array('value' => "<$tag>Drupal Rocks</$tag>", 'format' => 'full_html'));
|
||||
break;
|
||||
}
|
||||
$nodes[$tag] = $this->drupalCreateNode($settings);
|
||||
|
@ -167,7 +167,7 @@ class SearchRankingTest extends SearchTestBase {
|
|||
// Test tags with the same weight against the sorted tags.
|
||||
$unsorted_tags = array('u', 'b', 'i', 'strong', 'em');
|
||||
foreach ($unsorted_tags as $tag) {
|
||||
$settings['body'] = array(LANGUAGE_NOT_SPECIFIED => array(array('value' => "<$tag>Drupal Rocks</$tag>", 'format' => 'full_html')));
|
||||
$settings['body'] = array(array('value' => "<$tag>Drupal Rocks</$tag>", 'format' => 'full_html'));
|
||||
$node = $this->drupalCreateNode($settings);
|
||||
|
||||
// Update the search index.
|
||||
|
@ -203,7 +203,7 @@ class SearchRankingTest extends SearchTestBase {
|
|||
$settings = array(
|
||||
'type' => 'page',
|
||||
'title' => 'Drupal rocks',
|
||||
'body' => array(LANGUAGE_NOT_SPECIFIED => array(array('value' => "Drupal's search rocks"))),
|
||||
'body' => array(array('value' => "Drupal's search rocks")),
|
||||
'sticky' => 1,
|
||||
);
|
||||
|
||||
|
|
|
@ -5,7 +5,7 @@
|
|||
* Enables site-wide keyword searching.
|
||||
*/
|
||||
|
||||
use Drupal\node\Plugin\Core\Entity\Node;
|
||||
use Drupal\Core\Entity\EntityInterface;
|
||||
|
||||
/**
|
||||
* Matches all 'N' Unicode character classes (numbers)
|
||||
|
@ -792,7 +792,7 @@ function search_touch_node($nid) {
|
|||
/**
|
||||
* Implements hook_node_update_index().
|
||||
*/
|
||||
function search_node_update_index(Node $node) {
|
||||
function search_node_update_index(EntityInterface $node) {
|
||||
// Transplant links to a node into the target node.
|
||||
$result = db_query("SELECT caption FROM {search_node_links} WHERE nid = :nid", array(':nid' => $node->nid), array('target' => 'slave'));
|
||||
$output = array();
|
||||
|
@ -807,7 +807,7 @@ function search_node_update_index(Node $node) {
|
|||
/**
|
||||
* Implements hook_node_update().
|
||||
*/
|
||||
function search_node_update(Node $node) {
|
||||
function search_node_update(EntityInterface $node) {
|
||||
// Reindex the node when it is updated. The node is automatically indexed
|
||||
// when it is added, simply by being added to the node table.
|
||||
search_touch_node($node->nid);
|
||||
|
|
|
@ -172,7 +172,7 @@ abstract class WebTestBase extends TestBase {
|
|||
* @param $reset
|
||||
* (optional) Whether to reset the entity cache.
|
||||
*
|
||||
* @return \Drupal\node\Plugin\Core\Entity\Node
|
||||
* @return \Drupal\Core\Entity\EntityInterface
|
||||
* A node entity matching $title.
|
||||
*/
|
||||
function drupalGetNodeByTitle($title, $reset = FALSE) {
|
||||
|
@ -201,7 +201,7 @@ abstract class WebTestBase extends TestBase {
|
|||
* The following defaults are provided:
|
||||
* - body: Random string using the default filter format:
|
||||
* @code
|
||||
* $settings['body'][LANGUAGE_NOT_SPECIFIED][0] = array(
|
||||
* $settings['body'][0] = array(
|
||||
* 'value' => $this->randomName(32),
|
||||
* 'format' => filter_default_format(),
|
||||
* );
|
||||
|
@ -214,10 +214,7 @@ abstract class WebTestBase extends TestBase {
|
|||
* - status: NODE_PUBLISHED.
|
||||
* - sticky: NODE_NOT_STICKY.
|
||||
* - type: 'page'.
|
||||
* - langcode: LANGUAGE_NOT_SPECIFIED. (If a 'langcode' key is provided in
|
||||
* the array, this language code will also be used for a randomly
|
||||
* generated body field for that language, and the body for
|
||||
* LANGUAGE_NOT_SPECIFIED will remain empty.)
|
||||
* - langcode: LANGUAGE_NOT_SPECIFIED.
|
||||
* - uid: The currently logged in user, or the user running test.
|
||||
* - revision: 1. (Backwards-compatible binary flag indicating whether a
|
||||
* new revision should be created; use 1 to specify a new revision.)
|
||||
|
@ -228,7 +225,7 @@ abstract class WebTestBase extends TestBase {
|
|||
protected function drupalCreateNode(array $settings = array()) {
|
||||
// Populate defaults array.
|
||||
$settings += array(
|
||||
'body' => array(LANGUAGE_NOT_SPECIFIED => array(array())),
|
||||
'body' => array(array()),
|
||||
'title' => $this->randomName(8),
|
||||
'changed' => REQUEST_TIME,
|
||||
'promote' => NODE_NOT_PROMOTED,
|
||||
|
@ -265,14 +262,10 @@ abstract class WebTestBase extends TestBase {
|
|||
}
|
||||
|
||||
// Merge body field value and format separately.
|
||||
$body = array(
|
||||
$settings['body'][0] += array(
|
||||
'value' => $this->randomName(32),
|
||||
'format' => filter_default_format(),
|
||||
);
|
||||
if (empty($settings['body'][$settings['langcode']])) {
|
||||
$settings['body'][$settings['langcode']][0] = array();
|
||||
}
|
||||
$settings['body'][$settings['langcode']][0] += $body;
|
||||
|
||||
$node = entity_create('node', $settings);
|
||||
if (!empty($settings['revision'])) {
|
||||
|
|
|
@ -5,7 +5,7 @@
|
|||
* Logs and displays content statistics for a site.
|
||||
*/
|
||||
|
||||
use Drupal\node\Plugin\Core\Entity\Node;
|
||||
use Drupal\Core\Entity\EntityInterface;
|
||||
use Drupal\entity\Plugin\Core\Entity\EntityDisplay;
|
||||
|
||||
/**
|
||||
|
@ -47,7 +47,7 @@ function statistics_permission() {
|
|||
/**
|
||||
* Implements hook_node_view().
|
||||
*/
|
||||
function statistics_node_view(Node $node, EntityDisplay $display, $view_mode) {
|
||||
function statistics_node_view(EntityInterface $node, EntityDisplay $display, $view_mode) {
|
||||
if (!empty($node->nid) && $view_mode == 'full' && node_is_page($node) && empty($node->in_preview)) {
|
||||
$node->content['#attached']['library'][] = array('statistics', 'drupal.statistics');
|
||||
$settings = array('data' => array('nid' => $node->nid), 'url' => url(drupal_get_path('module', 'statistics') . '/statistics.php'));
|
||||
|
@ -197,7 +197,7 @@ function _statistics_format_item($title, $path) {
|
|||
/**
|
||||
* Implements hook_node_predelete().
|
||||
*/
|
||||
function statistics_node_predelete(Node $node) {
|
||||
function statistics_node_predelete(EntityInterface $node) {
|
||||
// clean up statistics table when node is deleted
|
||||
db_delete('node_counter')
|
||||
->condition('nid', $node->nid)
|
||||
|
|
|
@ -134,11 +134,9 @@ class CascadingStylesheetsTest extends WebTestBase {
|
|||
$settings = array(
|
||||
'type' => 'page',
|
||||
'body' => array(
|
||||
LANGUAGE_NOT_SPECIFIED => array(
|
||||
array(
|
||||
'value' => t('This tests the inline CSS!') . "<?php drupal_add_css('$css', 'inline'); ?>",
|
||||
'format' => $php_format_id,
|
||||
),
|
||||
array(
|
||||
'value' => t('This tests the inline CSS!') . "<?php drupal_add_css('$css', 'inline'); ?>",
|
||||
'format' => $php_format_id,
|
||||
),
|
||||
),
|
||||
'promote' => 1,
|
||||
|
|
|
@ -0,0 +1,78 @@
|
|||
<?php
|
||||
|
||||
/**
|
||||
* @file
|
||||
* Contains \Drupal\system\Tests\Entity\EntityBCDecoratorTest.
|
||||
*/
|
||||
|
||||
namespace Drupal\system\Tests\Entity;
|
||||
|
||||
/**
|
||||
* Tests Entity API base functionality.
|
||||
*
|
||||
* @todo: Remove once the EntityBCDecorator is removed.
|
||||
*/
|
||||
class EntityBCDecoratorTest extends EntityUnitTestBase {
|
||||
|
||||
/**
|
||||
* Modules to enable.
|
||||
*
|
||||
* @var array
|
||||
*/
|
||||
public static $modules = array('filter', 'text', 'node', 'comment');
|
||||
|
||||
public static function getInfo() {
|
||||
return array(
|
||||
'name' => 'Entity Backward Compatibility Decorator',
|
||||
'description' => 'Tests the Entity Backward Compatibility Decorator',
|
||||
'group' => 'Entity API',
|
||||
);
|
||||
}
|
||||
|
||||
public function setUp() {
|
||||
parent::setUp();
|
||||
$this->installSchema('user', array('users_roles', 'users_data', 'role_permission'));
|
||||
$this->installSchema('node', array('node', 'node_revision', 'node_type', 'node_access'));
|
||||
$this->installSchema('comment', array('comment', 'node_comment_statistics'));
|
||||
}
|
||||
|
||||
/**
|
||||
* Tests using the entity BC decorator with entity properties.
|
||||
*
|
||||
* @see \Drupal\Core\Entity\EntityBCDecorator
|
||||
*/
|
||||
public function testBCDecorator() {
|
||||
// Test using comment subject via the BC decorator.
|
||||
$this->createUser();
|
||||
$node = entity_create('node', array(
|
||||
'type' => 'page',
|
||||
'uid' => 1,
|
||||
));
|
||||
$node->save();
|
||||
$comment = entity_create('comment', array(
|
||||
'nid' => $node->nid,
|
||||
'subject' => 'old-value',
|
||||
));
|
||||
$comment->save();
|
||||
$bc_entity = $comment->getBCEntity();
|
||||
|
||||
// Test reading of a defined property.
|
||||
$this->assertEqual($bc_entity->subject, 'old-value', 'Accessing entity property via BC decorator.');
|
||||
// Test writing of a defined property via the decorator.
|
||||
$bc_entity->subject = 'new';
|
||||
$this->assertEqual($bc_entity->subject, 'new', 'Updated defined entity property via BC decorator.');
|
||||
$this->assertEqual($comment->subject->value, 'new', 'Updated defined entity property via BC decorator.');
|
||||
|
||||
// Test writing of a defined property.
|
||||
$comment->subject->value = 'newer';
|
||||
$this->assertEqual($bc_entity->subject, 'newer', 'Updated defined entity property via default entity class.');
|
||||
$this->assertEqual($comment->subject->value, 'newer', 'Updated defined entity property via default entity class.');
|
||||
|
||||
// Test handling of an undefined property.
|
||||
$this->assertFalse(isset($bc_entity->foo), 'Checking if isset() on undefnied property.');
|
||||
$bc_entity->foo = 'bar';
|
||||
$this->assertEqual($bc_entity->foo, 'bar', 'Accessing undefined entity property via BC decorator.');
|
||||
$this->assertEqual($comment->foo, 'bar', 'Accessing undefined entity property via default entity class.');
|
||||
$this->assertTrue(isset($bc_entity->foo), 'Checking if isset() on undefnied property.');
|
||||
}
|
||||
}
|
|
@ -99,6 +99,12 @@ class EntityUUIDTest extends EntityUnitTestBase {
|
|||
$this->assertNotNull($entity->id());
|
||||
$this->assertNotEqual($entity_duplicate->id(), $entity->id());
|
||||
break;
|
||||
case 'revision_id':
|
||||
$this->assertNull($entity_duplicate->getRevisionId());
|
||||
$this->assertNotNull($entity->getRevisionId());
|
||||
$this->assertNotEqual($entity_duplicate->getRevisionId(), $entity->getRevisionId());
|
||||
$this->assertNotEqual($entity_duplicate->{$property}->getValue(), $entity->{$property}->getValue());
|
||||
break;
|
||||
default:
|
||||
$this->assertEqual($entity_duplicate->{$property}->getValue(), $entity->{$property}->getValue());
|
||||
}
|
||||
|
|
|
@ -40,7 +40,7 @@ class ContextPluginTest extends DrupalUnitTestBase {
|
|||
$manager = new MockBlockManager();
|
||||
$plugin = $manager->createInstance('user_name');
|
||||
// Create a node, add it as context, catch the exception.
|
||||
$node = entity_create('node', array('title' => $name));
|
||||
$node = entity_create('node', array('title' => $name, 'type' => 'page'));
|
||||
|
||||
// Try to get a valid context that has not been set.
|
||||
try {
|
||||
|
|
|
@ -89,7 +89,7 @@ abstract class PluginTestBase extends UnitTestBase {
|
|||
'class' => 'Drupal\plugin_test\Plugin\plugin_test\mock_block\MockComplexContextBlock',
|
||||
'context' => array(
|
||||
'user' => array('class' => 'Drupal\user\Plugin\Core\Entity\User'),
|
||||
'node' => array('class' => 'Drupal\node\Plugin\Core\Entity\Node'),
|
||||
'node' => array('class' => 'Drupal\Core\Entity\EntityBCDecorator'),
|
||||
),
|
||||
),
|
||||
);
|
||||
|
|
|
@ -102,7 +102,7 @@ class EntityFilteringThemeTest extends WebTestBase {
|
|||
'title' => $this->xss_label,
|
||||
'type' => 'article',
|
||||
'promote' => NODE_PROMOTED,
|
||||
'field_tags' => array(LANGUAGE_NOT_SPECIFIED => array(array('tid' => $this->term->tid))),
|
||||
'field_tags' => array(array('tid' => $this->term->tid)),
|
||||
));
|
||||
|
||||
// Create a test comment on the test node.
|
||||
|
@ -111,7 +111,7 @@ class EntityFilteringThemeTest extends WebTestBase {
|
|||
'node_type' => $this->node->type,
|
||||
'status' => COMMENT_PUBLISHED,
|
||||
'subject' => $this->xss_label,
|
||||
'comment_body' => array(LANGUAGE_NOT_SPECIFIED => array($this->randomName())),
|
||||
'comment_body' => array($this->randomName()),
|
||||
));
|
||||
comment_save($this->comment);
|
||||
}
|
||||
|
|
|
@ -7,7 +7,7 @@
|
|||
|
||||
namespace Drupal\paramconverter_test;
|
||||
|
||||
use Drupal\node\Plugin\Core\Entity\Node;
|
||||
use Drupal\Core\Entity\EntityInterface;
|
||||
|
||||
/**
|
||||
* Controller routine for testing the paramconverter.
|
||||
|
@ -21,7 +21,7 @@ class TestControllers {
|
|||
return $retval;
|
||||
}
|
||||
|
||||
public function testNodeSetParent(Node $node, Node $parent) {
|
||||
public function testNodeSetParent(EntityInterface $node, EntityInterface $parent) {
|
||||
return "Setting '{$parent->title}' as parent of '{$node->title}'.";
|
||||
}
|
||||
}
|
||||
|
|
|
@ -91,7 +91,7 @@ class MockBlockManager extends PluginManagerBase {
|
|||
'class' => 'Drupal\plugin_test\Plugin\plugin_test\mock_block\MockComplexContextBlock',
|
||||
'context' => array(
|
||||
'user' => array('class' => 'Drupal\user\Plugin\Core\Entity\User'),
|
||||
'node' => array('class' => 'Drupal\node\Plugin\Core\Entity\Node'),
|
||||
'node' => array('class' => 'Drupal\Core\Entity\EntityBCDecorator'),
|
||||
),
|
||||
));
|
||||
|
||||
|
|
|
@ -73,7 +73,7 @@ class TaxonomyAutocompleteWidget extends WidgetBase {
|
|||
public function massageFormValues(array $values, array $form, array &$form_state) {
|
||||
// Autocomplete widgets do not send their tids in the form, so we must detect
|
||||
// them here and process them independently.
|
||||
$terms = array();
|
||||
$items = array();
|
||||
$field = $this->field;
|
||||
|
||||
// Collect candidate vocabularies.
|
||||
|
@ -89,19 +89,20 @@ class TaxonomyAutocompleteWidget extends WidgetBase {
|
|||
// otherwise, create a new 'autocreate' term for insert/update.
|
||||
if ($possibilities = entity_load_multiple_by_properties('taxonomy_term', array('name' => trim($value), 'vid' => array_keys($vocabularies)))) {
|
||||
$term = array_pop($possibilities);
|
||||
$item = array('tid' => $term->tid);
|
||||
}
|
||||
else {
|
||||
$vocabulary = reset($vocabularies);
|
||||
$term = array(
|
||||
'tid' => 'autocreate',
|
||||
$term = entity_create('taxonomy_term', array(
|
||||
'vid' => $vocabulary->id(),
|
||||
'name' => $value,
|
||||
);
|
||||
));
|
||||
$item = array('tid' => FALSE, 'entity' => $term);
|
||||
}
|
||||
$terms[] = (array)$term;
|
||||
$items[] = $item;
|
||||
}
|
||||
|
||||
return $terms;
|
||||
return $items;
|
||||
}
|
||||
|
||||
}
|
||||
|
|
|
@ -54,8 +54,8 @@ abstract class TaxonomyTestBase extends ViewTestBase {
|
|||
|
||||
$node = array();
|
||||
$node['type'] = 'article';
|
||||
$node['field_views_testing_tags'][LANGUAGE_NOT_SPECIFIED][]['tid'] = $this->term1->tid;
|
||||
$node['field_views_testing_tags'][LANGUAGE_NOT_SPECIFIED][]['tid'] = $this->term2->tid;
|
||||
$node['field_views_testing_tags'][]['tid'] = $this->term1->tid;
|
||||
$node['field_views_testing_tags'][]['tid'] = $this->term2->tid;
|
||||
$this->nodes[] = $this->drupalCreateNode($node);
|
||||
$this->nodes[] = $this->drupalCreateNode($node);
|
||||
}
|
||||
|
|
|
@ -1067,10 +1067,7 @@ function taxonomy_field_validate(EntityInterface $entity = NULL, $field, $instan
|
|||
* Implements hook_field_is_empty().
|
||||
*/
|
||||
function taxonomy_field_is_empty($item, $field) {
|
||||
if (!is_array($item) || (empty($item['tid']) && (string) $item['tid'] !== '0')) {
|
||||
return TRUE;
|
||||
}
|
||||
return FALSE;
|
||||
return !is_array($item) || (empty($item['tid']) && empty($item['entity']));
|
||||
}
|
||||
|
||||
/**
|
||||
|
@ -1099,9 +1096,8 @@ function taxonomy_field_formatter_info() {
|
|||
function taxonomy_field_formatter_view(EntityInterface $entity, $field, $instance, $langcode, $items, $display) {
|
||||
$element = array();
|
||||
|
||||
// Terms whose tid is 'autocreate' do not exist
|
||||
// yet and $item['taxonomy_term'] is not set. Theme such terms as
|
||||
// just their name.
|
||||
// Terms whose tid is 'autocreate' do not exist yet and $item['entity'] is not
|
||||
// set. Theme such terms as just their name.
|
||||
|
||||
switch ($display['type']) {
|
||||
case 'taxonomy_term_reference_link':
|
||||
|
@ -1112,7 +1108,7 @@ function taxonomy_field_formatter_view(EntityInterface $entity, $field, $instanc
|
|||
);
|
||||
}
|
||||
else {
|
||||
$term = $item['taxonomy_term'];
|
||||
$term = $item['entity'];
|
||||
$uri = $term->uri();
|
||||
$element[$delta] = array(
|
||||
'#type' => 'link',
|
||||
|
@ -1126,7 +1122,7 @@ function taxonomy_field_formatter_view(EntityInterface $entity, $field, $instanc
|
|||
|
||||
case 'taxonomy_term_reference_plain':
|
||||
foreach ($items as $delta => $item) {
|
||||
$name = ($item['tid'] != 'autocreate' ? $item['taxonomy_term']->label() : $item['name']);
|
||||
$name = ($item['tid'] != 'autocreate' ? $item['entity']->label() : $item['name']);
|
||||
$element[$delta] = array(
|
||||
'#markup' => check_plain($name),
|
||||
);
|
||||
|
@ -1137,7 +1133,7 @@ function taxonomy_field_formatter_view(EntityInterface $entity, $field, $instanc
|
|||
foreach ($items as $delta => $item) {
|
||||
$entity->rss_elements[] = array(
|
||||
'key' => 'category',
|
||||
'value' => $item['tid'] != 'autocreate' ? $item['taxonomy_term']->label() : $item['name'],
|
||||
'value' => $item['tid'] != 'autocreate' ? $item['entity']->label() : $item['name'],
|
||||
'attributes' => array(
|
||||
'domain' => $item['tid'] != 'autocreate' ? url('taxonomy/term/' . $item['tid'], array('absolute' => TRUE)) : '',
|
||||
),
|
||||
|
@ -1192,7 +1188,7 @@ function taxonomy_field_formatter_prepare_view($entity_type, $entities, $field,
|
|||
foreach ($entities as $id => $entity) {
|
||||
foreach ($items[$id] as $delta => $item) {
|
||||
// Force the array key to prevent duplicates.
|
||||
if ($item['tid'] != 'autocreate') {
|
||||
if ($item['tid'] != 'autocreate' && $item['tid'] !== FALSE) {
|
||||
$tids[$item['tid']] = $item['tid'];
|
||||
}
|
||||
}
|
||||
|
@ -1208,7 +1204,7 @@ function taxonomy_field_formatter_prepare_view($entity_type, $entities, $field,
|
|||
// Check whether the taxonomy term field instance value could be loaded.
|
||||
if (isset($terms[$item['tid']])) {
|
||||
// Replace the instance value with the term data.
|
||||
$items[$id][$delta]['taxonomy_term'] = $terms[$item['tid']];
|
||||
$items[$id][$delta]['entity'] = $terms[$item['tid']];
|
||||
}
|
||||
// Terms to be created are not in $terms, but are still legitimate.
|
||||
elseif ($item['tid'] == 'autocreate') {
|
||||
|
@ -1358,12 +1354,10 @@ function taxonomy_rdf_mapping() {
|
|||
*/
|
||||
function taxonomy_field_presave(EntityInterface $entity, $field, $instance, $langcode, &$items) {
|
||||
foreach ($items as $delta => $item) {
|
||||
if ($item['tid'] == 'autocreate') {
|
||||
if (!$item['tid'] && isset($item['entity'])) {
|
||||
unset($item['tid']);
|
||||
$term = entity_create('taxonomy_term', $item);
|
||||
$term->langcode = $langcode;
|
||||
taxonomy_term_save($term);
|
||||
$items[$delta]['tid'] = $term->tid;
|
||||
taxonomy_term_save($item['entity']);
|
||||
$items[$delta]['tid'] = $item['entity']->tid;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@ -1371,7 +1365,7 @@ function taxonomy_field_presave(EntityInterface $entity, $field, $instance, $lan
|
|||
/**
|
||||
* Implements hook_node_insert().
|
||||
*/
|
||||
function taxonomy_node_insert(Node $node) {
|
||||
function taxonomy_node_insert(EntityInterface $node) {
|
||||
// Add taxonomy index entries for the node.
|
||||
taxonomy_build_node_index($node);
|
||||
}
|
||||
|
@ -1448,7 +1442,7 @@ function taxonomy_build_node_index($node) {
|
|||
/**
|
||||
* Implements hook_node_update().
|
||||
*/
|
||||
function taxonomy_node_update(Node $node) {
|
||||
function taxonomy_node_update(EntityInterface $node) {
|
||||
// Always rebuild the node's taxonomy index entries on node save.
|
||||
taxonomy_delete_node_index($node);
|
||||
taxonomy_build_node_index($node);
|
||||
|
@ -1457,7 +1451,7 @@ function taxonomy_node_update(Node $node) {
|
|||
/**
|
||||
* Implements hook_node_predelete().
|
||||
*/
|
||||
function taxonomy_node_predelete(Node $node) {
|
||||
function taxonomy_node_predelete(EntityInterface $node) {
|
||||
// Clean up the {taxonomy_index} table when nodes are deleted.
|
||||
taxonomy_delete_node_index($node);
|
||||
}
|
||||
|
@ -1465,10 +1459,10 @@ function taxonomy_node_predelete(Node $node) {
|
|||
/**
|
||||
* Deletes taxonomy index entries for a given node.
|
||||
*
|
||||
* @param Drupal\node\Plugin\Core\Entity\Node $node
|
||||
* @param \Drupal\Core\Entity\EntityInterface $node
|
||||
* The node entity.
|
||||
*/
|
||||
function taxonomy_delete_node_index(Node $node) {
|
||||
function taxonomy_delete_node_index(EntityInterface $node) {
|
||||
if (config('taxonomy.settings')->get('maintain_index_table')) {
|
||||
db_delete('taxonomy_index')->condition('nid', $node->nid)->execute();
|
||||
}
|
||||
|
|
|
@ -5,7 +5,7 @@
|
|||
* Tracks recent content posted by a user or users.
|
||||
*/
|
||||
|
||||
use Drupal\node\Plugin\Core\Entity\Node;
|
||||
use Drupal\Core\Entity\EntityInterface;
|
||||
|
||||
/**
|
||||
* Implements hook_help().
|
||||
|
@ -193,7 +193,7 @@ function _tracker_user_access($account) {
|
|||
*
|
||||
* Adds new tracking information for this node since it's new.
|
||||
*/
|
||||
function tracker_node_insert(Node $node, $arg = 0) {
|
||||
function tracker_node_insert(EntityInterface $node, $arg = 0) {
|
||||
_tracker_add($node->nid, $node->uid, $node->changed);
|
||||
}
|
||||
|
||||
|
@ -202,7 +202,7 @@ function tracker_node_insert(Node $node, $arg = 0) {
|
|||
*
|
||||
* Adds tracking information for this node since it's been updated.
|
||||
*/
|
||||
function tracker_node_update(Node $node, $arg = 0) {
|
||||
function tracker_node_update(EntityInterface $node, $arg = 0) {
|
||||
_tracker_add($node->nid, $node->uid, $node->changed);
|
||||
}
|
||||
|
||||
|
@ -211,7 +211,7 @@ function tracker_node_update(Node $node, $arg = 0) {
|
|||
*
|
||||
* Deletes tracking information for a node.
|
||||
*/
|
||||
function tracker_node_predelete(Node $node, $arg = 0) {
|
||||
function tracker_node_predelete(EntityInterface $node, $arg = 0) {
|
||||
db_delete('tracker_node')
|
||||
->condition('nid', $node->nid)
|
||||
->execute();
|
||||
|
|
|
@ -37,7 +37,7 @@ function tracker_page($account = NULL, $set_title = FALSE) {
|
|||
|
||||
// This array acts as a placeholder for the data selected later
|
||||
// while keeping the correct order.
|
||||
$nodes = $query
|
||||
$tracker_data = $query
|
||||
->addTag('node_access')
|
||||
->addMetaData('base_table', 'tracker_node')
|
||||
->fields('t', array('nid', 'changed'))
|
||||
|
@ -48,12 +48,14 @@ function tracker_page($account = NULL, $set_title = FALSE) {
|
|||
->fetchAllAssoc('nid');
|
||||
|
||||
$rows = array();
|
||||
if (!empty($nodes)) {
|
||||
if (!empty($tracker_data)) {
|
||||
$nids = array_keys($tracker_data);
|
||||
$nodes = entity_load_multiple('node', $nids);
|
||||
// Now, get the data and put into the placeholder array.
|
||||
$result = db_query('SELECT n.nid, n.title, n.type, n.changed, n.uid, u.name, l.comment_count FROM {node} n INNER JOIN {node_comment_statistics} l ON n.nid = l.nid INNER JOIN {users} u ON n.uid = u.uid WHERE n.nid IN (:nids)', array(':nids' => array_keys($nodes)), array('target' => 'slave'));
|
||||
foreach ($result as $node) {
|
||||
$node->last_activity = $nodes[$node->nid]->changed;
|
||||
$nodes[$node->nid] = $node;
|
||||
$result = db_query('SELECT n.nid, l.comment_count FROM {node} n INNER JOIN {node_comment_statistics} l ON n.nid = l.nid INNER JOIN {users} u ON n.uid = u.uid WHERE n.nid IN (:nids)', array(':nids' => $nids), array('target' => 'slave'))->fetchAllKeyed();
|
||||
foreach ($result as $nid => $comment_count) {
|
||||
$nodes[$nid]->last_activity = $tracker_data[$nid]->changed;
|
||||
$nodes[$nid]->comment_count = $comment_count;
|
||||
}
|
||||
|
||||
// Display the data.
|
||||
|
|
|
@ -7,7 +7,7 @@
|
|||
|
||||
namespace Drupal\translation\Tests;
|
||||
|
||||
use Drupal\node\Plugin\Core\Entity\Node;
|
||||
use Drupal\Core\Entity\EntityInterface;
|
||||
use Drupal\simpletest\WebTestBase;
|
||||
|
||||
/**
|
||||
|
@ -362,7 +362,7 @@ class TranslationTest extends WebTestBase {
|
|||
/**
|
||||
* Creates a translation for a basic page in the specified language.
|
||||
*
|
||||
* @param Drupal\node\Node $node
|
||||
* @param \Drupal\Core\Entity\EntityInterface $node
|
||||
* The basic page to create the translation for.
|
||||
* @param $title
|
||||
* The title of a basic page in the specified language.
|
||||
|
@ -374,7 +374,7 @@ class TranslationTest extends WebTestBase {
|
|||
* @return
|
||||
* Translation object.
|
||||
*/
|
||||
function createTranslation(Node $node, $title, $body, $langcode) {
|
||||
function createTranslation(EntityInterface $node, $title, $body, $langcode) {
|
||||
$this->drupalGet('node/add/page', array('query' => array('translation' => $node->nid, 'target' => $langcode)));
|
||||
|
||||
$field_langcode = LANGUAGE_NOT_SPECIFIED;
|
||||
|
|
|
@ -5,11 +5,11 @@
|
|||
* Mock module for content translation tests.
|
||||
*/
|
||||
|
||||
use Drupal\node\Plugin\Core\Entity\Node;
|
||||
use Drupal\Core\Entity\EntityInterface;
|
||||
|
||||
/**
|
||||
* Implements hook_node_insert().
|
||||
*/
|
||||
function translation_test_node_insert(Node $node) {
|
||||
drupal_write_record('node', $node, 'nid');
|
||||
function translation_test_node_insert(EntityInterface $node) {
|
||||
$node->save();
|
||||
}
|
||||
|
|
|
@ -19,7 +19,7 @@
|
|||
* date (0) or needs to be updated (1).
|
||||
*/
|
||||
|
||||
use Drupal\node\Plugin\Core\Entity\Node;
|
||||
use Drupal\Core\Entity\EntityInterface;
|
||||
use Drupal\entity\Plugin\Core\Entity\EntityDisplay;
|
||||
|
||||
/**
|
||||
|
@ -248,7 +248,7 @@ function translation_form_node_form_alter(&$form, &$form_state) {
|
|||
* translation set. If no language provider is enabled, "fall back" to simple
|
||||
* links built through the result of translation_node_get_translations().
|
||||
*/
|
||||
function translation_node_view(Node $node, EntityDisplay $display, $view_mode) {
|
||||
function translation_node_view(EntityInterface $node, EntityDisplay $display, $view_mode) {
|
||||
// If the site has no translations or is not multilingual we have no content
|
||||
// translation links to display.
|
||||
if (isset($node->tnid) && language_multilingual() && $translations = translation_node_get_translations($node->tnid)) {
|
||||
|
@ -302,7 +302,7 @@ function translation_node_view(Node $node, EntityDisplay $display, $view_mode) {
|
|||
/**
|
||||
* Implements hook_node_prepare().
|
||||
*/
|
||||
function translation_node_prepare(Node $node) {
|
||||
function translation_node_prepare(EntityInterface $node) {
|
||||
// Only act if we are dealing with a content type supporting translations.
|
||||
if (translation_supported_type($node->type) &&
|
||||
// And it's a new node.
|
||||
|
@ -344,7 +344,7 @@ function translation_node_prepare(Node $node) {
|
|||
/**
|
||||
* Implements hook_node_insert().
|
||||
*/
|
||||
function translation_node_insert(Node $node) {
|
||||
function translation_node_insert(EntityInterface $node) {
|
||||
// Only act if we are dealing with a content type supporting translations.
|
||||
if (translation_supported_type($node->type)) {
|
||||
if (!empty($node->translation_source)) {
|
||||
|
@ -379,7 +379,7 @@ function translation_node_insert(Node $node) {
|
|||
/**
|
||||
* Implements hook_node_update().
|
||||
*/
|
||||
function translation_node_update(Node $node) {
|
||||
function translation_node_update(EntityInterface $node) {
|
||||
// Only act if we are dealing with a content type supporting translations.
|
||||
if (translation_supported_type($node->type)) {
|
||||
if (isset($node->translation) && $node->translation && !empty($node->langcode) && $node->tnid) {
|
||||
|
@ -408,7 +408,7 @@ function translation_node_update(Node $node) {
|
|||
*
|
||||
* Ensures that duplicate translations can't be created for the same source.
|
||||
*/
|
||||
function translation_node_validate(Node $node, $form, &$form_state) {
|
||||
function translation_node_validate(EntityInterface $node, $form, &$form_state) {
|
||||
// Only act on translatable nodes with a tnid or translation_source.
|
||||
$form_node = $form_state['controller']->getEntity($form_state);
|
||||
if (translation_supported_type($node->type) && (!empty($node->tnid) || !empty($form_node->translation_source->nid))) {
|
||||
|
@ -423,7 +423,7 @@ function translation_node_validate(Node $node, $form, &$form_state) {
|
|||
/**
|
||||
* Implements hook_node_predelete().
|
||||
*/
|
||||
function translation_node_predelete(Node $node) {
|
||||
function translation_node_predelete(EntityInterface $node) {
|
||||
// Only act if we are dealing with a content type supporting translations.
|
||||
if (translation_supported_type($node->type)) {
|
||||
translation_remove_from_set($node);
|
||||
|
|
|
@ -6,12 +6,12 @@
|
|||
*/
|
||||
|
||||
use Drupal\Component\Utility\NestedArray;
|
||||
use Drupal\node\Plugin\Core\Entity\Node;
|
||||
use Drupal\Core\Entity\EntityInterface;
|
||||
|
||||
/**
|
||||
* Page callback: Displays a list of a node's translations.
|
||||
*
|
||||
* @param Drupal\node\Node $node
|
||||
* @param \Drupal\Core\Entity\EntityInterface $node
|
||||
* A node entity.
|
||||
*
|
||||
* @return
|
||||
|
@ -19,7 +19,7 @@ use Drupal\node\Plugin\Core\Entity\Node;
|
|||
*
|
||||
* @see translation_menu()
|
||||
*/
|
||||
function translation_node_overview(Node $node) {
|
||||
function translation_node_overview(EntityInterface $node) {
|
||||
include_once DRUPAL_ROOT . '/core/includes/language.inc';
|
||||
|
||||
if ($node->tnid) {
|
||||
|
|
|
@ -66,7 +66,7 @@ abstract class EntityTranslationUITest extends EntityTranslationTestBase {
|
|||
|
||||
$base_path = $this->controller->getBasePath($entity);
|
||||
$path = $langcode . '/' . $base_path . '/translations/add/' . $default_langcode . '/' . $langcode;
|
||||
$this->drupalPost($path, $this->getEditValues($values, $langcode), $this->getFormSubmitAction());
|
||||
$this->drupalPost($path, $this->getEditValues($values, $langcode), $this->getFormSubmitAction($entity));
|
||||
if ($this->testLanguageSelector) {
|
||||
$this->assertNoFieldByXPath('//select[@id="edit-langcode"]', NULL, 'Language selector correclty disabled on translations.');
|
||||
}
|
||||
|
@ -83,7 +83,7 @@ abstract class EntityTranslationUITest extends EntityTranslationTestBase {
|
|||
// Add another translation and mark the other ones as outdated.
|
||||
$values[$langcode] = $this->getNewEntityValues($langcode);
|
||||
$edit = $this->getEditValues($values, $langcode) + array('translation_entity[retranslate]' => TRUE);
|
||||
$this->drupalPost($path, $edit, $this->getFormSubmitAction());
|
||||
$this->drupalPost($path, $edit, $this->getFormSubmitAction($entity));
|
||||
$entity = entity_load($this->entityType, $this->entityId, TRUE);
|
||||
|
||||
// Check that the entered values have been correctly stored.
|
||||
|
@ -108,7 +108,7 @@ abstract class EntityTranslationUITest extends EntityTranslationTestBase {
|
|||
|
||||
// Mark translations as outdated.
|
||||
$edit = array('translation_entity[retranslate]' => TRUE);
|
||||
$this->drupalPost($langcode . '/' . $this->controller->getEditPath($entity), $edit, $this->getFormSubmitAction());
|
||||
$this->drupalPost($langcode . '/' . $this->controller->getEditPath($entity), $edit, $this->getFormSubmitAction($entity));
|
||||
$entity = entity_load($this->entityType, $this->entityId, TRUE);
|
||||
|
||||
// Check that every translation has the correct "outdated" status.
|
||||
|
@ -122,7 +122,7 @@ abstract class EntityTranslationUITest extends EntityTranslationTestBase {
|
|||
else {
|
||||
$this->assertFieldByXPath('//input[@name="translation_entity[outdated]"]', TRUE, 'The translate flag is checked by default.');
|
||||
$edit = array('translation_entity[outdated]' => FALSE);
|
||||
$this->drupalPost($path, $edit, $this->getFormSubmitAction());
|
||||
$this->drupalPost($path, $edit, $this->getFormSubmitAction($entity));
|
||||
$this->drupalGet($path);
|
||||
$this->assertFieldByXPath('//input[@name="translation_entity[retranslate]"]', FALSE, 'The retranslate flag is now shown.');
|
||||
$entity = entity_load($this->entityType, $this->entityId, TRUE);
|
||||
|
@ -142,7 +142,7 @@ abstract class EntityTranslationUITest extends EntityTranslationTestBase {
|
|||
foreach ($this->langcodes as $index => $langcode) {
|
||||
if ($index > 0) {
|
||||
$edit = array('translation_entity[status]' => FALSE);
|
||||
$this->drupalPost($langcode . '/' . $path, $edit, $this->getFormSubmitAction());
|
||||
$this->drupalPost($langcode . '/' . $path, $edit, $this->getFormSubmitAction($entity));
|
||||
$entity = entity_load($this->entityType, $this->entityId, TRUE);
|
||||
$this->assertFalse($entity->translation[$langcode]['status'], 'The translation has been correctly unpublished.');
|
||||
}
|
||||
|
@ -173,7 +173,7 @@ abstract class EntityTranslationUITest extends EntityTranslationTestBase {
|
|||
'translation_entity[created]' => format_date($values[$langcode]['created'], 'custom', 'Y-m-d H:i:s O'),
|
||||
);
|
||||
$prefix = $index > 0 ? $langcode . '/' : '';
|
||||
$this->drupalPost($prefix . $path, $edit, $this->getFormSubmitAction());
|
||||
$this->drupalPost($prefix . $path, $edit, $this->getFormSubmitAction($entity));
|
||||
}
|
||||
|
||||
$entity = entity_load($this->entityType, $this->entityId, TRUE);
|
||||
|
@ -189,7 +189,7 @@ abstract class EntityTranslationUITest extends EntityTranslationTestBase {
|
|||
'translation_entity[name]' => $this->randomName(12),
|
||||
'translation_entity[created]' => $this->randomName(),
|
||||
);
|
||||
$this->drupalPost($path, $edit, $this->getFormSubmitAction());
|
||||
$this->drupalPost($path, $edit, $this->getFormSubmitAction($entity));
|
||||
$this->assertTrue($this->xpath('//div[@id="messages"]//div[contains(@class, "error")]//ul'), 'Invalid values generate a list of form errors.');
|
||||
$this->assertEqual($entity->translation[$langcode]['uid'] == $values[$langcode]['uid'], 'Translation author correctly kept.');
|
||||
$this->assertEqual($entity->translation[$langcode]['created'] == $values[$langcode]['created'], 'Translation date correctly kept.');
|
||||
|
@ -235,8 +235,14 @@ abstract class EntityTranslationUITest extends EntityTranslationTestBase {
|
|||
|
||||
/**
|
||||
* Returns the form action value to be used to submit the entity form.
|
||||
*
|
||||
* @param \Drupal\Core\Entity\EntityInterface $entity
|
||||
* The entity being tested.
|
||||
*
|
||||
* @return string
|
||||
* Name of the button to hit.
|
||||
*/
|
||||
protected function getFormSubmitAction() {
|
||||
protected function getFormSubmitAction(EntityInterface $entity) {
|
||||
return t('Save');
|
||||
}
|
||||
|
||||
|
@ -252,6 +258,8 @@ abstract class EntityTranslationUITest extends EntityTranslationTestBase {
|
|||
* The translation object to act on.
|
||||
*/
|
||||
protected function getTranslation(EntityInterface $entity, $langcode) {
|
||||
// @todo remove once EntityBCDecorator is gone.
|
||||
$entity = $entity->getOriginalEntity();
|
||||
return $entity instanceof EntityNG ? $entity->getTranslation($langcode, FALSE) : $entity;
|
||||
}
|
||||
|
||||
|
@ -270,7 +278,8 @@ abstract class EntityTranslationUITest extends EntityTranslationTestBase {
|
|||
*/
|
||||
protected function getValue(ComplexDataInterface $translation, $property, $langcode) {
|
||||
$key = $property == 'user_id' ? 'target_id' : 'value';
|
||||
if (($translation instanceof EntityInterface) && !($translation instanceof EntityNG)) {
|
||||
// @todo remove EntityBCDecorator condition once EntityBCDecorator is gone.
|
||||
if (($translation instanceof EntityInterface) && !($translation instanceof EntityNG) && !($translation instanceof EntityBCDecorator)) {
|
||||
return is_array($translation->$property) ? $translation->{$property}[$langcode][0][$key] : $translation->$property;
|
||||
}
|
||||
else {
|
||||
|
|
|
@ -614,6 +614,7 @@ function translation_entity_form_alter(array &$form, array &$form_state) {
|
|||
// Handle fields shared between translations when there is at least one
|
||||
// translation available or a new one is being created.
|
||||
if (!$entity->isNew() && (!isset($translations[$form_langcode]) || count($translations) > 1)) {
|
||||
$entity = $entity->getOriginalEntity();
|
||||
if ($entity instanceof EntityNG) {
|
||||
foreach ($entity->getPropertyDefinitions() as $property_name => $definition) {
|
||||
if (isset($form[$property_name])) {
|
||||
|
|
|
@ -238,6 +238,7 @@ function translation_entity_edit_page(EntityInterface $entity, Language $languag
|
|||
function translation_entity_prepare_translation(EntityInterface $entity, Language $source, Language $target) {
|
||||
// @todo Unify field and property handling.
|
||||
$instances = field_info_instances($entity->entityType(), $entity->bundle());
|
||||
$entity = $entity->getOriginalEntity();
|
||||
if ($entity instanceof EntityNG) {
|
||||
$source_translation = $entity->getTranslation($source->langcode);
|
||||
$target_translation = $entity->getTranslation($target->langcode);
|
||||
|
|
|
@ -44,6 +44,9 @@ class DefaultViewsTest extends WebTestBase {
|
|||
protected function setUp() {
|
||||
parent::setUp();
|
||||
|
||||
// Create Basic page node type.
|
||||
$this->drupalCreateContentType(array('type' => 'page', 'name' => 'Basic page'));
|
||||
|
||||
$this->vocabulary = entity_create('taxonomy_vocabulary', array(
|
||||
'name' => $this->randomName(),
|
||||
'description' => $this->randomName(),
|
||||
|
@ -93,13 +96,13 @@ class DefaultViewsTest extends WebTestBase {
|
|||
$term = $this->createTerm($this->vocabulary);
|
||||
|
||||
$values = array('created' => $time, 'type' => 'page');
|
||||
$values[$this->field_name][LANGUAGE_NOT_SPECIFIED][]['tid'] = $term->tid;
|
||||
$values[$this->field_name][]['tid'] = $term->tid;
|
||||
|
||||
// Make every other node promoted.
|
||||
if ($i % 2) {
|
||||
$values['promote'] = TRUE;
|
||||
}
|
||||
$values['body'][LANGUAGE_NOT_SPECIFIED][]['value'] = l('Node ' . 1, 'node/' . 1);
|
||||
$values['body'][]['value'] = l('Node ' . 1, 'node/' . 1);
|
||||
|
||||
$node = $this->drupalCreateNode($values);
|
||||
|
||||
|
|
Loading…
Reference in New Issue