public function PardotCampaignFormBase::save in Pardot Integration 8
Overrides Drupal\Core\Entity\EntityFormController::save().
Saves the entity. This is called after submit() has built the entity from the form values. Do not override submit() as save() is the preferred method for entity form controllers.
Parameters
array $form: An associative array containing the structure of the form.
\Drupal\Core\Form\FormStateInterface $form_state: An associative array containing the current state of the form.
Overrides EntityForm::save
File
- src/
Form/ PardotCampaignFormBase.php, line 206
Class
- PardotCampaignFormBase
- Class PardotCampaignFormBase.
Namespace
Drupal\pardot\FormCode
public function save(array $form, FormStateInterface $form_state) {
$campaign = $this
->getEntity();
// Drupal already populated the form values in the entity object. Each
// form field was saved as a public variable in the entity class. PHP
// allows Drupal to do this even if the method is not defined ahead of
// time.
$status = $campaign
->save();
// Grab the URL of the new entity. We'll use it in the message.
$url = $campaign
->urlInfo();
// Create an edit link.
$edit_link = $this
->l($this
->t('Edit'), $url);
if ($status == SAVED_UPDATED) {
// If we edited an existing entity...
drupal_set_message($this
->t('Pardot Campaign %label has been updated.', array(
'%label' => $campaign
->label(),
)));
$this
->logger('contact')
->notice('Pardot Campaign %label has been updated.', [
'%label' => $campaign
->label(),
'link' => $edit_link,
]);
}
else {
// If we created a new entity...
drupal_set_message($this
->t('Pardot Campaign %label has been added.', array(
'%label' => $campaign
->label(),
)));
$this
->logger('contact')
->notice('Pardot Campaign %label has been added.', [
'%label' => $campaign
->label(),
'link' => $edit_link,
]);
}
// Redirect the user back to the listing route after the save operation.
$form_state
->setRedirect('pardot.campaign.list');
}