3 namespace Drupal\shortcut;
5 use Drupal\Core\Entity\BundleEntityFormBase;
6 use Drupal\Core\Form\FormStateInterface;
9 * Form handler for the shortcut set entity edit forms.
11 class ShortcutSetForm extends BundleEntityFormBase {
16 public function form(array $form, FormStateInterface $form_state) {
17 $form = parent::form($form, $form_state);
19 $entity = $this->entity;
21 '#type' => 'textfield',
22 '#title' => t('Set name'),
23 '#description' => t('The new set is created by copying items from your default shortcut set.'),
25 '#default_value' => $entity->label(),
28 '#type' => 'machine_name',
30 'exists' => '\Drupal\shortcut\Entity\ShortcutSet::load',
31 'source' => ['label'],
32 'replace_pattern' => '[^a-z0-9-]+',
35 '#default_value' => $entity->id(),
36 // This id could be used for menu name.
40 $form['actions']['submit']['#value'] = t('Create new set');
42 return $this->protectBundleIdElement($form);
48 public function save(array $form, FormStateInterface $form_state) {
49 $entity = $this->entity;
50 $is_new = !$entity->getOriginalId();
54 drupal_set_message(t('The %set_name shortcut set has been created. You can edit it from this page.', ['%set_name' => $entity->label()]));
57 drupal_set_message(t('Updated set name to %set-name.', ['%set-name' => $entity->label()]));
59 $form_state->setRedirectUrl($this->entity->urlInfo('customize-form'));