Class Drupal\history\Hook\HistoryViewsHooks - Source Code

Primary tabs

API docs: https://api.drupal.org/api/drupal/core!modules!history!src!Hook!HistoryViewsHooks.php/11.3.x

GitLab: https://git.drupalcode.org/project/drupal/-/blob/11.3.x/core/modules/history/src/Hook/HistoryViewsHooks.php

Location: /core/modules/history/src/Hook/HistoryViewsHooks.php

    
        
namespace Drupal\history\Hook;

use Drupal\Core\Hook\Attribute\Hook;
use Drupal\Core\StringTranslation\StringTranslationTrait;

/**
 * Hook implementations for history.
 */
class HistoryViewsHooks {

  use StringTranslationTrait;

  /**
   * Implements hook_views_data().
   */
  #[Hook('views_data')]
  public function viewsData(): array {
    // History table
    // We're actually defining a specific instance of the table, so let's
    // alias it so that we can later add the real table for other purposes if we
    // need it.
    $data['history']['table']['group'] = $this->t('Content');
    // Explain how this table joins to others.
    $data['history']['table']['join'] = [
          // Directly links to node table.
      'node_field_data' => [
        'table' => 'history',
        'left_field' => 'nid',
        'field' => 'nid',
        'extra' => [
                  [
                    'field' => 'uid',
                    'value' => '***CURRENT_USER***',
                    'numeric' => TRUE,
                  ],
        ],
      ],
    ];
    $data['history']['timestamp'] = [
      'title' => $this->t('Has new content'),
      'field' => [
        'id' => 'history_user_timestamp',
        'help' => $this->t('Show a marker if the content is new or updated.'),
      ],
      'filter' => [
        'help' => $this->t('Show only content that is new or updated.'),
        'id' => 'history_user_timestamp',
      ],
    ];
    return $data;
  }

  /**
   * Implements hook_views_data_alter().
   */
  #[Hook('views_data_alter')]
  public function viewsDataAlter(&$data): void {
    if (!\Drupal::moduleHandler()->moduleExists('comment')) {
      return;
    }
    // New comments are only supported for node table because it requires the
    // history table.
    $data['node']['new_comments'] = [
      'title' => $this->t('New comments'),
      'help' => $this->t('The number of new comments on the node.'),
      'field' => [
        'id' => 'node_new_comments',
        'no group by' => TRUE,
      ],
    ];
  }

}