diff --git a/src/Controller/TrashDeleteController.php b/src/Controller/TrashDeleteController.php index 216ad00da2053b7dd278f6c18ecf02e5e42e1a86..65eeb1edc8adff967e0b4710fac15b9691b8e237 100644 --- a/src/Controller/TrashDeleteController.php +++ b/src/Controller/TrashDeleteController.php @@ -106,18 +106,19 @@ class TrashDeleteController extends ControllerBase { return $this->entityFormBuilder->getForm($entity, 'delete'); } - if ($this->trashManager->trash($entity)) { - drupal_set_message($this->t('The @entity %label has been moved to the trash. <a href=":undo-page">Undo</a>', [ - '@entity' => $entity->getEntityType() - ->getLabel(), - '%label' => $entity->label(), - ':undo-page' => Url::fromRoute('restore.form', [ - 'entity_type_id' => $entity->getEntityTypeId(), - 'entity_id' => $entity->id(), - ])->toString(), - ])); - } + $this->trashManager->trash($entity); + + drupal_set_message($this->t('The @entity %label has been moved to the trash. <a href=":undo-page">Undo</a>', [ + '@entity' => $entity->getEntityType() + ->getLabel(), + '%label' => $entity->label(), + ':undo-page' => Url::fromRoute('restore.form', [ + 'entity_type_id' => $entity->getEntityTypeId(), + 'entity_id' => $entity->id(), + ])->toString(), + ])); $redirect_url = $this->getRedirectUrl($entity); + return $this->redirect($redirect_url->getRouteName(), $redirect_url->getRouteParameters()); } diff --git a/src/Form/RestoreForm.php b/src/Form/RestoreForm.php index 166ab9648b4d5aa64cc9d2172a9f68578afcd52b..28e0725a857af7fee467a482b0e6d50b5ad3d291 100644 --- a/src/Form/RestoreForm.php +++ b/src/Form/RestoreForm.php @@ -116,14 +116,13 @@ class RestoreForm extends ConfirmFormBase { * {@inheritdoc} */ public function submitForm(array &$form, FormStateInterface $form_state) { - if ($this->trashManager->restore($this->entity)) { - drupal_set_message(t('The @entity "@label" has been restored.', [ - '@entity' => $this->entity->getEntityType() - ->get('label'), - '@label' => $this->entity->label(), - ])); - $form_state->setRedirect('trash.default', ['entity_type_id' => $this->entity->getEntityTypeId()]); - } + $this->trashManager->restore($this->entity); + drupal_set_message(t('The @entity "@label" has been restored.', [ + '@entity' => $this->entity->getEntityType() + ->get('label'), + '@label' => $this->entity->label(), + ])); + $form_state->setRedirect('trash.default', ['entity_type_id' => $this->entity->getEntityTypeId()]); } } diff --git a/src/TrashManager.php b/src/TrashManager.php index 932eeb65184ca0b4a70d96ac81825e3ab7171e7f..5075fea91dbb340bd7d273679244462bc85cad57 100644 --- a/src/TrashManager.php +++ b/src/TrashManager.php @@ -23,7 +23,7 @@ class TrashManager implements TrashManagerInterface { */ public function trash(ContentEntityInterface $entity) { $entity->set('moderation_state', TrashModerationState::TRASHED); - return (bool) $entity->save(); + $entity->save(); } /** @@ -45,7 +45,7 @@ class TrashManager implements TrashManagerInterface { $revision_id = reset($revision_ids); $content_moderation_state = $storage->loadRevision($revision_id); $entity->set('moderation_state', $content_moderation_state->moderation_state->target_id); - return (bool) $entity->save(); + $entity->save(); } } diff --git a/src/TrashManagerInterface.php b/src/TrashManagerInterface.php index afdc9caa7f25a89e8479402c0d2dac2e33ec1f2a..8cdcba3a2aa5bef57d5207fd18a7421b5f0757bf 100644 --- a/src/TrashManagerInterface.php +++ b/src/TrashManagerInterface.php @@ -7,16 +7,19 @@ use Drupal\Core\Entity\ContentEntityInterface; interface TrashManagerInterface { /** - * @param \Drupal\Core\Entity\ContentEntityInterface $entity + * Moves an entity to trash. * - * @return bool + * @param \Drupal\Core\Entity\ContentEntityInterface $entity + * A content entity object. */ public function trash(ContentEntityInterface $entity); /** - * @param \Drupal\Core\Entity\ContentEntityInterface $entity + * Restores an entity from trash. * - * @return bool + * @param \Drupal\Core\Entity\ContentEntityInterface $entity + * A content entity object. */ public function restore(ContentEntityInterface $entity); + }