BP_Notifications_Notification::get_grouped_notifications_for_user( int $user_id )
Get a user’s unread notifications, grouped by component and action.
Description
Multiple notifications of the same type (those that share the same component_name and component_action) are collapsed for formatting as "You have 5 pending connection requests", etc. See bp_notifications_get_notifications_for_user(). For a full-fidelity list of user notifications, use bp_notifications_get_all_notifications_for_user().
Parameters
- $user_id
-
(Required) ID of the user whose notifications are being fetched.
Return
(array) Notifications items for formatting into a list.
Source
File: bp-notifications/classes/class-bp-notifications-notification.php
1181 1182 1183 1184 1185 1186 1187 1188 1189 1190 1191 1192 1193 1194 1195 1196 1197 1198 1199 1200 1201 1202 1203 1204 1205 1206 1207 1208 1209 1210 1211 | public static function get_grouped_notifications_for_user( $user_id ) { global $wpdb ; // Load BuddyPress. $bp = buddypress(); // SELECT. $select_sql = "SELECT id, user_id, item_id, secondary_item_id, component_name, component_action, date_notified, is_new, COUNT(id) as total_count " ; // FROM. $from_sql = "FROM {$bp->notifications->table_name} n " ; // WHERE. $where_sql = self::get_where_sql( array ( 'user_id' => $user_id , 'is_new' => 1, 'component_name' => bp_notifications_get_registered_components(), ), $select_sql , $from_sql ); // GROUP $group_sql = "GROUP BY user_id, component_name, component_action" ; // SORT $order_sql = "ORDER BY date_notified desc" ; // Concatenate query parts. $sql = "{$select_sql} {$from_sql} {$where_sql} {$group_sql} {$order_sql}" ; // Return the queried results. return $wpdb ->get_results( $sql ); } |
Changelog
Version | Description |
---|---|
BuddyPress 3.0.0 | Introduced. |
Questions?
We're always happy to help with code or other questions you might have! Search our developer docs, contact support, or connect with our sales team.