dbprefix; $max = 24; //this works but is wildly inefficient //$annotations = get_annotations(0, "object", "image", "tp_view", "", "", 5000); $sql = "SELECT ent.guid, count( * ) AS views FROM " . $prefix . "entities ent INNER JOIN " . $prefix . "entity_subtypes sub ON ent.subtype = sub.id AND sub.subtype = 'image' INNER JOIN " . $prefix . "annotations ann1 ON ann1.entity_guid = ent.guid INNER JOIN " . $prefix . "metastrings ms ON ms.id = ann1.name_id AND ms.string = 'generic_comment' GROUP BY ent.guid ORDER BY views DESC LIMIT $max"; $result = get_data($sql); $entities = array(); foreach ($result as $entity) { $entities[] = get_entity($entity->guid); } tidypics_mostviewed_submenus(); $title = elgg_echo("tidypics:mostcommented"); $area2 = elgg_view_title($title); $area2 .= elgg_view_entity_list($entities, $max, 0, $max, false); $body = elgg_view_layout('two_column_left_sidebar', '', $area2); page_draw($title, $body);