contacts_events-8.x-1.x-dev/src/Form/EventTypeForm.php
src/Form/EventTypeForm.php
<?php
namespace Drupal\contacts_events\Form;
use Drupal\Core\Entity\EntityForm;
use Drupal\Core\Form\FormStateInterface;
/**
* The event type form.
*/
class EventTypeForm extends EntityForm {
/**
* {@inheritdoc}
*/
public function form(array $form, FormStateInterface $form_state) {
$form = parent::form($form, $form_state);
$event_type = $this->entity;
$form['label'] = [
'#type' => 'textfield',
'#title' => $this->t('Label'),
'#maxlength' => 255,
'#default_value' => $event_type->label(),
'#description' => $this->t("Label for the Event type."),
'#required' => TRUE,
];
$form['id'] = [
'#type' => 'machine_name',
'#default_value' => $event_type->id(),
'#machine_name' => [
'exists' => '\Drupal\contacts_events\Entity\EventType::load',
],
'#disabled' => !$event_type->isNew(),
];
return $form;
}
/**
* {@inheritdoc}
*/
public function save(array $form, FormStateInterface $form_state) {
$event_type = $this->entity;
$status = $event_type->save();
switch ($status) {
case SAVED_NEW:
$this->messenger()->addMessage($this->t('Created the %label Event type.', [
'%label' => $event_type->label(),
]));
break;
default:
$this->messenger()->addMessage($this->t('Saved the %label Event type.', [
'%label' => $event_type->label(),
]));
}
$form_state->setRedirectUrl($event_type->toUrl('collection'));
}
}
