function node_mark

Same name in other branches
  1. 7.x modules/node/node.module \node_mark()
  2. 9 core/modules/node/node.module \node_mark()
  3. 10 core/modules/node/node.module \node_mark()
  4. 11.x core/modules/node/node.module \node_mark()

Determines the type of marker to be displayed for a given node.

Parameters

int $nid: Node ID whose history supplies the "last viewed" timestamp.

int $timestamp: Time which is compared against node's "last viewed" timestamp.

Return value

int One of the MARK constants.

1 call to node_mark()
NodeListBuilder::buildRow in core/modules/node/src/NodeListBuilder.php
Builds a row for an entity in the entity listing.

File

core/modules/node/node.module, line 248

Code

function node_mark($nid, $timestamp) {
    $cache =& drupal_static(__FUNCTION__, []);
    if (\Drupal::currentUser()->isAnonymous() || !\Drupal::moduleHandler()->moduleExists('history')) {
        return MARK_READ;
    }
    if (!isset($cache[$nid])) {
        $cache[$nid] = history_read($nid);
    }
    if ($cache[$nid] == 0 && $timestamp > HISTORY_READ_LIMIT) {
        return MARK_NEW;
    }
    elseif ($timestamp > $cache[$nid] && $timestamp > HISTORY_READ_LIMIT) {
        return MARK_UPDATED;
    }
    return MARK_READ;
}

Buggy or inaccurate documentation? Please file an issue. Need support? Need help programming? Connect with the Drupal community.