Newer
Older
<?php
namespace Drupal\shortcut;
Alex Pott
committed
use Drupal\Core\Entity\ContentEntityForm;
Dries Buytaert
committed
use Drupal\Core\Form\FormStateInterface;
/**
* Form handler for the shortcut entity forms.
*/
Alex Pott
committed
class ShortcutForm extends ContentEntityForm {
/**
Alex Pott
committed
* The entity being used by this form.
Alex Pott
committed
* @var \Drupal\shortcut\ShortcutInterface
*/
Alex Pott
committed
protected $entity;
/**
* {@inheritdoc}
*/
Dries Buytaert
committed
public function save(array $form, FormStateInterface $form_state) {
$entity = $this->entity;
$status = $entity->save();
$url = $entity->getUrl();
// There's an edge case where a user can have permission to
// 'link to any content', but has no right to access the linked page. So we
// check the access before showing the link.
if ($url->access()) {
$view_link = \Drupal::l($entity->getTitle(), $url);
}
else {
$view_link = $entity->getTitle();
}
if ($status == SAVED_UPDATED) {
$message = $this->t('The shortcut %link has been updated.', array('%link' => $view_link));
}
else {
$message = $this->t('Added a shortcut for %title.', array('%title' => $view_link));
}
drupal_set_message($message);
Alex Pott
committed
$form_state->setRedirect(
'entity.shortcut_set.customize_form',
array('shortcut_set' => $entity->bundle())