class HistoryHooks
Hook implementations for history.
Hierarchy
- class \Drupal\history\Hook\HistoryHooks uses \Drupal\Core\StringTranslation\StringTranslationTrait
Expanded class hierarchy of HistoryHooks
File
- 
              core/modules/ history/ src/ Hook/ HistoryHooks.php, line 17 
Namespace
Drupal\history\HookView source
class HistoryHooks {
  use StringTranslationTrait;
  
  /**
   * Constructs a new HistoryHooks object.
   *
   * @param \Drupal\Core\Session\AccountInterface $currentUser
   *   The current user account.
   */
  public function __construct(protected AccountInterface $currentUser) {
  }
  
  /**
   * Implements hook_help().
   */
  public function help($route_name, RouteMatchInterface $route_match) : ?string {
    switch ($route_name) {
      case 'help.page.history':
        $output = '<h2>' . $this->t('About') . '</h2>';
        $output .= '<p>' . $this->t('The History module keeps track of which content a user has read. It marks content as <em>new</em> or <em>updated</em> depending on the last time the user viewed it. History records that are older than one month are removed during cron, which means that content older than one month is always considered <em>read</em>. The History module does not have a user interface but it provides a filter to <a href=":views-help">Views</a> to show new or updated content. For more information, see the <a href=":url">online documentation for the History module</a>.', [
          ':views-help' => \Drupal::moduleHandler()->moduleExists('views') ? Url::fromRoute('help.page', [
            'name' => 'views',
          ])->toString() : '#',
          ':url' => 'https://www.drupal.org/documentation/modules/history',
        ]) . '</p>';
        return $output;
    }
    return NULL;
  }
  
  /**
   * Implements hook_cron().
   */
  public function cron() : void {
    \Drupal::database()->delete('history')
      ->condition('timestamp', HISTORY_READ_LIMIT, '<')
      ->execute();
  }
  
  /**
   * Implements hook_ENTITY_TYPE_view_alter() for node entities.
   */
  public function nodeViewAlter(array &$build, EntityInterface $node, EntityViewDisplayInterface $display) : void {
    if (\Drupal::moduleHandler()->moduleExists('comment')) {
      $build['#attributes']['data-history-node-id'] = $node->id();
    }
    if ($node->isNew() || isset($node->in_preview)) {
      return;
    }
    // Update the history table, stating that this user viewed this node.
    if ($display->getOriginalMode() === 'full') {
      $build['#cache']['contexts'][] = 'user.roles:authenticated';
      if (\Drupal::currentUser()->isAuthenticated()) {
        // When the window's "load" event is triggered, mark the node as read.
        // This still allows for Drupal behaviors (which are triggered on the
        // "DOMContentReady" event) to add "new" and "updated" indicators.
        $build['#attached']['library'][] = 'history/mark-as-read';
        $build['#attached']['drupalSettings']['history']['nodesToMarkAsRead'][$node->id()] = TRUE;
      }
    }
  }
  
  /**
   * Implements hook_ENTITY_TYPE_delete() for node entities.
   */
  public function nodeDelete(EntityInterface $node) : void {
    \Drupal::database()->delete('history')
      ->condition('nid', $node->id())
      ->execute();
  }
  
  /**
   * Implements hook_user_cancel().
   */
  public function userCancel($edit, UserInterface $account, $method) : void {
    switch ($method) {
      case 'user_cancel_reassign':
        \Drupal::database()->delete('history')
          ->condition('uid', $account->id())
          ->execute();
        break;
    }
  }
  
  /**
   * Implements hook_ENTITY_TYPE_delete() for user entities.
   */
  public function userDelete($account) : void {
    \Drupal::database()->delete('history')
      ->condition('uid', $account->id())
      ->execute();
  }
  
  /**
   * Implements hook_ENTITY_TYPE_view for comment entities.
   */
  public function commentView(array &$build, EntityInterface $entity, EntityViewDisplayInterface $display, $view_mode) : void {
    if (!$this->currentUser
      ->isAuthenticated()) {
      return;
    }
    /** @var \Drupal\comment\CommentInterface $entity */
    $commented_entity = $entity->getCommentedEntity();
    if ($commented_entity?->getEntityTypeId() !== 'node') {
      return;
    }
    $build[$entity->id()]['#attached']['library'][] = 'history/drupal.comment-new-indicator';
    // Embed the metadata for the comment "new" indicators on this node.
    $build[$entity->id()]['history'] = [
      '#lazy_builder' => [
        '\\Drupal\\history\\HistoryRenderCallback::lazyBuilder',
        [
          $commented_entity->id(),
        ],
      ],
      '#create_placeholder' => TRUE,
    ];
  }
}Members
| Title Sort descending | Modifiers | Object type | Summary | Overrides | 
|---|---|---|---|---|
| HistoryHooks::commentView | public | function | Implements hook_ENTITY_TYPE_view for comment entities. | |
| HistoryHooks::cron | public | function | Implements hook_cron(). | |
| HistoryHooks::help | public | function | Implements hook_help(). | |
| HistoryHooks::nodeDelete | public | function | Implements hook_ENTITY_TYPE_delete() for node entities. | |
| HistoryHooks::nodeViewAlter | public | function | Implements hook_ENTITY_TYPE_view_alter() for node entities. | |
| HistoryHooks::userCancel | public | function | Implements hook_user_cancel(). | |
| HistoryHooks::userDelete | public | function | Implements hook_ENTITY_TYPE_delete() for user entities. | |
| HistoryHooks::__construct | public | function | Constructs a new HistoryHooks object. | |
| StringTranslationTrait::$stringTranslation | protected | property | The string translation service. | 3 | 
| StringTranslationTrait::formatPlural | protected | function | Formats a string containing a count of items. | |
| StringTranslationTrait::getNumberOfPlurals | protected | function | Returns the number of plurals supported by a given language. | |
| StringTranslationTrait::getStringTranslation | protected | function | Gets the string translation service. | |
| StringTranslationTrait::setStringTranslation | public | function | Sets the string translation service to use. | 2 | 
| StringTranslationTrait::t | protected | function | Translates a string to the current language or to a given language. | 1 | 
Buggy or inaccurate documentation? Please file an issue. Need support? Need help programming? Connect with the Drupal community.
