class SubscriberMassSubscribeForm in Simplenews 8
Same name and namespace in other branches
- 8.2 src/Form/SubscriberMassSubscribeForm.php \Drupal\simplenews\Form\SubscriberMassSubscribeForm
- 3.x src/Form/SubscriberMassSubscribeForm.php \Drupal\simplenews\Form\SubscriberMassSubscribeForm
Do a mass subscription for a list of email addresses.
Hierarchy
- class \Drupal\Core\Form\FormBase implements ContainerInjectionInterface, FormInterface uses DependencySerializationTrait, LoggerChannelTrait, MessengerTrait, LinkGeneratorTrait, RedirectDestinationTrait, UrlGeneratorTrait, StringTranslationTrait
- class \Drupal\simplenews\Form\SubscriberMassSubscribeForm
Expanded class hierarchy of SubscriberMassSubscribeForm
1 string reference to 'SubscriberMassSubscribeForm'
File
- src/
Form/ SubscriberMassSubscribeForm.php, line 14
Namespace
Drupal\simplenews\FormView source
class SubscriberMassSubscribeForm extends FormBase {
/**
* The language manager.
*
* @var \Drupal\Core\Language\LanguageManagerInterface
*/
protected $languageManager;
/**
* Constructs a new SubscriberMassSubscribeForm.
*
* @param \Drupal\Core\Language\LanguageManagerInterface $language_manager
* The language manager.
*/
public function __construct(LanguageManagerInterface $language_manager) {
$this->languageManager = $language_manager;
}
/**
* {@inheritdoc}
*/
public static function create(ContainerInterface $container) {
return new static($container
->get('language_manager'));
}
/**
* {@inheritdoc}
*/
public function getFormId() {
return 'simplenews_subscriber_mass_subscribe';
}
/**
* {@inheritdoc}
*/
public function buildForm(array $form, FormStateInterface $form_state) {
$form['emails'] = array(
'#type' => 'textarea',
'#title' => t('Email addresses'),
'#cols' => 60,
'#rows' => 5,
'#description' => t('Email addresses must be separated by comma, space or newline.'),
);
$form['newsletters'] = array(
'#type' => 'checkboxes',
'#title' => t('Subscribe to'),
'#options' => simplenews_newsletter_list(),
'#required' => TRUE,
);
foreach (simplenews_newsletter_get_all() as $id => $newsletter) {
$form['newsletters'][$id]['#description'] = Html::escape($newsletter->description);
}
$form['resubscribe'] = array(
'#type' => 'checkbox',
'#title' => t('Force resubscription'),
'#description' => t('If checked, previously unsubscribed e-mail addresses will be resubscribed. Consider that this might be against the will of your users.'),
);
// Include language selection when the site is multilingual.
// Default value is the empty string which will result in receiving emails
// in the site's default language.
if ($this->languageManager
->isMultilingual()) {
$options[''] = t('Site default language');
$languages = $this->languageManager
->getLanguages();
foreach ($languages as $langcode => $language) {
$options[$langcode] = $language
->getName();
}
$form['language'] = array(
'#type' => 'radios',
'#title' => t('Anonymous user preferred language'),
'#default_value' => '',
'#options' => $options,
'#description' => t('New subscriptions will be subscribed with the selected preferred language. The language of existing subscribers is unchanged.'),
);
}
else {
$form['language'] = array(
'#type' => 'value',
'#value' => '',
);
}
$form['submit'] = array(
'#type' => 'submit',
'#value' => t('Subscribe'),
);
return $form;
}
/**
* {@inheritdoc}
*/
public function validateForm(array &$form, FormStateInterface $form_state) {
parent::validateForm($form, $form_state);
}
/**
* {@inheritdoc}
*/
public function submitForm(array &$form, FormStateInterface $form_state) {
$added = array();
$invalid = array();
$unsubscribed = array();
$checked_newsletters = array_keys(array_filter($form_state
->getValue('newsletters')));
$langcode = $form_state
->getValue('language');
$emails = preg_split("/[\\s,]+/", $form_state
->getValue('emails'));
foreach ($emails as $email) {
$email = trim($email);
if ($email == '') {
continue;
}
if (valid_email_address($email)) {
$subscriber = simplenews_subscriber_load_by_mail($email);
/** @var \Drupal\simplenews\Subscription\SubscriptionManagerInterface $subscription_manager */
$subscription_manager = \Drupal::service('simplenews.subscription_manager');
foreach (simplenews_newsletter_load_multiple($checked_newsletters) as $newsletter) {
// If there is a valid subscriber, check if there is a subscription for
// the current newsletter and if this subscription has the status
// unsubscribed.
$is_unsubscribed = $subscriber ? $subscriber
->isUnsubscribed($newsletter
->id()) : FALSE;
if (!$is_unsubscribed || $form_state
->getValue('resubscribe') == TRUE) {
$subscription_manager
->subscribe($email, $newsletter
->id(), FALSE, 'mass subscribe', $langcode);
$added[] = $email;
}
else {
$unsubscribed[$newsletter
->label()][] = $email;
}
}
}
else {
$invalid[] = $email;
}
}
if ($added) {
$added = implode(", ", $added);
$this
->messenger()
->addMessage(t('The following addresses were added or updated: %added.', array(
'%added' => $added,
)));
$list_names = array();
foreach (simplenews_newsletter_load_multiple($checked_newsletters) as $newsletter) {
$list_names[] = $newsletter
->label();
}
$this
->messenger()
->addMessage(t('The addresses were subscribed to the following newsletters: %newsletters.', array(
'%newsletters' => implode(', ', $list_names),
)));
}
else {
$this
->messenger()
->addMessage(t('No addresses were added.'));
}
if ($invalid) {
$invalid = implode(", ", $invalid);
$this
->messenger()
->addError(t('The following addresses were invalid: %invalid.', array(
'%invalid' => $invalid,
)));
}
foreach ($unsubscribed as $name => $subscribers) {
$subscribers = implode(", ", $subscribers);
$this
->messenger()
->addWarning(t('The following addresses were skipped because they have previously unsubscribed from %name: %unsubscribed.', array(
'%name' => $name,
'%unsubscribed' => $subscribers,
)));
}
if (!empty($unsubscribed)) {
$this
->messenger()
->addWarning(t("If you would like to resubscribe them, use the 'Force resubscription' option."));
}
// Return to the parent page.
$form_state
->setRedirect('view.simplenews_subscribers.page_1');
}
}
Members
Name | Modifiers | Type | Description | Overrides |
---|---|---|---|---|
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. | |
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. | |
SubscriberMassSubscribeForm:: |
protected | property | The language manager. | |
SubscriberMassSubscribeForm:: |
public | function |
Form constructor. Overrides FormInterface:: |
|
SubscriberMassSubscribeForm:: |
public static | function |
Instantiates a new instance of this class. Overrides FormBase:: |
|
SubscriberMassSubscribeForm:: |
public | function |
Returns a unique string identifying the form. Overrides FormInterface:: |
|
SubscriberMassSubscribeForm:: |
public | function |
Form submission handler. Overrides FormInterface:: |
|
SubscriberMassSubscribeForm:: |
public | function |
Form validation handler. Overrides FormBase:: |
|
SubscriberMassSubscribeForm:: |
public | function | Constructs a new SubscriberMassSubscribeForm. | |
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. |