public function HistoryUserTimestamp::render in Drupal 9
Same name and namespace in other branches
- 8 core/modules/history/src/Plugin/views/field/HistoryUserTimestamp.php \Drupal\history\Plugin\views\field\HistoryUserTimestamp::render()
Renders the field.
Parameters
\Drupal\views\ResultRow $values: The values retrieved from a single row of a view's query result.
Return value
string|\Drupal\Component\Render\MarkupInterface The rendered output. If the output is safe it will be wrapped in an object that implements MarkupInterface. If it is empty or unsafe it will be a string.
Overrides Node::render
File
- core/modules/ history/ src/ Plugin/ views/ field/ HistoryUserTimestamp.php, line 84 
Class
- HistoryUserTimestamp
- Field handler to display the marker for new content.
Namespace
Drupal\history\Plugin\views\fieldCode
public function render(ResultRow $values) {
  // Let's default to 'read' state.
  // This code shadows node_mark, but it reads from the db directly and
  // we already have that info.
  $mark = MARK_READ;
  if (\Drupal::currentUser()
    ->isAuthenticated()) {
    $last_read = $this
      ->getValue($values);
    $changed = $this
      ->getValue($values, 'changed');
    $last_comment = \Drupal::moduleHandler()
      ->moduleExists('comment') && !empty($this->options['comments']) ? $this
      ->getValue($values, 'last_comment') : 0;
    if (!$last_read && $changed > HISTORY_READ_LIMIT) {
      $mark = MARK_NEW;
    }
    elseif ($changed > $last_read && $changed > HISTORY_READ_LIMIT) {
      $mark = MARK_UPDATED;
    }
    elseif ($last_comment > $last_read && $last_comment > HISTORY_READ_LIMIT) {
      $mark = MARK_UPDATED;
    }
    $build = [
      '#theme' => 'mark',
      '#status' => $mark,
    ];
    return $this
      ->renderLink(\Drupal::service('renderer')
      ->render($build), $values);
  }
}