$contact_field = ((($contact["contact-type"] == self::TYPE_COMMUNITY) || ($contact['network'] == Protocol::MAIL)) ? 'owner-id' : 'author-id');
if ($thread_mode) {
- $condition = ["`$contact_field` = ? AND `gravity` = ? AND " . $sql,
- $cid, GRAVITY_PARENT, local_user()];
+ $condition = ["`$contact_field` = ? AND (`gravity` = ? OR (`gravity` = ? AND `vid` = ?)) AND " . $sql,
+ $cid, GRAVITY_PARENT, GRAVITY_ACTIVITY, Verb::getID(Activity::ANNOUNCE), local_user()];
} else {
$condition = ["`$contact_field` = ? AND `gravity` IN (?, ?) AND " . $sql,
$cid, GRAVITY_PARENT, GRAVITY_COMMENT, local_user()];
'limit' => [$pager->getStart(), $pager->getItemsPerPage()]];
if ($thread_mode) {
- $r = Item::selectThreadForUser(local_user(), ['uri'], $condition, $params);
-
- $items = Item::inArray($r);
+ $r = Item::selectForUser(local_user(), ['uri', 'gravity', 'parent-uri'], $condition, $params);
+ $items = [];
+ while ($item = DBA::fetch($r)) {
+ if ($item['gravity'] != GRAVITY_PARENT) {
+ $item['uri'] = $item['parent-uri'];
+ }
+ unset($item['parent-uri']);
+ unset($item['gravity']);
+
+ $items[] = $item;
+ }
+ DBA::close($r);
$o = conversation($a, $items, 'contacts', $update, false, 'commented', local_user());
} else {