BP_Notifications_Template::__construct( array $args = array() )
Constructor method.
Description
See also
- bp_has_notifications(): For information on the array format.
Parameters
- $args
-
(Optional) An array of arguments. See bp_has_notifications() for more details.
Default value: array()
Source
File: bp-notifications/classes/class-bp-notifications-template.php
public function __construct( $args = array() ) { // Parse arguments. $r = wp_parse_args( $args, array( 'id' => false, 'user_id' => 0, 'item_id' => false, 'secondary_item_id' => false, 'component_name' => bp_notifications_get_registered_components(), 'component_action' => false, 'is_new' => true, 'search_terms' => '', 'order_by' => 'date_notified', 'sort_order' => 'DESC', 'page_arg' => 'npage', 'page' => 1, 'per_page' => 25, 'max' => null, 'meta_query' => false, 'date_query' => false ) ); // Sort order direction. $orders = array( 'ASC', 'DESC' ); if ( ! empty( $_GET['sort_order'] ) && in_array( $_GET['sort_order'], $orders ) ) { $r['sort_order'] = $_GET['sort_order']; } else { $r['sort_order'] = in_array( $r['sort_order'], $orders ) ? $r['sort_order'] : 'DESC'; } // Setup variables. $this->pag_arg = sanitize_key( $r['page_arg'] ); $this->pag_page = bp_sanitize_pagination_arg( $this->pag_arg, $r['page'] ); $this->pag_num = bp_sanitize_pagination_arg( 'num', $r['per_page'] ); $this->user_id = $r['user_id']; $this->is_new = $r['is_new']; $this->search_terms = $r['search_terms']; $this->order_by = $r['order_by']; $this->sort_order = $r['sort_order']; $this->query_vars = array( 'id' => $r['id'], 'user_id' => $this->user_id, 'item_id' => $r['item_id'], 'secondary_item_id' => $r['secondary_item_id'], 'component_name' => $r['component_name'], 'component_action' => $r['component_action'], 'meta_query' => $r['meta_query'], 'date_query' => $r['date_query'], 'is_new' => $this->is_new, 'search_terms' => $this->search_terms, 'order_by' => $this->order_by, 'sort_order' => $this->sort_order, 'page' => $this->pag_page, 'per_page' => $this->pag_num, ); // Setup the notifications to loop through. $this->notifications = BP_Notifications_Notification::get( $this->query_vars ); $this->total_notification_count = BP_Notifications_Notification::get_total_count( $this->query_vars ); if ( empty( $this->notifications ) ) { $this->notification_count = 0; $this->total_notification_count = 0; } else { if ( ! empty( $r['max'] ) ) { if ( $r['max'] >= count( $this->notifications ) ) { $this->notification_count = count( $this->notifications ); } else { $this->notification_count = (int) $r['max']; } } else { $this->notification_count = count( $this->notifications ); } } if ( (int) $this->total_notification_count && (int) $this->pag_num ) { $add_args = array( 'sort_order' => $this->sort_order, ); $this->pag_links = paginate_links( array( 'base' => add_query_arg( $this->pag_arg, '%#%' ), 'format' => '', 'total' => ceil( (int) $this->total_notification_count / (int) $this->pag_num ), 'current' => $this->pag_page, 'prev_text' => __( '←', 'buddyboss' ), 'next_text' => __( '→', 'buddyboss' ), 'mid_size' => 1, 'add_args' => $add_args, ) ); } }
Changelog
Version | Description |
---|---|
BuddyPress 1.9.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.