groups_action_leave_group()
Catch and process “Leave Group” button clicks.
Description
When a group member clicks on the "Leave Group" button from a group’s page, this function is run.
Note: When leaving a group from the group directory, AJAX is used and another function handles this. See bp_legacy_theme_ajax_joinleave_group().
Return
(bool)
Source
File: bp-groups/actions/leave-group.php
function groups_action_leave_group() {
if ( ! bp_is_single_item() || ! bp_is_groups_component() || ! bp_is_current_action( 'leave-group' ) ) {
return false;
}
// Nonce check.
if ( ! check_admin_referer( 'groups_leave_group' ) ) {
return false;
}
// User wants to leave any group.
if ( groups_is_user_member( bp_loggedin_user_id(), bp_get_current_group_id() ) ) {
$bp = buddypress();
// Stop sole admins from abandoning their group.
$group_admins = groups_get_group_admins( bp_get_current_group_id() );
if ( 1 == count( $group_admins ) && $group_admins[0]->user_id == bp_loggedin_user_id() ) {
bp_core_add_message( __( 'This group must have at least one organizer.', 'buddyboss' ), 'error' );
} elseif ( ! groups_leave_group( $bp->groups->current_group->id ) ) {
bp_core_add_message( __( 'There was an error leaving the group.', 'buddyboss' ), 'error' );
} else {
bp_core_add_message( __( 'You left the group.', 'buddyboss' ) );
}
$group = groups_get_current_group();
$redirect = bp_get_group_permalink( $group );
if ( ! $group->is_visible ) {
$redirect = trailingslashit( bp_loggedin_user_domain() . bp_get_groups_slug() );
}
bp_core_redirect( $redirect );
}
/** This filter is documented in bp-groups/bp-groups-actions.php */
bp_core_load_template( apply_filters( 'groups_template_group_home', 'groups/single/home' ) );
}
Changelog
| Version | Description |
|---|---|
| BuddyPress 1.2.4 | Introduced. |
Questions?
We're always happy to help with code or other questions you might have! Search our developer docs, contact support, or connect with our sales team.