class PushNotificationsSendMessageForm in Push Notifications 8
Class PushNotificationsSendMessageForm.
@package Drupal\push_notifications\Form
Hierarchy
- class \Drupal\Core\Form\FormBase implements ContainerInjectionInterface, FormInterface uses DependencySerializationTrait, LoggerChannelTrait, MessengerTrait, LinkGeneratorTrait, RedirectDestinationTrait, UrlGeneratorTrait, StringTranslationTrait- class \Drupal\push_notifications\Form\PushNotificationsSendMessageForm
 
Expanded class hierarchy of PushNotificationsSendMessageForm
1 string reference to 'PushNotificationsSendMessageForm'
File
- src/Form/ PushNotificationsSendMessageForm.php, line 13 
Namespace
Drupal\push_notifications\FormView source
class PushNotificationsSendMessageForm extends FormBase {
  /**
   * {@inheritdoc}
   */
  public function getFormId() {
    return 'send_message_form';
  }
  /**
   * {@inheritdoc}
   */
  public function buildForm(array $form, FormStateInterface $form_state) {
    $form['instructions'] = array(
      '#type' => 'item',
      '#markup' => $this
        ->t('Compose the elements of your push notification message.'),
    );
    $form['message'] = array(
      '#type' => 'textfield',
      '#title' => $this
        ->t('Push Message'),
      '#description' => $this
        ->t('Compose the message to send out (@limit characters max.)', array(
        '@limit' => PUSH_NOTIFICATIONS_APNS_PAYLOAD_SIZE_LIMIT,
      )),
      '#required' => TRUE,
      '#size' => 128,
      '#maxlength' => PUSH_NOTIFICATIONS_APNS_PAYLOAD_SIZE_LIMIT,
    );
    // Only show Android option if GCM Api Key is available..
    $recipients_options = array(
      PUSH_NOTIFICATIONS_NETWORK_ID_IOS => t('iOS (Apple Push Notifications)'),
    );
    if (!empty(\Drupal::config('push_notifications.gcm')
      ->get('api_key'))) {
      $recipients_options[PUSH_NOTIFICATIONS_NETWORK_ID_ANDROID] = t('Android (Google Cloud Messaging)');
    }
    $form['networks'] = array(
      '#type' => 'checkboxes',
      '#title' => t('Target Networks'),
      '#description' => t('Select the networks you want to reach with this message.'),
      '#options' => $recipients_options,
    );
    $form['submit'] = array(
      '#type' => 'submit',
      '#value' => t('Send Push Notification'),
    );
    return $form;
  }
  /**
   * {@inheritdoc}
   */
  public function validateForm(array &$form, FormStateInterface $form_state) {
    // Make sure at least one network is selected.
    $networks = $form_state
      ->getValue('networks');
    if (empty(array_filter($networks))) {
      $form_state
        ->setErrorByName('networks', $this
        ->t('Please select at least one of the target networks.'));
    }
    // Determine recipients.
    $tokens = push_notifications_get_tokens(array(
      'networks' => $networks,
    ));
    if (empty($tokens)) {
      // Onlyproceed if tokens were found.
      $form_state
        ->setErrorByName('networks', $this
        ->t('No tokens found for your selected networks.'));
    }
    else {
      // Pass the tokens to the submit handler.
      $form_state
        ->setTemporaryValue('tokens', $tokens);
    }
    parent::validateForm($form, $form_state);
  }
  /**
   * {@inheritdoc}
   */
  public function submitForm(array &$form, FormStateInterface $form_state) {
    $messageSender = \Drupal::service('push_notifications.message_sender_list');
    $messageSender
      ->setTokens($form_state
      ->getTemporaryValue('tokens'));
    $messageSender
      ->setMessage($form_state
      ->getValue('message'));
    $messageSender
      ->dispatch();
    $results = $messageSender
      ->getResults();
    // Display result for each network.
    foreach ($results as $network => $result) {
      if (empty($result['count_attempted'])) {
        // Only display results for networks with tokens.
        continue;
      }
      drupal_set_message($this
        ->t('@network: Attempted to send @count_attempted tokens, sent @count_success.', array(
        '@network' => strtoupper($network),
        '@count_attempted' => $result['count_attempted'],
        '@count_success' => $result['count_success'],
      )));
    }
  }
}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:: | public static | function | Instantiates a new instance of this class. Overrides ContainerInjectionInterface:: | 87 | 
| 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. | |
| PushNotificationsSendMessageForm:: | public | function | Form constructor. Overrides FormInterface:: | |
| PushNotificationsSendMessageForm:: | public | function | Returns a unique string identifying the form. Overrides FormInterface:: | |
| PushNotificationsSendMessageForm:: | public | function | Form submission handler. Overrides FormInterface:: | |
| PushNotificationsSendMessageForm:: | public | function | Form validation handler. Overrides FormBase:: | |
| 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. | 
