entity->isNew()) { $form['new_revision'] = [ '#type' => 'checkbox', '#title' => $this->t('Create new revision'), '#default_value' => FALSE, '#weight' => 10, ]; } $entity = $this->entity; return $form; } /** * {@inheritdoc} */ public function save(array $form, FormStateInterface $form_state) { $entity = $this->entity; // Save as a new revision if requested to do so. if (!$form_state->isValueEmpty('new_revision') && $form_state->getValue('new_revision') != FALSE) { $entity->setNewRevision(); // If a new revision is created, save the current user as revision author. $entity->setRevisionCreationTime(REQUEST_TIME); $entity->setRevisionUserId(\Drupal::currentUser()->id()); } else { $entity->setNewRevision(FALSE); } $status = parent::save($form, $form_state); switch ($status) { case SAVED_NEW: \Drupal::messenger()->addMessage($this->t('Created the %bundle.', [ '%bundle' => $entity->bundle(), ])); break; default: \Drupal::messenger()->addMessage($this->t('Saved the %bundle.', [ '%bundle' => $entity->bundle(), ])); } // If you have unpublished the entity and you can't see unpublished entities, redirect to a more informative message than just "Access Denied". if (!$form_state->getValue('status')['value'] && !\Drupal::currentUser()->hasPermission('view unpublished activity entities')) { \Drupal::messenger()->addMessage($this->t('The %bundle is now unpublished & hidden from you.', [ '%bundle' => $entity->bundle(), ])); $form_state->setRedirect(''); } else { $form_state->setRedirect('entity.oc_activity.canonical', ['oc_activity' => $entity->id()]); } } }