activity->slug );
}
/**
* Output the activity component root slug.
*
* @since 1.5.0
*
*/
function bp_activity_root_slug() {
echo bp_get_activity_root_slug();
}
/**
* Return the activity component root slug.
*
* @since 1.5.0
*
*
* @return string The activity component root slug.
*/
function bp_get_activity_root_slug() {
/**
* Filters the activity component root slug.
*
* @since 1.5.0
*
* @param string $root_slug Activity component root slug.
*/
return apply_filters( 'bp_get_activity_root_slug', buddypress()->activity->root_slug );
}
/**
* Output activity directory permalink.
*
* @since 1.5.0
*
*/
function bp_activity_directory_permalink() {
echo esc_url( bp_get_activity_directory_permalink() );
}
/**
* Return activity directory permalink.
*
* @since 1.5.0
*
*
* @return string Activity directory permalink.
*/
function bp_get_activity_directory_permalink() {
/**
* Filters the activity directory permalink.
*
* @since 1.5.0
*
* @param string $url Permalink url for the activity directory.
*/
return apply_filters( 'bp_get_activity_directory_permalink', trailingslashit( bp_get_root_domain() . '/' . bp_get_activity_root_slug() ) );
}
/**
* Initialize the activity loop.
*
* Based on the $args passed, bp_has_activities() populates the
* $activities_template global, enabling the use of BuddyPress templates and
* template functions to display a list of activity items.
*
* @since 1.0.0
* @since 2.4.0 Introduced the `$fields` parameter.
*
* @global object $activities_template {@link BP_Activity_Template}
*
* @param array|string $args {
* Arguments for limiting the contents of the activity loop. Most arguments
* are in the same format as {@link BP_Activity_Activity::get()}. However,
* because the format of the arguments accepted here differs in a number of
* ways, and because bp_has_activities() determines some default arguments in
* a dynamic fashion, we list all accepted arguments here as well.
*
* Arguments can be passed as an associative array, or as a URL querystring
* (eg, 'user_id=4&display_comments=threaded').
*
* @type int $page Which page of results to fetch. Using page=1 without per_page will result
* in no pagination. Default: 1.
* @type int|bool $per_page Number of results per page. Default: 20.
* @type string $page_arg String used as a query parameter in pagination links. Default: 'acpage'.
* @type int|bool $max Maximum number of results to return. Default: false (unlimited).
* @type string $fields Activity fields to retrieve. 'all' to fetch entire activity objects,
* 'ids' to get only the activity IDs. Default 'all'.
* @type string|bool $count_total If true, an additional DB query is run to count the total activity items
* for the query. Default: false.
* @type string $sort 'ASC' or 'DESC'. Default: 'DESC'.
* @type array|bool $exclude Array of activity IDs to exclude. Default: false.
* @type array|bool $in Array of IDs to limit query by (IN). 'in' is intended to be used in
* conjunction with other filter parameters. Default: false.
* @type array|bool $include Array of exact activity IDs to query. Providing an 'include' array will
* override all other filters passed in the argument array. When viewing the
* permalink page for a single activity item, this value defaults to the ID of
* that item. Otherwise the default is false.
* @type array $meta_query Limit by activitymeta by passing an array of meta_query conditions. See
* {@link WP_Meta_Query::queries} for a description of the syntax.
* @type array $date_query Limit by date by passing an array of date_query conditions. See first
* parameter of {@link WP_Date_Query::__construct()} for syntax.
* @type array $filter_query Advanced activity filtering. See {@link BP_Activity_Query::__construct()}.
* @type string $search_terms Limit results by a search term. Default: false.
* @type string $scope Use a BuddyPress pre-built filter.
* - 'just-me' retrieves items belonging only to a user; this is equivalent
* to passing a 'user_id' argument.
* - 'friends' retrieves items belonging to the friends of a user.
* - 'groups' retrieves items belonging to groups to which a user belongs to.
* - 'favorites' retrieves a user's favorited activity items.
* - 'mentions' retrieves items where a user has received an @-mention.
* The default value of 'scope' is set to one of the above if that value
* appears in the appropriate place in the URL; eg, 'scope' will be 'groups'
* when visiting http://example.com/members/joe/activity/groups/. Otherwise
* defaults to false.
* @type int|array|bool $user_id The ID(s) of user(s) whose activity should be fetched. Pass a single ID or
* an array of IDs. When viewing a user profile page (but not that user's
* activity subpages, ie My Friends, My Groups, etc), 'user_id' defaults to
* the ID of the displayed user. Otherwise the default is false.
* @type string|array|bool $object Filters by the `component` column in the database, which is generally the
* component ID in the case of BuddyPress components, or the plugin slug in
* the case of plugins. For example, 'groups' will limit results to those that
* are associated with the BP Groups component. Accepts a single component
* string, or an array of multiple components. Defaults to 'groups' when
* viewing the page of a single group, the My Groups activity filter, or the
* Activity > Groups filter of a user profile. Otherwise defaults to false.
* @type string|array|bool $action Filters by the `type` column in the database, which is a string
* categorizing the activity item (eg, 'new_blog_post', 'created_group').
* Accepts a comma-delimited string or an array of types. Default: false.
* @type int|array|bool $primary_id Filters by the `item_id` column in the database. The meaning of
* 'primary_id' differs between components/types; for example, in the case of
* 'created_group', 'primary_id' is the ID of the group. Accepts a single ID,
* or an array of multiple IDs. When viewing a single group, defaults to the
* current group ID. When viewing a user's Groups stream page, defaults to the
* IDs of the user's groups. Otherwise defaults to false.
* @type int|array|bool $secondary_id Filters by the `secondary_item_id` column in the database. The meaning of
* 'secondary_id' differs between components/types. Accepts a single ID, or an
* array of multiple IDs. Defaults to false.
* @type int $offset Return only activity items with an ID greater than or equal to this one.
* Note that providing an offset will disable pagination. Default: false.
* @type string|bool $display_comments How to handle activity comments. Possible values:
* - 'threaded' - comments appear in a threaded tree, under their parent
* items.
* - 'stream' - the activity stream is presented in a flat manner, with
* comments sorted in chronological order alongside other activity items.
* - false - don't fetch activity comments at all.
* Default: 'threaded'.
* @type bool $show_hidden Whether to show items marked hide_sitewide. Defaults to false, except in
* the following cases:
* - User is viewing his own activity stream.
* - User is viewing the activity stream of a non-public group of which he
* is a member.
* @type string|bool $spam Spam status. 'ham_only', 'spam_only', or false to show all activity
* regardless of spam status. Default: 'ham_only'.
* @type bool $populate_extras Whether to pre-fetch the activity metadata for the queried items.
* Default: true.
* }
* @return bool Returns true when activities are found, otherwise false.
*/
function bp_has_activities( $args = '' ) {
global $activities_template;
// Get BuddyPress.
$bp = buddypress();
/*
* Smart Defaults.
*/
// User filtering.
$user_id = bp_displayed_user_id()
? bp_displayed_user_id()
: false;
// Group filtering.
if ( bp_is_group() ) {
$object = $bp->groups->id;
$primary_id = bp_get_current_group_id();
$show_hidden = (bool) ( groups_is_user_member( bp_loggedin_user_id(), $primary_id ) || bp_current_user_can( 'bp_moderate' ) );
} else {
$object = false;
$primary_id = false;
$show_hidden = false;
}
// The default scope should recognize custom slugs.
$scope = array_key_exists( bp_current_action(), (array) $bp->loaded_components )
? $bp->loaded_components[ bp_current_action() ]
: bp_current_action();
// Support for permalinks on single item pages: /groups/my-group/activity/124/.
$include = bp_is_current_action( bp_get_activity_slug() )
? bp_action_variable( 0 )
: false;
$search_terms_default = false;
$search_query_arg = bp_core_get_component_search_query_arg( 'activity' );
if ( ! empty( $_REQUEST[ $search_query_arg ] ) ) {
$search_terms_default = stripslashes( $_REQUEST[ $search_query_arg ] );
}
/*
* Parse Args.
*/
// Note: any params used for filtering can be a single value, or multiple
// values comma separated.
$r = bp_parse_args(
$args,
array(
'display_comments' => 'threaded', // False for none, stream/threaded - show comments in the stream or threaded under items.
'include' => $include, // Pass an activity_id or string of IDs comma-separated.
'exclude' => false, // Pass an activity_id or string of IDs comma-separated.
'in' => false, // Comma-separated list or array of activity IDs among which to search.
'sort' => 'DESC', // Sort DESC or ASC.
'page' => 1, // Which page to load.
'per_page' => 20, // Number of items per page.
'page_arg' => 'acpage', // See https://buddypress.trac.wordpress.org/ticket/3679.
'max' => false, // Max number to return.
'fields' => 'all',
'count_total' => false,
'show_hidden' => $show_hidden, // Show activity items that are hidden site-wide?
'spam' => 'ham_only', // Hide spammed items.
// Scope - pre-built activity filters for a user (friends/groups/favorites/mentions).
'scope' => $scope,
// Filtering.
'user_id' => $user_id, // user_id to filter on.
'object' => $object, // Object to filter on e.g. groups, profile, status, friends.
'action' => false, // Action to filter on e.g. activity_update, profile_updated.
'primary_id' => $primary_id, // Object ID to filter on e.g. a group_id or blog_id etc.
'secondary_id' => false, // Secondary object ID to filter on e.g. a post_id.
'offset' => false, // Return only items >= this ID.
'since' => false, // Return only items recorded since this Y-m-d H:i:s date.
'meta_query' => false, // Filter on activity meta. See WP_Meta_Query for format.
'date_query' => false, // Filter by date. See first parameter of WP_Date_Query for format.
'filter_query' => false, // Advanced filtering. See BP_Activity_Query for format.
// Searching.
'search_terms' => $search_terms_default,
'update_meta_cache' => true,
),
'has_activities'
);
/*
* Smart Overrides.
*/
// Translate various values for 'display_comments'
// This allows disabling comments via ?display_comments=0
// or =none or =false. Final true is a strict type check. See #5029.
if ( in_array( $r['display_comments'], array( 0, '0', 'none', 'false' ), true ) ) {
$r['display_comments'] = false;
}
// Ignore pagination if an offset is passed.
if ( ! empty( $r['offset'] ) ) {
$r['page'] = 0;
}
// Search terms.
if ( ! empty( $_REQUEST['s'] ) && empty( $r['search_terms'] ) ) {
$r['search_terms'] = $_REQUEST['s'];
}
// Do not exceed the maximum per page.
if ( ! empty( $r['max'] ) && ( (int) $r['per_page'] > (int) $r['max'] ) ) {
$r['per_page'] = $r['max'];
}
/**
* Filters whether BuddyPress should enable afilter support.
*
* Support for basic filters in earlier BP versions is disabled by default.
* To enable, put add_filter( 'bp_activity_enable_afilter_support', '__return_true' );
* into bp-custom.php or your theme's functions.php.
*
* @since 1.6.0
*
* @param bool $value True if BuddyPress should enable afilter support.
*/
if ( isset( $_GET['afilter'] ) && apply_filters( 'bp_activity_enable_afilter_support', false ) ) {
$r['filter'] = array(
'object' => $_GET['afilter']
);
} elseif ( ! empty( $r['user_id'] ) || ! empty( $r['object'] ) || ! empty( $r['action'] ) || ! empty( $r['primary_id'] ) || ! empty( $r['secondary_id'] ) || ! empty( $r['offset'] ) || ! empty( $r['since'] ) ) {
$r['filter'] = array(
'user_id' => $r['user_id'],
'object' => $r['object'],
'action' => $r['action'],
'primary_id' => $r['primary_id'],
'secondary_id' => $r['secondary_id'],
'offset' => $r['offset'],
'since' => $r['since']
);
} else {
$r['filter'] = false;
}
// If specific activity items have been requested, override the $hide_spam
// argument. This prevents backpat errors with AJAX.
if ( ! empty( $r['include'] ) && ( 'ham_only' === $r['spam'] ) ) {
$r['spam'] = 'all';
}
/*
* Query
*/
$activities_template = new BP_Activity_Template( $r );
/**
* Filters whether or not there are activity items to display.
*
* @since 1.1.0
*
* @param bool $value Whether or not there are activity items to display.
* @param string $activities_template Current activities template being used.
* @param array $r Array of arguments passed into the BP_Activity_Template class.
*/
return apply_filters( 'bp_has_activities', $activities_template->has_activities(), $activities_template, $r );
}
/**
* Determine if there are still activities left in the loop.
*
* @since 1.0.0
*
* @global object $activities_template {@link BP_Activity_Template}
*
* @return bool Returns true when activities are found.
*/
function bp_activities() {
global $activities_template;
return $activities_template->user_activities();
}
/**
* Get the current activity object in the loop.
*
* @since 1.0.0
*
* @global object $activities_template {@link BP_Activity_Template}
*
* @return object The current activity within the loop.
*/
function bp_the_activity() {
global $activities_template;
return $activities_template->the_activity();
}
/**
* Output the URL for the Load More link.
*
* @since 2.1.0
*/
function bp_activity_load_more_link() {
echo esc_url( bp_get_activity_load_more_link() );
}
/**
* Get the URL for the Load More link.
*
* @since 2.1.0
*
* @return string $link
*/
function bp_get_activity_load_more_link() {
global $activities_template;
$url = bp_get_requested_url();
$link = add_query_arg( $activities_template->pag_arg, $activities_template->pag_page + 1, $url );
/**
* Filters the Load More link URL.
*
* @since 2.1.0
*
* @param string $link The "Load More" link URL with appropriate query args.
* @param string $url The original URL.
* @param object $activities_template The activity template loop global.
*/
return apply_filters( 'bp_get_activity_load_more_link', $link, $url, $activities_template );
}
/**
* Output the activity pagination count.
*
* @since 1.0.0
*
* @global object $activities_template {@link BP_Activity_Template}
*/
function bp_activity_pagination_count() {
echo bp_get_activity_pagination_count();
}
/**
* Return the activity pagination count.
*
* @since 1.2.0
*
* @global object $activities_template {@link BP_Activity_Template}
*
* @return string The pagination text.
*/
function bp_get_activity_pagination_count() {
global $activities_template;
$start_num = intval( ( $activities_template->pag_page - 1 ) * $activities_template->pag_num ) + 1;
$from_num = bp_core_number_format( $start_num );
$to_num = bp_core_number_format( ( $start_num + ( $activities_template->pag_num - 1 ) > $activities_template->total_activity_count ) ? $activities_template->total_activity_count : $start_num + ( $activities_template->pag_num - 1 ) );
$total = bp_core_number_format( $activities_template->total_activity_count );
if ( 1 == $activities_template->total_activity_count ) {
$message = __( 'Viewing 1 item', 'buddypress' );
} else {
/* translators: 1: the from number item. 2: the to number item. 3: the total number of items. */
$message = sprintf( _n( 'Viewing %1$s - %2$s of %3$s item', 'Viewing %1$s - %2$s of %3$s items', $activities_template->total_activity_count, 'buddypress' ), $from_num, $to_num, $total );
}
return $message;
}
/**
* Output the activity pagination links.
*
* @since 1.0.0
*
*/
function bp_activity_pagination_links() {
echo bp_get_activity_pagination_links();
}
/**
* Return the activity pagination links.
*
* @since 1.0.0
*
* @global object $activities_template {@link BP_Activity_Template}
*
* @return string The pagination links.
*/
function bp_get_activity_pagination_links() {
global $activities_template;
/**
* Filters the activity pagination link output.
*
* @since 1.0.0
*
* @param string $pag_links Output for the activity pagination links.
*/
return apply_filters( 'bp_get_activity_pagination_links', $activities_template->pag_links );
}
/**
* Return true when there are more activity items to be shown than currently appear.
*
* @since 1.5.0
*
* @global object $activities_template {@link BP_Activity_Template}
*
* @return bool $has_more_items True if more items, false if not.
*/
function bp_activity_has_more_items() {
global $activities_template;
if ( ! empty( $activities_template->has_more_items ) ) {
$has_more_items = true;
} else {
$remaining_pages = 0;
if ( ! empty( $activities_template->pag_page ) ) {
$remaining_pages = floor( ( $activities_template->total_activity_count - 1 ) / ( $activities_template->pag_num * $activities_template->pag_page ) );
}
$has_more_items = (int) $remaining_pages > 0;
}
/**
* Filters whether there are more activity items to display.
*
* @since 1.5.0
*
* @param bool $has_more_items Whether or not there are more activity items to display.
*/
return apply_filters( 'bp_activity_has_more_items', $has_more_items );
}
/**
* Output the activity count.
*
* @since 1.2.0
*
*/
function bp_activity_count() {
echo bp_get_activity_count();
}
/**
* Return the activity count.
*
* @since 1.2.0
*
* @global object $activities_template {@link BP_Activity_Template}
*
* @return int The activity count.
*/
function bp_get_activity_count() {
global $activities_template;
/**
* Filters the activity count for the activity template.
*
* @since 1.2.0
*
* @param int $activity_count The count for total activity.
*/
return apply_filters( 'bp_get_activity_count', (int) $activities_template->activity_count );
}
/**
* Output the number of activities per page.
*
* @since 1.2.0
*
*/
function bp_activity_per_page() {
echo bp_get_activity_per_page();
}
/**
* Return the number of activities per page.
*
* @since 1.2.0
*
* @global object $activities_template {@link BP_Activity_Template}
*
* @return int The activities per page.
*/
function bp_get_activity_per_page() {
global $activities_template;
/**
* Filters the activity posts per page value.
*
* @since 1.2.0
*
* @param int $pag_num How many post should be displayed for pagination.
*/
return apply_filters( 'bp_get_activity_per_page', (int) $activities_template->pag_num );
}
/**
* Output the activities title.
*
* @since 1.0.0
*
* @todo Deprecate.
*/
function bp_activities_title() {
echo bp_get_activities_title();
}
/**
* Return the activities title.
*
* @since 1.0.0
*
* @global string $bp_activity_title
* @todo Deprecate.
*
* @return string The activities title.
*/
function bp_get_activities_title() {
global $bp_activity_title;
/**
* Filters the activities title for the activity template.
*
* @since 1.0.0
*
* @param string $bp_activity_title The title to be displayed.
*/
return apply_filters( 'bp_get_activities_title', $bp_activity_title );
}
/**
* {@internal Missing Description}
*
* @since 1.0.0
*
* @todo Deprecate.
*/
function bp_activities_no_activity() {
echo bp_get_activities_no_activity();
}
/**
* {@internal Missing Description}
*
* @since 1.0.0
*
* @global string $bp_activity_no_activity
* @todo Deprecate.
*
* @return string
*/
function bp_get_activities_no_activity() {
global $bp_activity_no_activity;
/**
* Filters the text used when there is no activity to display.
*
* @since 1.0.0
*
* @param string $bp_activity_no_activity Text to display for no activity.
*/
return apply_filters( 'bp_get_activities_no_activity', $bp_activity_no_activity );
}
/**
* Output the activity ID.
*
* @since 1.2.0
*
*/
function bp_activity_id() {
echo bp_get_activity_id();
}
/**
* Return the activity ID.
*
* @since 1.2.0
*
* @global object $activities_template {@link BP_Activity_Template}
*
* @return int The activity ID.
*/
function bp_get_activity_id() {
global $activities_template;
/**
* Filters the activity ID being displayed.
*
* @since 1.2.0
*
* @param int $id The activity ID.
*/
return apply_filters( 'bp_get_activity_id', $activities_template->activity->id );
}
/**
* Output the activity item ID.
*
* @since 1.2.0
*
*/
function bp_activity_item_id() {
echo bp_get_activity_item_id();
}
/**
* Return the activity item ID.
*
* @since 1.2.0
*
* @global object $activities_template {@link BP_Activity_Template}
*
* @return int The activity item ID.
*/
function bp_get_activity_item_id() {
global $activities_template;
/**
* Filters the activity item ID being displayed.
*
* @since 1.2.0
*
* @param int $item_id The activity item ID.
*/
return apply_filters( 'bp_get_activity_item_id', $activities_template->activity->item_id );
}
/**
* Output the activity secondary item ID.
*
* @since 1.2.0
*
*/
function bp_activity_secondary_item_id() {
echo bp_get_activity_secondary_item_id();
}
/**
* Return the activity secondary item ID.
*
* @since 1.2.0
*
* @global object $activities_template {@link BP_Activity_Template}
*
* @return int The activity secondary item ID.
*/
function bp_get_activity_secondary_item_id() {
global $activities_template;
/**
* Filters the activity secondary item ID being displayed.
*
* @since 1.2.0
*
* @param int $secondary_item_id The activity secondary item ID.
*/
return apply_filters( 'bp_get_activity_secondary_item_id', $activities_template->activity->secondary_item_id );
}
/**
* Output the date the activity was recorded.
*
* @since 1.2.0
*
*/
function bp_activity_date_recorded() {
echo bp_get_activity_date_recorded();
}
/**
* Return the date the activity was recorded.
*
* @since 1.2.0
*
* @global object $activities_template {@link BP_Activity_Template}
*
* @return string The date the activity was recorded.
*/
function bp_get_activity_date_recorded() {
global $activities_template;
/**
* Filters the date the activity was recorded.
*
* @since 1.2.0
*
* @param int $date_recorded The activity's date.
*/
return apply_filters( 'bp_get_activity_date_recorded', $activities_template->activity->date_recorded );
}
/**
* Output the display name of the member who posted the activity.
*
* @since 2.1.0
*
*/
function bp_activity_member_display_name() {
echo bp_get_activity_member_display_name();
}
/**
* Return the display name of the member who posted the activity.
*
* @since 2.1.0
*
* @global object $activities_template {@link BP_Activity_Template}
*
* @return string The date the activity was recorded.
*/
function bp_get_activity_member_display_name() {
global $activities_template;
$retval = isset( $activities_template->activity->display_name )
? $activities_template->activity->display_name
: '';
/**
* Filters the display name of the member who posted the activity.
*
* @since 2.1.0
*
* @param int $retval Display name for the member who posted.
*/
return apply_filters( 'bp_get_activity_member_display_name', $retval );
}
/**
* Output the activity object name.
*
* @since 1.2.0
*
*/
function bp_activity_object_name() {
echo bp_get_activity_object_name();
}
/**
* Return the activity object name.
*
* @since 1.2.0
*
* @global object $activities_template {@link BP_Activity_Template}
*
* @return string The activity object name.
*/
function bp_get_activity_object_name() {
global $activities_template;
/**
* Filters the activity object name.
*
* @since 1.2.0
*
* @param string $activity_component The activity object name.
*/
return apply_filters( 'bp_get_activity_object_name', $activities_template->activity->component );
}
/**
* Output the activity type.
*
* @since 1.2.0
*
*/
function bp_activity_type() {
echo bp_get_activity_type();
}
/**
* Return the activity type.
*
* @since 1.2.0
*
* @global object $activities_template {@link BP_Activity_Template}
*
* @return string The activity type.
*/
function bp_get_activity_type() {
global $activities_template;
/**
* Filters the activity type.
*
* @since 1.2.0
*
* @param string $activity_type The activity type.
*/
return apply_filters( 'bp_get_activity_type', $activities_template->activity->type );
}
/**
* Return the activity type template part name.
*
* @since 10.0.0
*
* @global object $activities_template {@link BP_Activity_Template}
*
* @return string The activity type template part name.
*/
function bp_activity_type_part() {
global $activities_template;
$name = '';
if ( isset( $activities_template->activity->type ) && $activities_template->activity->type ) {
$name = str_replace( '_', '-', $activities_template->activity->type );
}
return $name;
}
/**
* Output the activity action name.
*
* Just a wrapper for bp_activity_type().
*
* @since 1.2.0
* @deprecated 1.5.0
*
* @todo Properly deprecate in favor of bp_activity_type() and
* remove redundant echo
*
*/
function bp_activity_action_name() { echo bp_activity_type(); }
/**
* Return the activity type.
*
* Just a wrapper for bp_get_activity_type().
*
* @since 1.2.0
* @deprecated 1.5.0
*
* @todo Properly deprecate in favor of bp_get_activity_type().
*
*
* @return string The activity type.
*/
function bp_get_activity_action_name() { return bp_get_activity_type(); }
/**
* Output the activity user ID.
*
* @since 1.1.0
*
*/
function bp_activity_user_id() {
echo bp_get_activity_user_id();
}
/**
* Return the activity user ID.
*
* @since 1.1.0
*
* @global object $activities_template {@link BP_Activity_Template}
*
* @return int The activity user ID.
*/
function bp_get_activity_user_id() {
global $activities_template;
/**
* Filters the activity user ID.
*
* @since 1.1.0
*
* @param int $user_id The activity user ID.
*/
return apply_filters( 'bp_get_activity_user_id', $activities_template->activity->user_id );
}
/**
* Output the activity user link.
*
* @since 1.2.0
*
*/
function bp_activity_user_link() {
echo bp_get_activity_user_link();
}
/**
* Return the activity user link.
*
* @since 1.2.0
*
* @global object $activities_template {@link BP_Activity_Template}
*
* @return string $link The activity user link.
*/
function bp_get_activity_user_link() {
global $activities_template;
if ( empty( $activities_template->activity->user_id ) || empty( $activities_template->activity->user_nicename ) || empty( $activities_template->activity->user_login ) ) {
$link = $activities_template->activity->primary_link;
} else {
$link = bp_core_get_user_domain( $activities_template->activity->user_id, $activities_template->activity->user_nicename, $activities_template->activity->user_login );
}
/**
* Filters the activity user link.
*
* @since 1.2.0
*
* @param string $link The activity user link.
*/
return apply_filters( 'bp_get_activity_user_link', $link );
}
/**
* Output the avatar of the user that performed the action.
*
* @since 1.1.0
*
* @see bp_get_activity_avatar() for description of arguments.
*
* @param array|string $args See {@link bp_get_activity_avatar()} for description.
*/
function bp_activity_avatar( $args = '' ) {
echo bp_get_activity_avatar( $args );
}
/**
* Return the avatar of the user that performed the action.
*
* @since 1.1.0
*
* @see bp_core_fetch_avatar() For a description of the arguments.
* @global object $activities_template {@link BP_Activity_Template}
*
* @param array|string $args {
* Arguments are listed here with an explanation of their defaults.
* For more information about the arguments, see
* {@link bp_core_fetch_avatar()}.
* @type string $alt Default: 'Profile picture of [user name]' if
* activity user name is available, otherwise 'Profile picture'.
* @type string $class Default: 'avatar'.
* @type string|bool $email Default: Email of the activity's
* associated user, if available. Otherwise false.
* @type string $type Default: 'full' when viewing a single activity
* permalink page, otherwise 'thumb'.
* @type int|bool $user_id Default: ID of the activity's user.
* }
* @return string User avatar string.
*/
function bp_get_activity_avatar( $args = '' ) {
global $activities_template;
$bp = buddypress();
// On activity permalink pages, default to the full-size avatar.
$type_default = bp_is_single_activity() ? 'full' : 'thumb';
// Within the activity comment loop, the current activity should be set
// to current_comment. Otherwise, just use activity.
$current_activity_item = isset( $activities_template->activity->current_comment ) ? $activities_template->activity->current_comment : $activities_template->activity;
// Activity user display name.
$dn_default = isset( $current_activity_item->display_name ) ? $current_activity_item->display_name : '';
// Prepend some descriptive text to alt.
$alt_default = __( 'Profile picture', 'buddypress' );
if ( ! empty( $dn_default ) ) {
/* translators: %s: member name */
$alt_default = sprintf( __( 'Profile picture of %s', 'buddypress' ), $dn_default );
}
$defaults = array(
'alt' => $alt_default,
'class' => 'avatar',
'email' => false,
'type' => $type_default,
'user_id' => false
);
$r = bp_parse_args(
$args,
$defaults
);
extract( $r, EXTR_SKIP );
if ( !isset( $height ) && !isset( $width ) ) {
// Backpat.
if ( isset( $bp->avatar->full->height ) || isset( $bp->avatar->thumb->height ) ) {
$height = ( 'full' == $type ) ? $bp->avatar->full->height : $bp->avatar->thumb->height;
} else {
$height = 20;
}
// Backpat.
if ( isset( $bp->avatar->full->width ) || isset( $bp->avatar->thumb->width ) ) {
$width = ( 'full' == $type ) ? $bp->avatar->full->width : $bp->avatar->thumb->width;
} else {
$width = 20;
}
}
/**
* Filters the activity avatar object based on current activity item component.
*
* This is a variable filter dependent on the component used.
* Possible hooks are bp_get_activity_avatar_object_blog,
* bp_get_activity_avatar_object_group, and bp_get_activity_avatar_object_user.
*
* @since 1.1.0
*
* @param string $component Component being displayed.
*/
$object = apply_filters( 'bp_get_activity_avatar_object_' . $current_activity_item->component, 'user' );
$item_id = !empty( $user_id ) ? $user_id : $current_activity_item->user_id;
/**
* Filters the activity avatar item ID.
*
* @since 1.2.10
*
* @param int $item_id Item ID for the activity avatar.
*/
$item_id = apply_filters( 'bp_get_activity_avatar_item_id', $item_id );
// If this is a user object pass the users' email address for Gravatar so we don't have to prefetch it.
if ( 'user' == $object && empty( $user_id ) && empty( $email ) && isset( $current_activity_item->user_email ) ) {
$email = $current_activity_item->user_email;
}
/**
* Filters the value returned by bp_core_fetch_avatar.
*
* @since 1.1.3
*
* @param array $value HTML image element containing the activity avatar.
*/
return apply_filters( 'bp_get_activity_avatar', bp_core_fetch_avatar( array(
'item_id' => $item_id,
'object' => $object,
'type' => $type,
'alt' => $alt,
'class' => $class,
'width' => $width,
'height' => $height,
'email' => $email
) ) );
}
/**
* Output the avatar of the object that action was performed on.
*
* @since 1.2.0
*
* @see bp_get_activity_secondary_avatar() for description of arguments.
*
* @param array|string $args See {@link bp_get_activity_secondary_avatar} for description.
*/
function bp_activity_secondary_avatar( $args = '' ) {
echo bp_get_activity_secondary_avatar( $args );
}
/**
* Return the avatar of the object that action was performed on.
*
* @since 1.2.0
*
* @see bp_core_fetch_avatar() for description of arguments.
* @global object $activities_template {@link BP_Activity_Template}
*
* @param array|string $args {
* For a complete description of arguments, see {@link bp_core_fetch_avatar()}.
* @type string $alt Default value varies based on current activity
* item component.
* @type string $type Default: 'full' when viewing a single activity
* permalink page, otherwise 'thumb'.
* @type string $class Default: 'avatar'.
* @type string|bool $email Default: email of the activity's user.
* @type int|bool $user_id Default: ID of the activity's user.
* }
* @return string The secondary avatar.
*/
function bp_get_activity_secondary_avatar( $args = '' ) {
global $activities_template;
$r = bp_parse_args(
$args,
array(
'alt' => '',
'type' => 'thumb',
'width' => 20,
'height' => 20,
'class' => 'avatar',
'link_class' => '',
'linked' => true,
'email' => false,
)
);
extract( $r, EXTR_SKIP );
// Set item_id and object (default to user).
switch ( $activities_template->activity->component ) {
case 'groups' :
if ( bp_disable_group_avatar_uploads() ) {
return false;
}
$object = 'group';
$item_id = $activities_template->activity->item_id;
$link = '';
$name = '';
// Only if groups is active.
if ( bp_is_active( 'groups' ) ) {
$group = groups_get_group( $item_id );
$link = bp_get_group_permalink( $group );
$name = $group->name;
}
if ( empty( $alt ) ) {
$alt = __( 'Group logo', 'buddypress' );
if ( ! empty( $name ) ) {
/* translators: %s: the Group name */
$alt = sprintf( __( 'Group logo of %s', 'buddypress' ), $name );
}
}
break;
case 'blogs' :
$object = 'blog';
$item_id = $activities_template->activity->item_id;
$link = home_url();
if ( empty( $alt ) ) {
/* translators: %s: the blog name */
$alt = sprintf( __( 'Profile picture of the author of the site %s', 'buddypress' ), get_blog_option( $item_id, 'blogname' ) );
}
break;
case 'friends' :
$object = 'user';
$item_id = $activities_template->activity->secondary_item_id;
$link = bp_core_get_userlink( $item_id, false, true );
if ( empty( $alt ) ) {
/* translators: %s: member name */
$alt = sprintf( __( 'Profile picture of %s', 'buddypress' ), bp_core_get_user_displayname( $activities_template->activity->secondary_item_id ) );
}
break;
default :
$object = 'user';
$item_id = $activities_template->activity->user_id;
$email = $activities_template->activity->user_email;
$link = bp_core_get_userlink( $item_id, false, true );
if ( empty( $alt ) ) {
/* translators: %s: member name */
$alt = sprintf( __( 'Profile picture of %s', 'buddypress' ), $activities_template->activity->display_name );
}
break;
}
/**
* Filters the activity secondary avatar object based on current activity item component.
*
* This is a variable filter dependent on the component used. Possible hooks are
* bp_get_activity_secondary_avatar_object_blog, bp_get_activity_secondary_avatar_object_group,
* and bp_get_activity_secondary_avatar_object_user.
*
* @since 1.2.10
*
* @param string $object Component being displayed.
*/
$object = apply_filters( 'bp_get_activity_secondary_avatar_object_' . $activities_template->activity->component, $object );
/**
* Filters the activity secondary avatar item ID.
*
* @since 1.2.10
*
* @param int $item_id ID for the secondary avatar item.
*/
$item_id = apply_filters( 'bp_get_activity_secondary_avatar_item_id', $item_id );
// If we have no item_id or object, there is no avatar to display.
if ( empty( $item_id ) || empty( $object ) ) {
return false;
}
// Get the avatar.
$avatar = bp_core_fetch_avatar( array(
'item_id' => $item_id,
'object' => $object,
'type' => $type,
'alt' => $alt,
'class' => $class,
'width' => $width,
'height' => $height,
'email' => $email
) );
if ( !empty( $linked ) ) {
/**
* Filters the secondary avatar link for current activity.
*
* @since 1.7.0
*
* @param string $link Link to wrap the avatar image in.
* @param string $component Activity component being acted on.
*/
$link = apply_filters( 'bp_get_activity_secondary_avatar_link', $link, $activities_template->activity->component );
/**
* Filters the determined avatar for the secondary activity item.
*
* @since 1.2.10
*
* @param string $avatar Formatted HTML element, or raw avatar URL.
*/
$avatar = apply_filters( 'bp_get_activity_secondary_avatar', $avatar );
return sprintf( '%s',
$link,
$link_class,
$avatar
);
}
/** This filter is documented in bp-activity/bp-activity-template.php */
return apply_filters( 'bp_get_activity_secondary_avatar', $avatar );
}
/**
* Output the activity action.
*
* @since 1.2.0
*
* @param array $args See bp_get_activity_action().
*/
function bp_activity_action( $args = array() ) {
echo bp_get_activity_action( $args );
}
/**
* Return the activity action.
*
* @since 1.2.0
* @since 1.7.0 Introduce function parameter, $args.
*
* @global object $activities_template {@link BP_Activity_Template}
*
* @param array $args {
* @type bool $no_timestamp Whether to exclude the timestamp.
* }
*
* @return string The activity action.
*/
function bp_get_activity_action( $args = array() ) {
global $activities_template;
$r = bp_parse_args(
$args,
array(
'no_timestamp' => false,
)
);
/**
* Filters the activity action before the action is inserted as meta.
*
* @since 1.2.10
*
* @param array $value Array containing the current action, the current activity, and the $args array passed into the function.
*/
$action = apply_filters_ref_array( 'bp_get_activity_action_pre_meta', array(
$activities_template->activity->action,
&$activities_template->activity,
$r
) );
// Prepend the activity action meta (link, time since, etc...).
if ( ! empty( $action ) && empty( $r['no_timestamp'] ) ) {
$action = bp_insert_activity_meta( $action );
}
/**
* Filters the activity action after the action has been inserted as meta.
*
* @since 1.2.0
* @since 1.7.0 Now passes a 3rd parameter, $r, an array of arguments from the function.
*
* @param array $value Array containing the current action, the current activity, and the $r array passed into the function.
*/
return apply_filters_ref_array( 'bp_get_activity_action', array(
$action,
&$activities_template->activity,
$r
) );
}
/**
* Output the activity content body.
*
* @since 1.2.0
*/
function bp_activity_content_body() {
echo bp_get_activity_content_body();
}
/**
* Return the activity content body.
*
* @since 1.2.0
*
* @global object $activities_template {@link BP_Activity_Template}
*
* @return string The activity content body.
*/
function bp_get_activity_content_body() {
global $activities_template;
// Backwards compatibility if action is not being used.
if ( empty( $activities_template->activity->action ) && ! empty( $activities_template->activity->content ) ) {
$activities_template->activity->content = bp_insert_activity_meta( $activities_template->activity->content );
}
/**
* Filters the activity content body.
*
* @since 1.2.0
*
* @param string $content Content body.
* @param object $activity Activity object. Passed by reference.
*/
return apply_filters_ref_array( 'bp_get_activity_content_body', array( $activities_template->activity->content, &$activities_template->activity ) );
}
/**
* Does the activity have content?
*
* @since 1.2.0
* @since 10.0.0 Generate a richer content for activity types supporting the feature.
*
* @global object $activities_template {@link BP_Activity_Template}
*
* @return bool True if activity has content, false otherwise.
*/
function bp_activity_has_content() {
global $activities_template;
$has_content = ! empty( $activities_template->activity->content );
if ( ! $has_content ) {
$activity_type = bp_get_activity_type();
if ( bp_activity_type_supports( $activity_type, 'generated-content' ) ) {
$bp = buddypress();
$generated_content = new stdClass();
$activity = $activities_template->activity;
$user_id = $activity->user_id;
// Set generated content properties.
if ( 'new_avatar' === $activity_type ) {
$avatars = array();
// Use the avatar history to display the avatar that was in use at the time the activity was posted.
if ( ! bp_avatar_history_is_disabled() ) {
$avatars = bp_avatar_get_version( $user_id, 'user', bp_get_activity_date_recorded() );
if ( $avatars && 1 === count( $avatars ) ) {
$avatar = reset( $avatars );
$historical_avatar = trailingslashit( $avatar->parent_dir_url ) . $avatar->name;
// Add historical avatar to the current activity.
$generated_content->user_profile_photo = array(
'value' => $historical_avatar,
'sanitize_callback' => 'esc_url',
);
}
// Otherwise use the current/latest avatar.
} else {
$generated_content->user_profile_photo = array(
'value' => bp_core_fetch_avatar(
array(
'item_id' => $user_id,
'object' => 'user',
'type' => 'full',
'width' => bp_core_avatar_full_width(),
'height' => bp_core_avatar_full_height(),
'html' => false,
)
),
'sanitize_callback' => 'esc_url',
);
}
}
if ( in_array( $activity_type, array( 'new_member', 'friendship_created', 'updated_profile' ), true ) ) {
if ( 'friendship_created' === $activity_type ) {
$user_id = $activity->secondary_item_id;
}
if ( isset( $bp->avatar->show_avatars ) && $bp->avatar->show_avatars ) {
$generated_content->user_profile_photo = array(
'value' => bp_core_fetch_avatar(
array(
'item_id' => $user_id,
'object' => 'user',
'type' => 'full',
'width' => bp_core_avatar_full_width(),
'height' => bp_core_avatar_full_height(),
'html' => false,
)
),
'sanitize_callback' => 'esc_url',
);
}
}
// Set common generated content properties.
if ( in_array( $activity_type, array( 'new_avatar', 'new_member', 'friendship_created', 'updated_profile' ), true ) ) {
$generated_content->user_url = array(
'value' => bp_core_get_user_domain( $user_id ),
'sanitize_callback' => 'esc_url',
);
$generated_content->user_display_name = array(
'value' => bp_core_get_user_displayname( $user_id ),
'sanitize_callback' => 'esc_html',
);
$generated_content->user_mention_name = array(
'value' => bp_activity_get_user_mentionname( $user_id ),
'sanitize_callback' => 'esc_html',
);
$generated_content->user_mention_url = array(
'value' => wp_nonce_url(
add_query_arg(
array(
'r' => $generated_content->user_mention_name['value'],
),
bp_get_activity_directory_permalink()
)
),
'sanitize_callback' => 'esc_url',
);
if ( bp_displayed_user_use_cover_image_header() ) {
$generated_content->user_cover_image = array(
'value' => bp_attachments_get_attachment(
'url',
array(
'object_dir' => 'members',
'item_id' => $user_id,
)
),
'sanitize_callback' => 'esc_url',
);
}
}
if ( 'created_group' === $activity_type || 'joined_group' === $activity_type ) {
$group = bp_get_group( $activity->item_id );
if ( isset( $bp->avatar->show_avatars ) && $bp->avatar->show_avatars && ! bp_disable_group_avatar_uploads() ) {
$generated_content->group_profile_photo = array(
'value' => bp_core_fetch_avatar(
array(
'item_id' => $group->id,
'object' => 'group',
'type' => 'full',
'width' => bp_core_avatar_full_width(),
'height' => bp_core_avatar_full_height(),
'html' => false,
)
),
'sanitize_callback' => 'esc_url',
);
}
$generated_content->group_url = array(
'value' => bp_get_group_permalink( $group ),
'sanitize_callback' => 'esc_url',
);
$generated_content->group_name = array(
'value' => bp_get_group_name( $group ),
'sanitize_callback' => 'esc_html',
);
if ( bp_group_use_cover_image_header() ) {
$generated_content->group_cover_image = array(
'value' => bp_get_group_cover_url( $group ),
'sanitize_callback' => 'esc_url',
);
}
}
// Update the corresponding entry into the activities template global.
if ( get_object_vars( $generated_content ) ) {
$activity_id = $activities_template->activity->id;
$activity_index = 0;
// Find the activity index.
while ( (int) $activities_template->activities[ $activity_index ]->id !== (int) $activity_id ) {
$activity_index++;
}
// Add the generated content object.
$activities_template->activities[ $activity_index ]->generated_content = $generated_content;
$has_content = true;
}
}
}
return $has_content;
}
/**
* Does this property has been generated?
*
* @since 10.0.0
*
* @param string $property The name of the property to check into the generated content.
* @return bool True if the property is not empty. False otherwise.
*/
function bp_activity_has_generated_content_part( $property = '' ) {
return bp_activity_get_generated_content_part( $property, 'boolean' );
}
/**
* Outputs a property of the activity generated content.
*
* @since 10.0.0
*
* @param string $property The name of the property to check into the generated content.
*/
function bp_activity_generated_content_part( $property = '' ) {
echo bp_activity_get_generated_content_part( $property );
}
/**
* Returns the property of the activity generated content.
*
* @since 10.0.0
*
* @param string $property The name of the property to check into the generated content.
* @param string $return Whether to return the property value or a boolean to check it exists.
* @return bool|string A boolean when requested, false if there is no value, the HTML output otherwise.
*/
function bp_activity_get_generated_content_part( $property = '', $return = '' ) {
global $activities_template;
if ( ! isset( $activities_template->activity->generated_content->{$property} ) ) {
return false;
}
$content_part = $activities_template->activity->generated_content->{$property};
if ( ! isset( $content_part['value'] ) || ! $content_part['value'] ) {
return false;
}
if ( 'boolean' === $return ) {
return true;
}
/**
* Filter here to edit the generated content part.
*
* @since 10.0.0
*
* @param string $value The generated content part.
* @param string $property The property the content part is attached to.
*/
$value = apply_filters( 'bp_activity_get_generated_content_part', $content_part['value'], $property );
if ( isset( $content_part['sanitize_callback'] ) && $content_part['sanitize_callback'] ) {
return call_user_func( $content_part['sanitize_callback'], $value );
}
return $value;
}
/**
* Output the activity content.
*
* @since 1.0.0
* @deprecated 1.5.0
*
* @todo properly deprecate this function.
*
*/
function bp_activity_content() {
echo bp_get_activity_content();
}
/**
* Return the activity content.
*
* @since 1.0.0
* @deprecated 1.5.0
*
* @todo properly deprecate this function.
*
*
* @return string The activity content.
*/
function bp_get_activity_content() {
/**
* If you want to filter activity update content, please use
* the filter 'bp_get_activity_content_body'.
*
* This function is mainly for backwards compatibility.
*/
$content = bp_get_activity_action() . ' ' . bp_get_activity_content_body();
return apply_filters( 'bp_get_activity_content', $content );
}
/**
* Attach metadata about an activity item to the activity content.
*
* This metadata includes the time since the item was posted (which will appear
* as a link to the item's permalink).
*
* @since 1.2.0
*
* @global object $activities_template {@link BP_Activity_Template}
*
* @param string $content The activity content.
* @return string The activity content with the metadata string attached.
*/
function bp_insert_activity_meta( $content = '' ) {
global $activities_template;
// Strip any legacy time since placeholders from BP 1.0-1.1.
$new_content = str_replace( '%s', '', $content );
// Get the time since this activity was recorded.
$date_recorded = bp_core_time_since( $activities_template->activity->date_recorded );
// Set up 'time-since' .
$time_since = sprintf(
'%2$s',
bp_core_get_iso8601_date( $activities_template->activity->date_recorded ),
$date_recorded
);
/**
* Filters the activity item time since markup.
*
* @since 1.2.0
*
* @param array $value Array containing the time since markup and the current activity component.
*/
$time_since = apply_filters_ref_array( 'bp_activity_time_since', array(
$time_since,
&$activities_template->activity
) );
// Insert the permalink.
if ( ! bp_is_single_activity() ) {
// Setup variables for activity meta.
$activity_permalink = bp_activity_get_permalink( $activities_template->activity->id, $activities_template->activity );
$activity_meta = sprintf( '%1$s %4$s',
$new_content,
$activity_permalink,
esc_attr__( 'View Discussion', 'buddypress' ),
$time_since
);
/**
* Filters the activity permalink to be added to the activity content.
*
* @since 1.2.0
*
* @param array $value Array containing the html markup for the activity permalink, after being parsed by
* sprintf and current activity component.
*/
$new_content = apply_filters_ref_array( 'bp_activity_permalink', array(
$activity_meta,
&$activities_template->activity
) );
} else {
$new_content .= str_pad( $time_since, strlen( $time_since ) + 2, ' ', STR_PAD_BOTH );
}
/**
* Filters the activity content after activity metadata has been attached.
*
* @since 1.2.0
*
* @param string $content Activity content with the activity metadata added.
*/
return apply_filters( 'bp_insert_activity_meta', $new_content, $content );
}
/**
* Determine if the current user can delete an activity item.
*
* @since 1.2.0
*
* @global object $activities_template {@link BP_Activity_Template}
*
* @param false|BP_Activity_Activity $activity Optional. Falls back on the current item in the loop.
* @return bool True if can delete, false otherwise.
*/
function bp_activity_user_can_delete( $activity = false ) {
global $activities_template;
// Try to use current activity if none was passed.
if ( empty( $activity ) && ! empty( $activities_template->activity ) ) {
$activity = $activities_template->activity;
}
// If current_comment is set, we'll use that in place of the main activity.
if ( isset( $activity->current_comment ) ) {
$activity = $activity->current_comment;
}
// Assume the user cannot delete the activity item.
$can_delete = false;
// Only logged in users can delete activity.
if ( is_user_logged_in() ) {
// Community moderators can always delete activity (at least for now).
if ( bp_current_user_can( 'bp_moderate' ) ) {
$can_delete = true;
}
// Users are allowed to delete their own activity. This is actually
// quite powerful, because doing so also deletes all comments to that
// activity item. We should revisit this eventually.
if ( isset( $activity->user_id ) && ( $activity->user_id === bp_loggedin_user_id() ) ) {
$can_delete = true;
}
/*
* Viewing a single item, and this user is an admin of that item.
*
* Group activity items are handled separately.
* See bp_groups_filter_activity_user_can_delete().
*/
if ( 'groups' !== $activity->component && bp_is_single_item() && bp_is_item_admin() ) {
$can_delete = true;
}
}
/**
* Filters whether the current user can delete an activity item.
*
* @since 1.5.0
*
* @param bool $can_delete Whether the user can delete the item.
* @param object $activity Current activity item object.
*/
return (bool) apply_filters( 'bp_activity_user_can_delete', $can_delete, $activity );
}
/**
* Output the activity parent content.
*
* @since 1.2.0
*
* @see bp_get_activity_parent_content() for a description of arguments.
*
* @param array|string $args See {@link bp_get_activity_parent_content} for description.
*/
function bp_activity_parent_content( $args = '' ) {
echo bp_get_activity_parent_content($args);
}
/**
* Return the activity content.
*
* @since 1.2.0
*
* @global object $activities_template {@link BP_Activity_Template}
*
* @param string $args Unused. Left over from an earlier implementation.
* @return mixed False on failure, otherwise the activity parent content.
*/
function bp_get_activity_parent_content( $args = '' ) {
global $activities_template;
// Bail if no activity on no item ID.
if ( empty( $activities_template->activity ) || empty( $activities_template->activity->item_id ) ) {
return false;
}
// Get the ID of the parent activity content.
$parent_id = $activities_template->activity->item_id;
// Bail if no parent content.
if ( empty( $activities_template->activity_parents[ $parent_id ] ) ) {
return false;
}
// Bail if no action.
if ( empty( $activities_template->activity_parents[ $parent_id ]->action ) ) {
return false;
}
// Content always includes action.
$content = $activities_template->activity_parents[ $parent_id ]->action;
// Maybe append activity content, if it exists.
if ( ! empty( $activities_template->activity_parents[ $parent_id ]->content ) ) {
$content .= ' ' . $activities_template->activity_parents[ $parent_id ]->content;
}
// Remove the time since content for backwards compatibility.
$content = str_replace( '%s', '', $content );
// Remove images.
$content = preg_replace( '/]*>/Ui', '', $content );
/**
* Filters the activity parent content.
*
* @since 1.2.0
*
* @param string $content Content set to be displayed as parent content.
*/
return apply_filters( 'bp_get_activity_parent_content', $content );
}
/**
* Output the parent activity's user ID.
*
* @since 1.7.0
*/
function bp_activity_parent_user_id() {
echo bp_get_activity_parent_user_id();
}
/**
* Return the parent activity's user ID.
*
* @since 1.7.0
*
* @global BP_Activity_Template $activities_template
*
* @return bool|int False if parent activity can't be found, otherwise
* the parent activity's user ID.
*/
function bp_get_activity_parent_user_id() {
global $activities_template;
// Bail if no activity on no item ID.
if ( empty( $activities_template->activity ) || empty( $activities_template->activity->item_id ) ) {
return false;
}
// Get the ID of the parent activity content.
$parent_id = $activities_template->activity->item_id;
// Bail if no parent item.
if ( empty( $activities_template->activity_parents[ $parent_id ] ) ) {
return false;
}
// Bail if no parent user ID.
if ( empty( $activities_template->activity_parents[ $parent_id ]->user_id ) ) {
return false;
}
$retval = $activities_template->activity_parents[ $parent_id ]->user_id;
/**
* Filters the activity parent item's user ID.
*
* @since 1.7.0
*
* @param int $retval ID for the activity parent's user.
*/
return (int) apply_filters( 'bp_get_activity_parent_user_id', $retval );
}
/**
* Output whether or not the current activity is in a current user's favorites.
*
* @since 1.2.0
*
*/
function bp_activity_is_favorite() {
echo bp_get_activity_is_favorite();
}
/**
* Return whether the current activity is in a current user's favorites.
*
* @since 1.2.0
*
* @global object $activities_template {@link BP_Activity_Template}
*
* @return bool True if user favorite, false otherwise.
*/
function bp_get_activity_is_favorite() {
global $activities_template;
/**
* Filters whether the current activity item is in the current user's favorites.
*
* @since 1.2.0
*
* @param bool $value Whether or not the current activity item is in the current user's favorites.
*/
return (bool) apply_filters( 'bp_get_activity_is_favorite', in_array( $activities_template->activity->id, (array) $activities_template->my_favs ) );
}
/**
* Output the comment markup for an activity item.
*
* @since 1.2.0
*
* @todo deprecate $args param
*
* @param array|string $args See {@link bp_activity_get_comments} for description.
*/
function bp_activity_comments( $args = '' ) {
echo bp_activity_get_comments( $args );
}
/**
* Get the comment markup for an activity item.
*
* @since 1.2.0
*
* @todo deprecate $args param
* @todo Given that checks for children already happen in bp_activity_recurse_comments(),
* this function can probably be streamlined or removed.
*
* @global object $activities_template {@link BP_Activity_Template}
*
* @param string $args Unused. Left over from an earlier implementation.
* @return bool
*/
function bp_activity_get_comments( $args = '' ) {
global $activities_template;
if ( empty( $activities_template->activity->children ) ) {
return false;
}
bp_activity_recurse_comments( $activities_template->activity );
}
/**
* Loops through a level of activity comments and loads the template for each.
*
* Note: The recursion itself used to happen entirely in this function. Now it is
* split between here and the comment.php template.
*
* @since 1.2.0
*
* @global object $activities_template {@link BP_Activity_Template}
*
* @param object $comment The activity object currently being recursed.
* @return bool|string
*/
function bp_activity_recurse_comments( $comment ) {
global $activities_template;
if ( empty( $comment ) ) {
return false;
}
if ( empty( $comment->children ) ) {
return false;
}
/**
* Filters the opening tag for the template that lists activity comments.
*
* @since 1.6.0
*
* @param string $value Opening tag for the HTML markup to use.
*/
echo apply_filters( 'bp_activity_recurse_comments_start_ul', '
' );
foreach ( (array) $comment->children as $comment_child ) {
// Put the comment into the global so it's available to filters.
$activities_template->activity->current_comment = $comment_child;
$template = bp_locate_template( 'activity/comment.php', false, false );
// Backward compatibility. In older versions of BP, the markup was
// generated in the PHP instead of a template. This ensures that
// older themes (which are not children of bp-default and won't
// have the new template) will still work.
if ( !$template ) {
$template = buddypress()->plugin_dir . '/bp-themes/bp-default/activity/comment.php';
}
load_template( $template, false );
unset( $activities_template->activity->current_comment );
}
/**
* Filters the closing tag for the template that list activity comments.
*
* @since 1.6.0
*
* @param string $value Closing tag for the HTML markup to use.
*/
echo apply_filters( 'bp_activity_recurse_comments_end_ul', '
' );
}
/**
* Utility function that returns the comment currently being recursed.
*
* @since 1.5.0
*
* @global object $activities_template {@link BP_Activity_Template}
*
* @return object|bool $current_comment The activity comment currently being
* displayed. False on failure.
*/
function bp_activity_current_comment() {
global $activities_template;
$current_comment = !empty( $activities_template->activity->current_comment )
? $activities_template->activity->current_comment
: false;
/**
* Filters the current comment being recursed.
*
* @since 1.5.0
*
* @param object|bool $current_comment The activity comment currently being displayed. False on failure.
*/
return apply_filters( 'bp_activity_current_comment', $current_comment );
}
/**
* Output the ID of the activity comment currently being displayed.
*
* @since 1.5.0
*
*/
function bp_activity_comment_id() {
echo bp_get_activity_comment_id();
}
/**
* Return the ID of the activity comment currently being displayed.
*
* @since 1.5.0
*
* @global object $activities_template {@link BP_Activity_Template}
*
* @return int|bool $comment_id The ID of the activity comment currently
* being displayed, false if none is found.
*/
function bp_get_activity_comment_id() {
global $activities_template;
$comment_id = isset( $activities_template->activity->current_comment->id ) ? $activities_template->activity->current_comment->id : false;
/**
* Filters the ID of the activity comment currently being displayed.
*
* @since 1.5.0
*
* @param int|bool $comment_id ID for the comment currently being displayed.
*/
return apply_filters( 'bp_activity_comment_id', $comment_id );
}
/**
* Output the ID of the author of the activity comment currently being displayed.
*
* @since 1.5.0
*
*/
function bp_activity_comment_user_id() {
echo bp_get_activity_comment_user_id();
}
/**
* Return the ID of the author of the activity comment currently being displayed.
*
* @since 1.5.0
*
* @global object $activities_template {@link BP_Activity_Template}
*
* @return int|bool $user_id The user_id of the author of the displayed
* activity comment. False on failure.
*/
function bp_get_activity_comment_user_id() {
global $activities_template;
$user_id = isset( $activities_template->activity->current_comment->user_id ) ? $activities_template->activity->current_comment->user_id : false;
/**
* Filters the ID of the author of the activity comment currently being displayed.
*
* @since 1.5.0
*
* @param int|bool $user_id ID for the author of the comment currently being displayed.
*/
return apply_filters( 'bp_activity_comment_user_id', $user_id );
}
/**
* Output the author link for the activity comment currently being displayed.
*
* @since 1.5.0
*
*/
function bp_activity_comment_user_link() {
echo bp_get_activity_comment_user_link();
}
/**
* Return the author link for the activity comment currently being displayed.
*
* @since 1.5.0
*
*
* @return string $user_link The URL of the activity comment author's profile.
*/
function bp_get_activity_comment_user_link() {
$user_link = bp_core_get_user_domain( bp_get_activity_comment_user_id() );
/**
* Filters the author link for the activity comment currently being displayed.
*
* @since 1.5.0
*
* @param string $user_link Link for the author of the activity comment currently being displayed.
*/
return apply_filters( 'bp_activity_comment_user_link', $user_link );
}
/**
* Output the author name for the activity comment currently being displayed.
*
* @since 1.5.0
*
*/
function bp_activity_comment_name() {
echo bp_get_activity_comment_name();
}
/**
* Return the author name for the activity comment currently being displayed.
*
* The use of the 'bp_acomment_name' filter is deprecated. Please use
* 'bp_activity_comment_name'.
*
* @since 1.5.0
*
* @global object $activities_template {@link BP_Activity_Template}
*
* @return string $name The full name of the activity comment author.
*/
function bp_get_activity_comment_name() {
global $activities_template;
if ( isset( $activities_template->activity->current_comment->user_fullname ) ) {
$name = apply_filters( 'bp_acomment_name', $activities_template->activity->current_comment->user_fullname, $activities_template->activity->current_comment ); // Backward compatibility.
} else {
$name = $activities_template->activity->current_comment->display_name;
}
/**
* Filters the name of the author for the activity comment.
*
* @since 1.5.0
*
* @param string $name Name to be displayed with the activity comment.
*/
return apply_filters( 'bp_activity_comment_name', $name );
}
/**
* Output the formatted date_recorded of the activity comment currently being displayed.
*
* @since 1.5.0
*
*/
function bp_activity_comment_date_recorded() {
echo bp_get_activity_comment_date_recorded();
}
/**
* Return the formatted date_recorded for the activity comment currently being displayed.
*
* @since 1.5.0
*
*
* @return string|bool $date_recorded Time since the activity was recorded,
* in the form "%s ago". False on failure.
*/
function bp_get_activity_comment_date_recorded() {
/**
* Filters the recorded date of the activity comment currently being displayed.
*
* @since 1.5.0
*
* @param string|bool Date for the activity comment currently being displayed.
*/
return apply_filters( 'bp_activity_comment_date_recorded', bp_core_time_since( bp_get_activity_comment_date_recorded_raw() ) );
}
/**
* Output the date_recorded of the activity comment currently being displayed.
*
* @since 2.3.0
*
*/
function bp_activity_comment_date_recorded_raw() {
echo bp_get_activity_comment_date_recorded_raw();
}
/**
* Return the date_recorded for the activity comment currently being displayed.
*
* @since 2.3.0
*
* @global object $activities_template {@link BP_Activity_Template}
*
* @return string|bool $date_recorded Time since the activity was recorded,
* in the form "%s ago". False on failure.
*/
function bp_get_activity_comment_date_recorded_raw() {
global $activities_template;
/**
* Filters the raw recorded date of the activity comment currently being displayed.
*
* @since 2.3.0
*
* @param string|bool Raw date for the activity comment currently being displayed.
*/
return apply_filters( 'bp_activity_comment_date_recorded', $activities_template->activity->current_comment->date_recorded );
}
/**
* Output the 'delete' URL for the activity comment currently being displayed.
*
* @since 1.5.0
*
*/
function bp_activity_comment_delete_link() {
echo bp_get_activity_comment_delete_link();
}
/**
* Gets the 'delete' URL for the activity comment currently being displayed.
*
* @since 1.5.0
*
*
* @return string $link The nonced URL for deleting the current
* activity comment.
*/
function bp_get_activity_comment_delete_link() {
$link = wp_nonce_url( trailingslashit( bp_get_activity_directory_permalink() . 'delete/' . bp_get_activity_comment_id() ) . '?cid=' . bp_get_activity_comment_id(), 'bp_activity_delete_link' );
/**
* Filters the link used for deleting the activity comment currently being displayed.
*
* @since 1.5.0
*
* @param string $link Link to use for deleting the currently displayed activity comment.
*/
return apply_filters( 'bp_activity_comment_delete_link', $link );
}
/**
* Output the content of the activity comment currently being displayed.
*
* @since 1.5.0
*
*/
function bp_activity_comment_content() {
echo bp_get_activity_comment_content();
}
/**
* Return the content of the activity comment currently being displayed.
*
* The content is run through two filters. 'bp_get_activity_content'
* will apply all filters applied to activity items in general. Use
* 'bp_activity_comment_content' to modify the content of activity
* comments only.
*
* @since 1.5.0
*
* @global object $activities_template {@link BP_Activity_Template}
*
* @return string $content The content of the current activity comment.
*/
function bp_get_activity_comment_content() {
global $activities_template;
/** This filter is documented in bp-activity/bp-activity-template.php */
$content = apply_filters( 'bp_get_activity_content', $activities_template->activity->current_comment->content );
/**
* Filters the content of the current activity comment.
*
* @since 1.2.0
* @since 3.0.0 Added $context parameter to disambiguate from bp_get_activity_comment_content().
*
* @param string $content The content of the current activity comment.
* @param string $context This filter's context ("get").
*/
return apply_filters( 'bp_activity_comment_content', $content, 'get' );
}
/**
* Output the activity comment count.
*
* @since 1.2.0
*
*/
function bp_activity_comment_count() {
echo bp_activity_get_comment_count();
}
/**
* Return the comment count of an activity item.
*
* @since 1.2.0
*
* @global object $activities_template {@link BP_Activity_Template}
*
* @param array|null $deprecated Deprecated.
* @return int $count The activity comment count.
*/
function bp_activity_get_comment_count( $deprecated = null ) {
global $activities_template;
// Deprecated notice about $args.
if ( ! empty( $deprecated ) ) {
_deprecated_argument(
__FUNCTION__,
'1.2',
sprintf(
/* translators: 1: the name of the function. 2: the name of the file. */
__( '%1$s no longer accepts arguments. See the inline documentation at %2$s for more details.', 'buddypress' ),
__FUNCTION__,
__FILE__
)
);
}
// Get the count using the purpose-built recursive function.
$count = ! empty( $activities_template->activity->children )
? bp_activity_recurse_comment_count( $activities_template->activity )
: 0;
/**
* Filters the activity comment count.
*
* @since 1.2.0
*
* @param int $count The activity comment count.
*/
return apply_filters( 'bp_activity_get_comment_count', (int) $count );
}
/**
* Return the total number of comments to the current comment.
*
* This function recursively adds the total number of comments each
* activity child has, and returns them.
*
* @since 1.2.0
*
*
* @param object $comment Activity comment object.
* @param int $count The current iteration count.
* @return int $count The activity comment count.
*/
function bp_activity_recurse_comment_count( $comment, $count = 0 ) {
// Copy the count.
$new_count = $count;
// Loop through children and recursively count comments.
if ( ! empty( $comment->children ) ) {
foreach ( (array) $comment->children as $comment ) {
$new_count++;
$new_count = bp_activity_recurse_comment_count( $comment, $new_count );
}
}
/**
* Filters the total number of comments for the current comment.
*
* @since 2.1.0
*
* @param int $new_count New total count for the current comment.
* @param object $comment Activity comment object.
* @param int $count Current iteration count for the current comment.
*/
return apply_filters( 'bp_activity_recurse_comment_count', $new_count, $comment, $count );
}
/**
* Output the depth of the current activity comment.
*
* @since 2.0.0
* @since 2.8.0 Added $comment as a parameter.
*
* @param object|int $comment Object of the activity comment or activity comment ID. Usually unnecessary
* when used in activity comment loop.
*/
function bp_activity_comment_depth( $comment = 0 ) {
echo bp_activity_get_comment_depth( $comment );
}
/**
* Return the current activity comment depth.
*
* @since 2.0.0
* @since 2.8.0 Added $comment as a parameter.
*
* @param object|int $comment Object of the activity comment or activity comment ID. Usually unnecessary
* when used in activity comment loop.
* @return int
*/
function bp_activity_get_comment_depth( $comment = 0 ) {
$depth = 0;
// Activity comment loop takes precedence.
if ( isset( $GLOBALS['activities_template']->activity->current_comment->depth ) ) {
$depth = $GLOBALS['activities_template']->activity->current_comment->depth;
// Get depth for activity comment manually.
} elseif ( ! empty( $comment ) ) {
// We passed an activity ID, so fetch the activity object.
if ( is_int( $comment ) ) {
$comment = new BP_Activity_Activity( $comment );
}
// Recurse through activity tree to find the depth.
if ( is_object( $comment ) && isset( $comment->type ) && 'activity_comment' === $comment->type ) {
// Fetch the entire root comment tree... ugh.
$comments = BP_Activity_Activity::get_activity_comments( $comment->item_id, 1, constant( 'PHP_INT_MAX' ) );
// Recursively find our comment object from the comment tree.
$iterator = new RecursiveArrayIterator( $comments );
$recursive = new RecursiveIteratorIterator( $iterator, RecursiveIteratorIterator::SELF_FIRST );
foreach ( $recursive as $cid => $cobj ) {
// Skip items that are not a comment object.
if ( ! is_numeric( $cid ) || ! is_object( $cobj ) ) {
continue;
}
// We found the activity comment! Set the depth.
if ( $cid === $comment->id && isset( $cobj->depth ) ) {
$depth = $cobj->depth;
break;
}
}
}
}
/**
* Filters the comment depth of the current activity comment.
*
* @since 2.0.0
*
* @param int $depth Depth for the current activity comment.
*/
return apply_filters( 'bp_activity_get_comment_depth', $depth );
}
/**
* Output the activity comment link.
*
* @since 1.2.0
*
*/
function bp_activity_comment_link() {
echo bp_get_activity_comment_link();
}
/**
* Return the activity comment link.
*
* @since 1.2.0
*
* @global object $activities_template {@link BP_Activity_Template}
*
* @return string The activity comment link.
*/
function bp_get_activity_comment_link() {
global $activities_template;
/**
* Filters the comment link for the current activity comment.
*
* @since 1.2.0
*
* @param string $value Constructed URL parameters with activity IDs.
*/
return apply_filters( 'bp_get_activity_comment_link', '?ac=' . $activities_template->activity->id . '/#ac-form-' . $activities_template->activity->id );
}
/**
* Output the activity comment form no JavaScript display CSS.
*
* @since 1.2.0
*
*/
function bp_activity_comment_form_nojs_display() {
echo bp_get_activity_comment_form_nojs_display();
}
/**
* Return the activity comment form no JavaScript display CSS.
*
* @since 1.2.0
*
* @global object $activities_template {@link BP_Activity_Template}
*
* @return string|false The activity comment form no JavaScript
* display CSS. False on failure.
*/
function bp_get_activity_comment_form_nojs_display() {
global $activities_template;
if ( isset( $_GET['ac'] ) && ( $_GET['ac'] === ( $activities_template->activity->id . '/' ) ) ) {
return 'style="display: block"';
}
return false;
}
/**
* Output the activity comment form action.
*
* @since 1.2.0
*
*/
function bp_activity_comment_form_action() {
echo bp_get_activity_comment_form_action();
}
/**
* Return the activity comment form action.
*
* @since 1.2.0
*
*
* @return string The activity comment form action.
*/
function bp_get_activity_comment_form_action() {
/**
* Filters the activity comment form action URL.
*
* @since 1.2.0
*
* @param string $value URL to use in the comment form's action attribute.
*/
return apply_filters( 'bp_get_activity_comment_form_action', home_url( bp_get_activity_root_slug() . '/reply/' ) );
}
/**
* Output the activity permalink ID.
*
* @since 1.2.0
*
*/
function bp_activity_permalink_id() {
echo bp_get_activity_permalink_id();
}
/**
* Return the activity permalink ID.
*
* @since 1.2.0
*
*
* @return string The activity permalink ID.
*/
function bp_get_activity_permalink_id() {
/**
* Filters the activity action permalink ID.
*
* @since 1.2.0
*
* @param string $value Current action for the activity item.
*/
return apply_filters( 'bp_get_activity_permalink_id', bp_current_action() );
}
/**
* Output the activity thread permalink.
*
* @since 1.2.0
*
*/
function bp_activity_thread_permalink() {
echo esc_url( bp_get_activity_thread_permalink() );
}
/**
* Return the activity thread permalink.
*
* @since 1.2.0
*
*
* @return string $link The activity thread permalink.
*/
function bp_get_activity_thread_permalink() {
global $activities_template;
$link = bp_activity_get_permalink( $activities_template->activity->id, $activities_template->activity );
/**
* Filters the activity thread permalink.
*
* @since 1.2.0
*
* @param string $link The activity thread permalink.
*/
return apply_filters( 'bp_get_activity_thread_permalink', $link );
}
/**
* Output the activity comment permalink.
*
* @since 1.8.0
*
*/
function bp_activity_comment_permalink() {
echo esc_url( bp_get_activity_comment_permalink() );
}
/**
* Return the activity comment permalink.
*
* @since 1.8.0
*
* @return string $link The activity comment permalink.
*/
function bp_get_activity_comment_permalink() {
global $activities_template;
$link = bp_activity_get_permalink( $activities_template->activity->id, $activities_template->activity );
// Used for filter below.
$comment_id = isset( $activities_template->activity->current_comment->id )
? $activities_template->activity->current_comment->id
: 0;
/**
* Filters the activity comment permalink.
*
* @since 1.8.0
*
* @param string $link Activity comment permalink.
* @param int $comment_id ID for the current activity comment.
*/
return apply_filters( 'bp_get_activity_comment_permalink', $link, $comment_id );
}
/**
* Output the activity favorite link.
*
* @since 1.2.0
*
*/
function bp_activity_favorite_link() {
echo bp_get_activity_favorite_link();
}
/**
* Return the activity favorite link.
*
* @since 1.2.0
*
* @global object $activities_template {@link BP_Activity_Template}
*
* @return string The activity favorite link.
*/
function bp_get_activity_favorite_link() {
global $activities_template;
/**
* Filters the activity favorite link.
*
* @since 1.2.0
*
* @param string $value Constructed link for favoriting the activity comment.
*/
return apply_filters( 'bp_get_activity_favorite_link', wp_nonce_url( home_url( bp_get_activity_root_slug() . '/favorite/' . $activities_template->activity->id . '/' ), 'mark_favorite' ) );
}
/**
* Output the activity unfavorite link.
*
* @since 1.2.0
*
*/
function bp_activity_unfavorite_link() {
echo bp_get_activity_unfavorite_link();
}
/**
* Return the activity unfavorite link.
*
* @since 1.2.0
*
* @global object $activities_template {@link BP_Activity_Template}
*
* @return string The activity unfavorite link.
*/
function bp_get_activity_unfavorite_link() {
global $activities_template;
/**
* Filters the activity unfavorite link.
*
* @since 1.2.0
*
* @param string $value Constructed link for unfavoriting the activity comment.
*/
return apply_filters( 'bp_get_activity_unfavorite_link', wp_nonce_url( home_url( bp_get_activity_root_slug() . '/unfavorite/' . $activities_template->activity->id . '/' ), 'unmark_favorite' ) );
}
/**
* Output the activity CSS class.
*
* @since 1.0.0
*
*/
function bp_activity_css_class() {
echo bp_get_activity_css_class();
}
/**
* Return the current activity item's CSS class.
*
* @since 1.0.0
*
* @global object $activities_template {@link BP_Activity_Template}
*
* @return string The activity item's CSS class.
*/
function bp_get_activity_css_class() {
global $activities_template;
/**
* Filters the available mini activity actions available as CSS classes.
*
* @since 1.2.0
*
* @param array $value Array of classes used to determine classes applied to HTML element.
*/
$mini_activity_actions = apply_filters( 'bp_activity_mini_activity_types', array(
'friendship_accepted',
'friendship_created',
'new_blog',
'joined_group',
'created_group',
'new_member'
) );
$class = ' activity-item';
if ( in_array( $activities_template->activity->type, (array) $mini_activity_actions ) || empty( $activities_template->activity->content ) ) {
$class .= ' mini';
}
if ( bp_activity_get_comment_count() && bp_activity_can_comment() ) {
$class .= ' has-comments';
}
/**
* Filters the determined classes to add to the HTML element.
*
* @since 1.0.0
*
* @param string $value Classes to be added to the HTML element.
*/
return apply_filters( 'bp_get_activity_css_class', $activities_template->activity->component . ' ' . $activities_template->activity->type . $class );
}
/**
* Output the activity delete link.
*
* @since 1.1.0
*
*/
function bp_activity_delete_link() {
echo bp_get_activity_delete_link();
}
/**
* Return the activity delete link.
*
* @since 1.1.0
*
* @global object $activities_template {@link BP_Activity_Template}
*
* @return string $link Activity delete link. Contains $redirect_to arg
* if on single activity page.
*/
function bp_get_activity_delete_link() {
$url = bp_get_activity_delete_url();
$class = 'delete-activity';
// Determine if we're on a single activity page, and customize accordingly.
if ( bp_is_activity_component() && is_numeric( bp_current_action() ) ) {
$class = 'delete-activity-single';
} elseif ( 'activity_comment' === bp_get_activity_type() ) {
$class = 'acomment-delete';
}
$link = '' . __( 'Delete', 'buddypress' ) . '';
/**
* Filters the activity delete link.
*
* @since 1.1.0
*
* @param string $link Activity delete HTML link.
*/
return apply_filters( 'bp_get_activity_delete_link', $link );
}
/**
* Output the URL to delete a single activity stream item.
*
* @since 2.1.0
*
*/
function bp_activity_delete_url() {
echo esc_url( bp_get_activity_delete_url() );
}
/**
* Return the URL to delete a single activity item.
*
* @since 2.1.0
*
* @global object $activities_template {@link BP_Activity_Template}
*
* @return string $link Activity delete link. Contains $redirect_to arg
* if on single activity page.
*/
function bp_get_activity_delete_url() {
global $activities_template;
$activity_id = 0;
if ( isset( $activities_template->activity->id ) ) {
$activity_id = (int) $activities_template->activity->id;
}
$url = trailingslashit( bp_get_root_domain() . '/' . bp_get_activity_root_slug() . '/delete/' . $activity_id );
// Determine if we're on a single activity page, and customize accordingly.
if ( bp_is_activity_component() && is_numeric( bp_current_action() ) ) {
$url = add_query_arg( array( 'redirect_to' => wp_get_referer() ), $url );
} elseif ( 'activity_comment' === bp_get_activity_type() ) {
$url = add_query_arg( 'cid', $activity_id, $url );
}
$url = wp_nonce_url( $url, 'bp_activity_delete_link' );
/**
* Filters the activity delete URL.
*
* @since 2.1.0
*
* @param string $url Activity delete URL.
*/
return apply_filters( 'bp_get_activity_delete_url', $url );
}
/**
* Output the activity latest update link.
*
* @since 1.2.0
*
* @see bp_get_activity_latest_update() for description of parameters.
*
* @param int $user_id See {@link bp_get_activity_latest_update()} for description.
*/
function bp_activity_latest_update( $user_id = 0 ) {
echo bp_get_activity_latest_update( $user_id );
}
/**
* Return the activity latest update link.
*
* @since 1.2.0
*
*
* @param int $user_id If empty, will fall back on displayed user.
* @return string|bool $latest_update The activity latest update link.
* False on failure.
*/
function bp_get_activity_latest_update( $user_id = 0 ) {
if ( empty( $user_id ) ) {
$user_id = bp_displayed_user_id();
}
if ( bp_is_user_inactive( $user_id ) ) {
return false;
}
if ( !$update = bp_get_user_meta( $user_id, 'bp_latest_update', true ) ) {
return false;
}
/**
* Filters the latest update excerpt.
*
* @since 1.2.10
* @since 2.6.0 Added the `$user_id` parameter.
*
* @param string $value The excerpt for the latest update.
* @param int $user_id ID of the queried user.
*/
$latest_update = apply_filters( 'bp_get_activity_latest_update_excerpt', trim( strip_tags( bp_create_excerpt( $update['content'], bp_activity_get_excerpt_length() ) ) ), $user_id );
$latest_update = sprintf(
'%s %s',
$latest_update,
esc_url_raw( bp_activity_get_permalink( $update['id'] ) ),
esc_attr__( 'View', 'buddypress' )
);
/**
* Filters the latest update excerpt with view link appended to the end.
*
* @since 1.2.0
* @since 2.6.0 Added the `$user_id` parameter.
*
* @param string $latest_update The latest update with "view" link appended to it.
* @param int $user_id ID of the queried user.
*/
return apply_filters( 'bp_get_activity_latest_update', $latest_update, $user_id );
}
/**
* Output the activity filter links.
*
* @since 1.1.0
*
* @see bp_get_activity_filter_links() for description of parameters.
*
* @param array|bool $args See {@link bp_get_activity_filter_links()} for description.
*/
function bp_activity_filter_links( $args = false ) {
echo bp_get_activity_filter_links( $args );
}
/**
* Return the activity filter links.
*
* @since 1.1.0
*
*
* @param array|bool $args {
* @type string $style The type of markup to use for the links.
* 'list', 'paragraph', or 'span'. Default: 'list'.
* }
* @return string|bool $component_links The activity filter links.
* False on failure.
*/
function bp_get_activity_filter_links( $args = false ) {
$r = bp_parse_args(
$args,
array(
'style' => 'list',
)
);
// Define local variable.
$component_links = array();
// Fetch the names of components that have activity recorded in the DB.
$components = BP_Activity_Activity::get_recorded_components();
if ( empty( $components ) ) {
return false;
}
foreach ( (array) $components as $component ) {
// Skip the activity comment filter.
if ( 'activity' == $component ) {
continue;
}
if ( isset( $_GET['afilter'] ) && $component == $_GET['afilter'] ) {
$selected = ' class="selected"';
} else {
$selected = '';
}
$component = esc_attr( $component );
switch ( $r['style'] ) {
case 'list':
$tag = 'li';
$before = '
';
$after = '
';
break;
case 'paragraph':
$tag = 'p';
$before = '
';
$after = '
';
break;
case 'span':
$tag = 'span';
$before = '';
$after = '';
break;
}
$link = add_query_arg( 'afilter', $component );
$link = remove_query_arg( 'acpage' , $link );
/**
* Filters the activity filter link URL for the current activity component.
*
* @since 1.1.0
*
* @param string $link The URL for the current component.
* @param string $component The current component getting links constructed for.
*/
$link = apply_filters( 'bp_get_activity_filter_link_href', $link, $component );
$component_links[] = $before . '' . ucwords( $component ) . '' . $after;
}
$link = remove_query_arg( 'afilter' , $link );
if ( isset( $_GET['afilter'] ) ) {
$component_links[] = '<' . $tag . ' id="afilter-clear">' . __( 'Clear Filter', 'buddypress' ) . '' . $tag . '>';
}
/**
* Filters all of the constructed filter links.
*
* @since 1.1.0
* @since 2.6.0 Added the `$r` parameter.
*
* @param string $value All of the links to be displayed to the user.
* @param array $r Array of parsed arguments.
*/
return apply_filters( 'bp_get_activity_filter_links', implode( "\n", $component_links ), $r );
}
/**
* Determine if a comment can be made on an activity item.
*
* @since 1.2.0
*
* @global object $activities_template {@link BP_Activity_Template}
*
* @return bool $can_comment True if item can receive comments.
*/
function bp_activity_can_comment() {
global $activities_template;
$bp = buddypress();
// Determine ability to comment based on activity type name.
$activity_type = bp_get_activity_type();
// Get the 'comment-reply' support for the current activity type.
$can_comment = bp_activity_type_supports( $activity_type, 'comment-reply' );
// Neutralize activity_comment.
if ( 'activity_comment' === $activity_type ) {
$can_comment = false;
}
/**
* Filters whether a comment can be made on an activity item.
*
* @since 1.5.0
* @since 2.5.0 Use $activity_type instead of $activity_name for the second parameter.
*
* @param bool $can_comment Status on if activity can be commented on.
* @param string $activity_type Current activity type being checked on.
*/
return apply_filters( 'bp_activity_can_comment', $can_comment, $activity_type );
}
/**
* Determine whether a comment can be made on an activity reply item.
*
* @since 1.5.0
*
* @param bool|object $comment Activity comment.
* @return bool $can_comment True if comment can receive comments,
* otherwise false.
*/
function bp_activity_can_comment_reply( $comment = false ) {
// Assume activity can be commented on.
$can_comment = true;
// Check that comment exists.
if ( empty( $comment ) ) {
$comment = bp_activity_current_comment();
}
if ( ! empty( $comment ) ) {
// Fall back on current comment in activity loop.
$comment_depth = isset( $comment->depth )
? intval( $comment->depth )
: bp_activity_get_comment_depth( $comment );
// Threading is turned on, so check the depth.
if ( get_option( 'thread_comments' ) ) {
$can_comment = (bool) ( $comment_depth < get_option( 'thread_comments_depth' ) );
// No threading for comment replies if no threading for comments.
} else {
$can_comment = false;
}
}
/**
* Filters whether a comment can be made on an activity reply item.
*
* @since 1.5.0
*
* @param bool $can_comment Status on if activity reply can be commented on.
* @param object $comment Current comment object being checked on.
*/
return (bool) apply_filters( 'bp_activity_can_comment_reply', $can_comment, $comment );
}
/**
* Determine whether favorites are allowed.
*
* Defaults to true, but can be modified by plugins.
*
* @since 1.5.0
*
* @return bool True if comment can receive comments.
*/
function bp_activity_can_favorite() {
/**
* Filters whether or not users can favorite activity items.
*
* @since 1.5.0
*
* @param bool $value Whether or not favoriting is enabled.
*/
return apply_filters( 'bp_activity_can_favorite', true );
}
/**
* Output the total favorite count for a specified user.
*
* @since 1.2.0
*
* @see bp_get_total_favorite_count_for_user() for description of parameters.
*
* @param int $user_id See {@link bp_get_total_favorite_count_for_user()}.
*/
function bp_total_favorite_count_for_user( $user_id = 0 ) {
echo bp_get_total_favorite_count_for_user( $user_id );
}
/**
* Return the total favorite count for a specified user.
*
* @since 1.2.0
*
*
* @param int $user_id ID of user being queried. Default: displayed user ID.
* @return int The total favorite count for the specified user.
*/
function bp_get_total_favorite_count_for_user( $user_id = 0 ) {
$retval = false;
if ( bp_activity_can_favorite() ) {
// Default to displayed user if none is passed.
$user_id = empty( $user_id )
? bp_displayed_user_id()
: $user_id;
// Get user meta if user ID exists.
if ( ! empty( $user_id ) ) {
$retval = bp_activity_total_favorites_for_user( $user_id );
}
}
/**
* Filters the total favorite count for a user.
*
* @since 1.2.0
* @since 2.6.0 Added the `$user_id` parameter.
*
* @param int|bool $retval Total favorite count for a user. False on no favorites.
* @param int $user_id ID of the queried user.
*/
return apply_filters( 'bp_get_total_favorite_count_for_user', $retval, $user_id );
}
/**
* Output the total mention count for a specified user.
*
* @since 1.2.0
*
* @see bp_get_total_mention_count_for_user() for description of parameters.
*
* @param int $user_id See {@link bp_get_total_mention_count_for_user()}.
*/
function bp_total_mention_count_for_user( $user_id = 0 ) {
echo bp_get_total_mention_count_for_user( $user_id );
}
/**
* Return the total mention count for a specified user.
*
* @since 1.2.0
*
*
* @param int $user_id ID of user being queried. Default: displayed user ID.
* @return int The total mention count for the specified user.
*/
function bp_get_total_mention_count_for_user( $user_id = 0 ) {
// Default to displayed user if none is passed.
$user_id = empty( $user_id )
? bp_displayed_user_id()
: $user_id;
// Get user meta if user ID exists.
$retval = ! empty( $user_id )
? bp_get_user_meta( $user_id, 'bp_new_mention_count', true )
: false;
/**
* Filters the total mention count for a user.
*
* @since 1.2.0
* @since 2.6.0 Added the `$user_id` parameter.
*
* @param int|bool $retval Total mention count for a user. False on no mentions.
* @param int $user_id ID of the queried user.
*/
return apply_filters( 'bp_get_total_mention_count_for_user', $retval, $user_id );
}
/**
* Output the public message link for displayed user.
*
* @since 1.2.0
*
*/
function bp_send_public_message_link() {
echo esc_url( bp_get_send_public_message_link() );
}
/**
* Return the public message link for the displayed user.
*
* @since 1.2.0
*
*
* @return string The public message link for the displayed user.
*/
function bp_get_send_public_message_link() {
// No link if not logged in, not looking at someone else's profile.
if ( ! is_user_logged_in() || ! bp_is_user() || bp_is_my_profile() ) {
$retval = '';
} else {
$args = array( 'r' => bp_get_displayed_user_mentionname() );
$url = add_query_arg( $args, bp_get_activity_directory_permalink() );
$retval = wp_nonce_url( $url );
}
/**
* Filters the public message link for the displayed user.
*
* @since 1.2.0
*
* @param string $retval The URL for the public message link.
*/
return apply_filters( 'bp_get_send_public_message_link', $retval );
}
/**
* Recurse through all activity comments and return the activity comment IDs.
*
* @since 2.0.0
*
* @param array $activity Array of activities generated from {@link bp_activity_get()}.
* @param array $activity_ids Used for recursion purposes in this function.
* @return array
*/
function bp_activity_recurse_comments_activity_ids( $activity = array(), $activity_ids = array() ) {
if ( is_array( $activity ) && ! empty( $activity['activities'] ) ) {
$activity = $activity['activities'][0];
}
if ( ! empty( $activity->children ) ) {
foreach ($activity->children as $child ) {
$activity_ids[] = $child->id;
if( ! empty( $child->children ) ) {
$activity_ids = bp_activity_recurse_comments_activity_ids( $child, $activity_ids );
}
}
}
return $activity_ids;
}
/**
* Output the mentioned user display name.
*
* @since 1.2.0
*
* @see bp_get_mentioned_user_display_name() for description of parameters.
*
* @param int|string|bool $user_id_or_username See {@link bp_get_mentioned_user_display_name()}.
*/
function bp_mentioned_user_display_name( $user_id_or_username = false ) {
echo bp_get_mentioned_user_display_name( $user_id_or_username );
}
/**
* Returns the mentioned user display name.
*
* @since 1.2.0
*
*
* @param int|string|bool $user_id_or_username User ID or username.
* @return string The mentioned user's display name.
*/
function bp_get_mentioned_user_display_name( $user_id_or_username = false ) {
// Get user display name.
$name = bp_core_get_user_displayname( $user_id_or_username );
// If user somehow has no name, return this really lame string.
if ( empty( $name ) ) {
$name = __( 'a user', 'buddypress' );
}
/**
* Filters the mentioned user display name.
*
* @since 1.2.0
*
* @param string $name Display name for the mentioned user.
* @param int|string $user_id_or_username User ID or username use for query.
*/
return apply_filters( 'bp_get_mentioned_user_display_name', $name, $user_id_or_username );
}
/**
* Output button for sending a public message (an @-mention).
*
* @since 1.2.0
*
* @see bp_get_send_public_message_button() for description of parameters.
*
* @param array|string $args See {@link bp_get_send_public_message_button()}.
*/
function bp_send_public_message_button( $args = '' ) {
echo bp_get_send_public_message_button( $args );
}
/**
* Return button for sending a public message (an @-mention).
*
* @since 1.2.0
*
*
* @param array|string $args {
* All arguments are optional. See {@link BP_Button} for complete
* descriptions.
* @type string $id Default: 'public_message'.
* @type string $component Default: 'activity'.
* @type bool $must_be_logged_in Default: true.
* @type bool $block_self Default: true.
* @type string $wrapper_id Default: 'post-mention'.
* @type string $link_href Default: the public message link for
* the current member in the loop.
* @type string $link_text Default: 'Public Message'.
* @type string $link_class Default: 'activity-button mention'.
* }
* @return string The button for sending a public message.
*/
function bp_get_send_public_message_button( $args = '' ) {
$r = bp_parse_args(
$args,
array(
'id' => 'public_message',
'component' => 'activity',
'must_be_logged_in' => true,
'block_self' => true,
'wrapper_id' => 'post-mention',
'link_href' => bp_get_send_public_message_link(),
'link_text' => __( 'Public Message', 'buddypress' ),
'link_class' => 'activity-button mention',
)
);
/**
* Filters the public message button HTML.
*
* @since 1.2.10
*
* @param array $r Array of arguments for the public message button HTML.
*/
return bp_get_button( apply_filters( 'bp_get_send_public_message_button', $r ) );
}
/**
* Output the activity post form action.
*
* @since 1.2.0
*
*/
function bp_activity_post_form_action() {
echo bp_get_activity_post_form_action();
}
/**
* Return the activity post form action.
*
* @since 1.2.0
*
*
* @return string The activity post form action.
*/
function bp_get_activity_post_form_action() {
/**
* Filters the action url used for the activity post form.
*
* @since 1.2.0
*
* @param string $value URL to be used for the activity post form.
*/
return apply_filters( 'bp_get_activity_post_form_action', home_url( bp_get_activity_root_slug() . '/post/' ) );
}
/**
* Echo a list of linked avatars of users who have commented on the current activity item.
*
* Use this function to easily output activity comment authors' avatars.
*
* Avatars are wrapped in
elements, but you've got to provide your own
*
or wrapper markup.
*
* @since 1.7.0
*
* @see bp_core_fetch_avatar() for a description of arguments.
*
* @param array $args See {@link bp_core_fetch_avatar()}.
*/
function bp_activity_comments_user_avatars( $args = array() ) {
$r = bp_parse_args(
$args,
array(
'height' => false,
'html' => true,
'type' => 'thumb',
'width' => false,
)
);
// Get the user IDs of everyone who has left a comment to the current activity item.
$user_ids = bp_activity_get_comments_user_ids();
$output = array();
$retval = '';
if ( ! empty( $user_ids ) ) {
foreach ( (array) $user_ids as $user_id ) {
// Skip an empty user ID.
if ( empty( $user_id ) ) {
continue;
}
// Get profile link for this user.
$profile_link = bp_core_get_user_domain( $user_id );
// Get avatar for this user.
$image_html = bp_core_fetch_avatar( array(
'item_id' => $user_id,
'height' => $r['height'],
'html' => $r['html'],
'type' => $r['type'],
'width' => $r['width']
) );
// If user has link & avatar, add them to the output array.
if ( ! empty( $profile_link ) && ! empty( $image_html ) ) {
$output[] = sprintf( '%2$s', esc_url( $profile_link ), $image_html );
}
}
// If output array is not empty, wrap everything in some list items.
if ( ! empty( $output ) ) {
$retval = '
' . implode( '
', $output ) . '
';
}
}
/**
* Filters the list of linked avatars for users who have commented on the current activity item.
*
* @since 1.7.0
*
* @param string $retval HTML markup for the list of avatars.
* @param array $r Array of arguments used for each avatar.
* @param array $output Array of each avatar found, before imploded into single string.
*/
echo apply_filters( 'bp_activity_comments_user_avatars', $retval, $r, $output );
}
/**
* Return the IDs of every user who's left a comment on the current activity item.
*
* @since 1.7.0
*
* @return bool|array An array of IDs, or false if none are found.
*/
function bp_activity_get_comments_user_ids() {
global $activities_template;
$user_ids = ! empty( $activities_template->activity->children )
? (array) bp_activity_recurse_comments_user_ids( $activities_template->activity->children )
: array();
/**
* Filters the list of user IDs for the current activity item.
*
* @since 1.7.0
*
* @param array $value Array of unique user IDs for the current activity item.
*/
return apply_filters( 'bp_activity_get_comments_user_ids', array_unique( $user_ids ) );
}
/**
* Recurse through all activity comments and collect the IDs of the users who wrote them.
*
* @since 1.7.0
*
* @param array $comments Array of {@link BP_Activity_Activity} items.
* @return array Array of user IDs.
*/
function bp_activity_recurse_comments_user_ids( array $comments = array() ) {
// Default user ID's array.
$user_ids = array();
// Loop through comments and try to get user ID's.
if ( ! empty( $comments ) ) {
foreach ( $comments as $comment ) {
// If a user is a spammer, their activity items will have been
// automatically marked as spam. Skip these.
if ( ! empty( $comment->is_spam ) ) {
continue;
}
// Add user ID to array.
$user_ids[] = $comment->user_id;
// Check for commentception.
if ( ! empty( $comment->children ) ) {
$user_ids = array_merge( $user_ids, bp_activity_recurse_comments_user_ids( $comment->children ) );
}
}
}
/**
* Filters the list of user IDs for the current activity comment item.
*
* @since 2.1.0
*
* @param array $user_ids Array of user IDs for the current activity comment item.
* @param array $comments Array of comments being checked for user IDs.
*/
return apply_filters( 'bp_activity_recurse_comments_user_ids', $user_ids, $comments );
}
/**
* Output the mentionname for the displayed user.
*
* @since 1.9.0
*/
function bp_displayed_user_mentionname() {
echo bp_get_displayed_user_mentionname();
}
/**
* Get the mentionname for the displayed user.
*
* @since 1.9.0
*
* @return string Mentionname for the displayed user, if available.
*/
function bp_get_displayed_user_mentionname() {
/**
* Filters the mentionname for the displayed user.
*
* @since 1.9.0
*
* @param string $value The mentionanme for the displayed user.
*/
return apply_filters( 'bp_get_displayed_user_mentionname', bp_activity_get_user_mentionname( bp_displayed_user_id() ) );
}
/**
* Echo a list of all registered activity types for use in dropdowns or checkbox lists.
*
* @since 1.7.0
*
* @param string $output Optional. Either 'select' or 'checkbox'. Default: 'select'.
* @param array|string $args {
* Optional extra arguments.
* @type string $checkbox_name When returning checkboxes, sets the 'name'
* attribute.
* @type array|string $selected A list of types that should be checked/
* selected.
* }
*/
function bp_activity_types_list( $output = 'select', $args = '' ) {
$args = bp_parse_args(
$args,
array(
'checkbox_name' => 'bp_activity_types',
'selected' => array(),
)
);
$activities = bp_activity_get_types();
natsort( $activities );
// Loop through the activity types and output markup.
foreach ( $activities as $type => $description ) {
// See if we need to preselect the current type.
$checked = checked( true, in_array( $type, (array) $args['selected'] ), false );
$selected = selected( true, in_array( $type, (array) $args['selected'] ), false );
// Switch output based on the element.
switch ( $output ) {
case 'select' :
printf( '', esc_attr( $type ), $selected, esc_html( $description ) );
break;
case 'checkbox' :
printf( '', esc_attr( $args['checkbox_name'] ), esc_html( $description ), esc_attr( $args['checkbox_name'] ), esc_attr( $args['checkbox_name'] ), esc_attr( $type ), $checked );
break;
}
/**
* Fires at the end of the listing of activity types.
*
* This is a variable action hook. The actual hook to use will depend on the output type specified.
* Two default hooks are bp_activity_types_list_select and bp_activity_types_list_checkbox.
*
* @since 1.7.0
*
* @param array $args Array of arguments passed into function.
* @param string $type Activity type being rendered in the output.
* @param string $description Description of the activity type being rendered.
*/
do_action( 'bp_activity_types_list_' . $output, $args, $type, $description );
}
// Backpat with BP-Default for dropdown boxes only.
if ( 'select' === $output ) {
do_action( 'bp_activity_filter_options' );
}
}
/* RSS Feed Template Tags ****************************************************/
/**
* Output the sitewide activity feed link.
*
* @since 1.0.0
*
*/
function bp_sitewide_activity_feed_link() {
echo bp_get_sitewide_activity_feed_link();
}
/**
* Returns the sitewide activity feed link.
*
* @since 1.0.0
*
*
* @return string The sitewide activity feed link.
*/
function bp_get_sitewide_activity_feed_link() {
/**
* Filters the sidewide activity feed link.
*
* @since 1.0.0
*
* @param string $value The feed link for sitewide activity.
*/
return apply_filters( 'bp_get_sitewide_activity_feed_link', bp_get_root_domain() . '/' . bp_get_activity_root_slug() . '/feed/' );
}
/**
* Output the member activity feed link.
*
* @since 1.2.0
*
*/
function bp_member_activity_feed_link() {
echo bp_get_member_activity_feed_link();
}
/**
* Output the member activity feed link.
*
* @since 1.0.0
* @deprecated 1.2.0
*
* @todo properly deprecate in favor of bp_member_activity_feed_link().
*
*/
function bp_activities_member_rss_link() { echo bp_get_member_activity_feed_link(); }
/**
* Return the member activity feed link.
*
* @since 1.2.0
*
*
* @return string $link The member activity feed link.
*/
function bp_get_member_activity_feed_link() {
// Single member activity feed link.
if ( bp_is_profile_component() || bp_is_current_action( 'just-me' ) ) {
$link = bp_displayed_user_domain() . bp_get_activity_slug() . '/feed/';
// Friend feed link.
} elseif ( bp_is_active( 'friends' ) && bp_is_current_action( bp_get_friends_slug() ) ) {
$link = bp_displayed_user_domain() . bp_get_activity_slug() . '/' . bp_get_friends_slug() . '/feed/';
// Group feed link.
} elseif ( bp_is_active( 'groups' ) && bp_is_current_action( bp_get_groups_slug() ) ) {
$link = bp_displayed_user_domain() . bp_get_activity_slug() . '/' . bp_get_groups_slug() . '/feed/';
// Favorites activity feed link.
} elseif ( 'favorites' === bp_current_action() ) {
$link = bp_displayed_user_domain() . bp_get_activity_slug() . '/favorites/feed/';
// Mentions activity feed link.
} elseif ( ( 'mentions' === bp_current_action() ) && bp_activity_do_mentions() ) {
$link = bp_displayed_user_domain() . bp_get_activity_slug() . '/mentions/feed/';
// No feed link.
} else {
$link = '';
}
/**
* Filters the member activity feed link.
*
* @since 1.0.0
*
* @param string $link URL for the member activity feed.
*/
return apply_filters( 'bp_get_activities_member_rss_link', $link );
}
/**
* Return the member activity feed link.
*
* @since 1.0.0
* @deprecated 1.2.0
*
* @todo properly deprecate in favor of bp_get_member_activity_feed_link().
*
*
* @return string The member activity feed link.
*/
function bp_get_activities_member_rss_link() { return bp_get_member_activity_feed_link(); }
/** Template tags for RSS feed output ****************************************/
/**
* Outputs the activity feed item guid.
*
* @since 1.0.0
*
*/
function bp_activity_feed_item_guid() {
echo bp_get_activity_feed_item_guid();
}
/**
* Returns the activity feed item guid.
*
* @since 1.2.0
*
* @global object $activities_template {@link BP_Activity_Template}
*
* @return string The activity feed item guid.
*/
function bp_get_activity_feed_item_guid() {
global $activities_template;
/**
* Filters the activity feed item guid.
*
* @since 1.1.3
*
* @param string $value Calculated md5 value for the activity feed item.
*/
return apply_filters( 'bp_get_activity_feed_item_guid', md5( $activities_template->activity->date_recorded . '-' . $activities_template->activity->content ) );
}
/**
* Output the activity feed item title.
*
* @since 1.0.0
*
*/
function bp_activity_feed_item_title() {
echo bp_get_activity_feed_item_title();
}
/**
* Return the activity feed item title.
*
* @since 1.0.0
*
* @global object $activities_template {@link BP_Activity_Template}
*
* @return string $title The activity feed item title.
*/
function bp_get_activity_feed_item_title() {
global $activities_template;
if ( !empty( $activities_template->activity->action ) ) {
$content = $activities_template->activity->action;
} else {
$content = $activities_template->activity->content;
}
$content = explode( 'activity->type ) {
$title .= ': ' . strip_tags( ent2ncr( trim( convert_chars( bp_create_excerpt( $activities_template->activity->content, 70, array( 'ending' => " [ ]" ) ) ) ) ) );
}
/**
* Filters the activity feed item title.
*
* @since 1.0.0
*
* @param string $title The title for the activity feed item.
*/
return apply_filters( 'bp_get_activity_feed_item_title', $title );
}
/**
* Output the activity feed item link.
*
* @since 1.0.0
*
*/
function bp_activity_feed_item_link() {
echo bp_get_activity_feed_item_link();
}
/**
* Return the activity feed item link.
*
* @since 1.0.0
*
* @global object $activities_template {@link BP_Activity_Template}
*
* @return string The activity feed item link.
*/
function bp_get_activity_feed_item_link() {
global $activities_template;
$retval = ! empty( $activities_template->activity->primary_link )
? $activities_template->activity->primary_link
: '';
/**
* Filters the activity feed item link.
*
* @since 1.0.0
*
* @param string $retval The URL for the activity feed item.
*/
return apply_filters( 'bp_get_activity_feed_item_link', $retval );
}
/**
* Output the activity feed item date.
*
* @since 1.0.0
*
*/
function bp_activity_feed_item_date() {
echo bp_get_activity_feed_item_date();
}
/**
* Return the activity feed item date.
*
* @since 1.0.0
*
* @global object $activities_template {@link BP_Activity_Template}
*
* @return string The activity feed item date.
*/
function bp_get_activity_feed_item_date() {
global $activities_template;
$retval = ! empty( $activities_template->activity->date_recorded )
? $activities_template->activity->date_recorded
: '';
/**
* Filters the activity feed item date.
*
* @since 1.0.0
*
* @param string $retval The date for the activity feed item.
*/
return apply_filters( 'bp_get_activity_feed_item_date', $retval );
}
/**
* Output the activity feed item description.
*
* @since 1.0.0
*
*/
function bp_activity_feed_item_description() {
echo bp_get_activity_feed_item_description();
}
/**
* Return the activity feed item description.
*
* @since 1.0.0
*
* @global object $activities_template {@link BP_Activity_Template}
*
* @return string The activity feed item description.
*/
function bp_get_activity_feed_item_description() {
global $activities_template;
// Get the content, if exists.
$content = ! empty( $activities_template->activity->content )
? $activities_template->activity->content
: '';
// Perform a few string conversions on the content, if it's not empty.
if ( ! empty( $content ) ) {
$content = ent2ncr( convert_chars( str_replace( '%s', '', $content ) ) );
}
/**
* Filters the activity feed item description.
*
* @since 1.0.0
*
* @param string $content The description for the activity feed item.
*/
return apply_filters( 'bp_get_activity_feed_item_description', $content );
}
/**
* Template tag so we can hook activity feed to .
*
* @since 1.5.0
*
*/
function bp_activity_sitewide_feed() {
?>
values.
*/
function bp_get_activity_show_filters( $context = '' ) {
$filters = array();
$actions = bp_activity_get_actions_for_context( $context );
foreach ( $actions as $action ) {
// Friends activity collapses two filters into one.
if ( in_array( $action['key'], array( 'friendship_accepted', 'friendship_created' ) ) ) {
$action['key'] = 'friendship_accepted,friendship_created';
}
// The 'activity_update' filter is already used by the Activity component.
if ( 'bp_groups_format_activity_action_group_activity_update' === $action['format_callback'] ) {
continue;
}
$filters[ $action['key'] ] = $action['label'];
}
/**
* Filters the options available in the activity filter dropdown.
*
* @since 2.2.0
*
* @param array $filters Array of filter options for the given context, in the following format: $option_value => $option_name.
* @param string $context Context for the filter. 'activity', 'member', 'member_groups', 'group'.
*/
$filters = apply_filters( 'bp_get_activity_show_filters_options', $filters, $context );
// Build the options output.
$output = '';
if ( ! empty( $filters ) ) {
foreach ( $filters as $value => $filter ) {
$output .= '' . "\n";
}
}
/**
* Filters the HTML markup result for the activity filter dropdown.
*
* @since 2.1.0
*
* @param string $output HTML output for the activity filter dropdown.
* @param array $filters Array of filter options for the given context, in the following format: $option_value => $option_name.
* @param string $context Context for the filter. 'activity', 'member', 'member_groups', 'group'.
*/
return apply_filters( 'bp_get_activity_show_filters', $output, $filters, $context );
}