function comment_view_multiple
Same name in other branches
- 8.9.x core/modules/comment/comment.module \comment_view_multiple()
Construct a drupal_render() style array from an array of loaded comments.
Parameters
$comments: An array of comments as returned by comment_load_multiple().
$node: The node the comments are attached to.
$view_mode: View mode, e.g. 'full', 'teaser'...
$weight: An integer representing the weight of the first comment in the list.
$langcode: A string indicating the language field values are to be shown in. If no language is provided the current content language is used.
Return value
An array in the format expected by drupal_render().
2 calls to comment_view_multiple()
- comment_node_page_additions in modules/
comment/ comment.module - Build the comment-related elements for node detail pages.
- comment_node_update_index in modules/
comment/ comment.module - Implements hook_node_update_index().
File
-
modules/
comment/ comment.module, line 1111
Code
function comment_view_multiple($comments, $node, $view_mode = 'full', $weight = 0, $langcode = NULL) {
$build = array();
$entities_by_view_mode = entity_view_mode_prepare('comment', $comments, $view_mode, $langcode);
foreach ($entities_by_view_mode as $entity_view_mode => $entities) {
field_attach_prepare_view('comment', $entities, $entity_view_mode, $langcode);
entity_prepare_view('comment', $entities, $langcode);
foreach ($entities as $entity) {
$build[$entity->cid] = comment_view($entity, $node, $entity_view_mode, $langcode);
}
}
foreach ($comments as $comment) {
$build[$comment->cid]['#weight'] = $weight;
$weight++;
}
// Sort here, to preserve the input order of the entities that were passed to
// this function.
uasort($build, 'element_sort');
$build['#sorted'] = TRUE;
return $build;
}
Buggy or inaccurate documentation? Please file an issue. Need support? Need help programming? Connect with the Drupal community.