class DeleteMultiple in Message UI 8
Provides a message deletion confirmation form.
Hierarchy
- class \Drupal\Core\Form\FormBase implements ContainerInjectionInterface, FormInterface uses DependencySerializationTrait, LoggerChannelTrait, MessengerTrait, LinkGeneratorTrait, RedirectDestinationTrait, UrlGeneratorTrait, StringTranslationTrait
- class \Drupal\Core\Form\ConfirmFormBase implements ConfirmFormInterface
- class \Drupal\message_ui\Form\DeleteMultiple
- class \Drupal\Core\Form\ConfirmFormBase implements ConfirmFormInterface
Expanded class hierarchy of DeleteMultiple
File
- src/
Form/ DeleteMultiple.php, line 17
Namespace
Drupal\message_ui\FormView source
class DeleteMultiple extends ConfirmFormBase {
/**
* The array of messages to delete.
*
* @var array
*/
protected $messages = [];
/**
* The tempstore factory.
*
* @var \Drupal\Core\TempStore\PrivateTempStoreFactory
*/
protected $tempStoreFactory;
/**
* The message storage.
*
* @var \Drupal\Core\Entity\EntityTypeManagerInterface
*/
protected $manager;
/**
* Constructs a DeleteMultiple form object.
*
* @param \Drupal\Core\TempStore\PrivateTempStoreFactory $temp_store_factory
* The tempstore factory.
* @param \Drupal\Core\Entity\EntityTypeManagerInterface $manager
* The entity manager.
*
* @throws \Drupal\Component\Plugin\Exception\InvalidPluginDefinitionException
* @throws \Drupal\Component\Plugin\Exception\PluginNotFoundException
*/
public function __construct(PrivateTempStoreFactory $temp_store_factory, EntityTypeManagerInterface $manager) {
$this->tempStoreFactory = $temp_store_factory;
$this->storage = $manager
->getStorage('message');
}
/**
* {@inheritdoc}
*/
public static function create(ContainerInterface $container) {
return new static($container
->get('tempstore.private'), $container
->get('entity_type.manager'));
}
/**
* {@inheritdoc}
*/
public function getFormId() {
return 'message_multiple_delete_confirm';
}
/**
* {@inheritdoc}
*/
public function getQuestion() {
return \Drupal::translation()
->formatPlural(count($this->messages), 'Are you sure you want to delete this item?', 'Are you sure you want to delete these items?');
}
/**
* {@inheritdoc}
*/
public function getCancelRoute() {
}
/**
* {@inheritdoc}
*/
public function getConfirmText() {
return t('Delete');
}
/**
* {@inheritdoc}
*/
public function buildForm(array $form, FormStateInterface $form_state) {
// @todo - below is from Message module, remove?
$this->messages = $this->tempStoreFactory
->get('message_multiple_delete_confirm')
->get(\Drupal::currentUser()
->id());
if (empty($this->messages)) {
return new RedirectResponse($this
->getCancelUrl()
->setAbsolute()
->toString());
}
$form['messages'] = [
'#theme' => 'item_list',
'#items' => array_map([
$this,
'filterCallback',
], $this->messages),
];
$form = parent::buildForm($form, $form_state);
$form['actions']['cancel']['#href'] = $this
->getCancelRoute();
// @todo - See "Delete multiple messages" from message_ui in D7.
return $form;
}
/**
* Filter callback; Set text for each message which will be deleted.
*
* @param \Drupal\message\Entity\Message $message
* The message object.
*
* @return \Drupal\Core\StringTranslation\TranslatableMarkup
* A simple text to show which message is deleted.
*/
private function filterCallback(Message $message) {
$params = [
'@id' => $message
->id(),
'@template' => $message
->getTemplate()
->label(),
];
return t('Delete message ID @id fo template @template', $params);
}
/**
* {@inheritdoc}
*/
public function submitForm(array &$form, FormStateInterface $form_state) {
// Get the message IDs.
$query = \Drupal::entityQuery('message');
$result = $query
->condition('type', $form_state['values']['types'], 'IN')
->execute();
if (empty($result['message'])) {
// No messages found, return.
$this
->messenger()
->addError(t('No messages were found according to the parameters you entered'));
return;
}
// Prepare the message IDs chunk array for batch operation.
$chunks = array_chunk(array_keys($result['message']), 100);
$operations = [];
// @todo : update the operation below to new structure.
foreach ($chunks as $chunk) {
$operations[] = [
'message_delete_multiple',
[
$chunk,
],
];
}
// Set the batch.
$batch = [
'operations' => $operations,
'title' => t('deleting messages.'),
'init_message' => t('Starting to delete messages.'),
'progress_message' => t('Processed @current out of @total.'),
'error_message' => t('The batch operation has failed.'),
];
batch_set($batch);
batch_process($_GET['q']);
}
/**
* {@inheritdoc}
*/
public function getCancelUrl() {
return new Url('message.messages');
}
}
Members
Name | Modifiers | Type | Description | Overrides |
---|---|---|---|---|
ConfirmFormBase:: |
public | function |
Returns a caption for the link which cancels the action. Overrides ConfirmFormInterface:: |
1 |
ConfirmFormBase:: |
public | function |
Returns additional text to display as a description. Overrides ConfirmFormInterface:: |
11 |
ConfirmFormBase:: |
public | function |
Returns the internal name used to refer to the confirmation item. Overrides ConfirmFormInterface:: |
|
DeleteMultiple:: |
protected | property | The message storage. | |
DeleteMultiple:: |
protected | property | The array of messages to delete. | |
DeleteMultiple:: |
protected | property | The tempstore factory. | |
DeleteMultiple:: |
public | function |
Form constructor. Overrides ConfirmFormBase:: |
|
DeleteMultiple:: |
public static | function |
Instantiates a new instance of this class. Overrides FormBase:: |
|
DeleteMultiple:: |
private | function | Filter callback; Set text for each message which will be deleted. | |
DeleteMultiple:: |
public | function | ||
DeleteMultiple:: |
public | function |
Returns the route to go to if the user cancels the action. Overrides ConfirmFormInterface:: |
|
DeleteMultiple:: |
public | function |
Returns a caption for the button that confirms the action. Overrides ConfirmFormBase:: |
|
DeleteMultiple:: |
public | function |
Returns a unique string identifying the form. Overrides FormInterface:: |
|
DeleteMultiple:: |
public | function |
Returns the question to ask the user. Overrides ConfirmFormInterface:: |
|
DeleteMultiple:: |
public | function |
Form submission handler. Overrides FormInterface:: |
|
DeleteMultiple:: |
public | function | Constructs a DeleteMultiple form object. | |
DependencySerializationTrait:: |
protected | property | An array of entity type IDs keyed by the property name of their storages. | |
DependencySerializationTrait:: |
protected | property | An array of service IDs keyed by property name used for serialization. | |
DependencySerializationTrait:: |
public | function | 1 | |
DependencySerializationTrait:: |
public | function | 2 | |
FormBase:: |
protected | property | The config factory. | 1 |
FormBase:: |
protected | property | The request stack. | 1 |
FormBase:: |
protected | property | The route match. | |
FormBase:: |
protected | function | Retrieves a configuration object. | |
FormBase:: |
protected | function | Gets the config factory for this form. | 1 |
FormBase:: |
private | function | Returns the service container. | |
FormBase:: |
protected | function | Gets the current user. | |
FormBase:: |
protected | function | Gets the request object. | |
FormBase:: |
protected | function | Gets the route match. | |
FormBase:: |
protected | function | Gets the logger for a specific channel. | |
FormBase:: |
protected | function |
Returns a redirect response object for the specified route. Overrides UrlGeneratorTrait:: |
|
FormBase:: |
public | function | Resets the configuration factory. | |
FormBase:: |
public | function | Sets the config factory for this form. | |
FormBase:: |
public | function | Sets the request stack object to use. | |
FormBase:: |
public | function |
Form validation handler. Overrides FormInterface:: |
62 |
LinkGeneratorTrait:: |
protected | property | The link generator. | 1 |
LinkGeneratorTrait:: |
protected | function | Returns the link generator. | |
LinkGeneratorTrait:: |
protected | function | Renders a link to a route given a route name and its parameters. | |
LinkGeneratorTrait:: |
public | function | Sets the link generator service. | |
LoggerChannelTrait:: |
protected | property | The logger channel factory service. | |
LoggerChannelTrait:: |
protected | function | Gets the logger for a specific channel. | |
LoggerChannelTrait:: |
public | function | Injects the logger channel factory. | |
MessengerTrait:: |
protected | property | The messenger. | 29 |
MessengerTrait:: |
public | function | Gets the messenger. | 29 |
MessengerTrait:: |
public | function | Sets the messenger. | |
RedirectDestinationTrait:: |
protected | property | The redirect destination service. | 1 |
RedirectDestinationTrait:: |
protected | function | Prepares a 'destination' URL query parameter for use with \Drupal\Core\Url. | |
RedirectDestinationTrait:: |
protected | function | Returns the redirect destination service. | |
RedirectDestinationTrait:: |
public | function | Sets the redirect destination service. | |
StringTranslationTrait:: |
protected | property | The string translation service. | 1 |
StringTranslationTrait:: |
protected | function | Formats a string containing a count of items. | |
StringTranslationTrait:: |
protected | function | Returns the number of plurals supported by a given language. | |
StringTranslationTrait:: |
protected | function | Gets the string translation service. | |
StringTranslationTrait:: |
public | function | Sets the string translation service to use. | 2 |
StringTranslationTrait:: |
protected | function | Translates a string to the current language or to a given language. | |
UrlGeneratorTrait:: |
protected | property | The url generator. | |
UrlGeneratorTrait:: |
protected | function | Returns the URL generator service. | |
UrlGeneratorTrait:: |
public | function | Sets the URL generator service. | |
UrlGeneratorTrait:: |
protected | function | Generates a URL or path for a specific route based on the given parameters. |