%s capability has been created.', 'groups' ), stripslashes( wp_filter_nohtml_kses( $capability->capability ) ) ) ); } break; case 'edit' : if ( !( $capability_id = groups_admin_capabilities_edit_submit() ) ) { return groups_admin_capabilities_edit( $_POST['capability-id-field'] ); } else { $capability = Groups_Capability::read( $capability_id ); Groups_Admin::add_message( sprintf( __( 'The %s capability has been updated.', 'groups' ), stripslashes( wp_filter_nohtml_kses( $capability->capability ) ) ) ); } break; case 'remove' : if ( $capability_id = groups_admin_capabilities_remove_submit() ) { Groups_Admin::add_message( __( 'The capability has been deleted.', 'groups' ) ); } break; // bulk actions on groups: capabilities case 'groups-action' : if ( wp_verify_nonce( $_POST[GROUPS_ADMIN_GROUPS_ACTION_NONCE], 'admin' ) ) { $capability_ids = isset( $_POST['capability_ids'] ) ? $_POST['capability_ids'] : null; $bulk = isset( $_POST['bulk'] ) ? $_POST['bulk'] : null; if ( is_array( $capability_ids ) && ( $bulk !== null ) ) { foreach ( $capability_ids as $capability_id ) { $bulk_action = isset( $_POST['bulk-action'] ) ? $_POST['bulk-action'] : null; switch( $bulk_action ) { case 'remove' : if ( isset( $_POST['confirm'] ) ) { groups_admin_capabilities_bulk_remove_submit(); } else { return groups_admin_capabilities_bulk_remove(); } break; } break; } } } break; } } else if ( isset ( $_GET['action'] ) ) { // handle action request - show form switch( $_GET['action'] ) { case 'add' : return groups_admin_capabilities_add(); break; case 'edit' : if ( isset( $_GET['capability_id'] ) ) { return groups_admin_capabilities_edit( $_GET['capability_id'] ); } break; case 'remove' : if ( isset( $_GET['capability_id'] ) ) { return groups_admin_capabilities_remove( $_GET['capability_id'] ); } break; case 'refresh' : if ( check_admin_referer( 'refresh' ) ) { $n = Groups_WordPress::refresh_capabilities(); if ( $n > 0 ) { $output .= '

' . sprintf( _n( 'One capability has been added.', '%d capabilities have been added.', $n, 'groups' ), $n ) . '

'; } else { $output .= '

' . __( 'No new capabilities have been found.', 'groups' ) . '

'; } } else { wp_die( __( 'A Duck!', 'groups' ) ); } break; } } // // capabilities table // if ( isset( $_POST['clear_filters'] ) || isset( $_POST['capability_id'] ) || isset( $_POST['capability'] ) ) { if ( !wp_verify_nonce( $_POST[GROUPS_ADMIN_CAPABILITIES_FILTER_NONCE], 'admin' ) ) { wp_die( __( 'Access denied.', 'groups' ) ); } } // filters $capability_id = Groups_Options::get_user_option( 'capabilities_capability_id', null ); $capability = Groups_Options::get_user_option( 'capabilities_capability', null ); if ( isset( $_POST['clear_filters'] ) ) { Groups_Options::delete_user_option( 'capabilities_capability_id' ); Groups_Options::delete_user_option( 'capabilities_capability' ); $capability_id = null; $capability = null; } else if ( isset( $_POST['submitted'] ) ) { // filter by name if ( !empty( $_POST['capability'] ) ) { $capability = $_POST['capability']; Groups_Options::update_user_option( 'capabilities_capability', $capability ); } // filter by capability id if ( !empty( $_POST['capability_id'] ) ) { $capability_id = intval( $_POST['capability_id'] ); Groups_Options::update_user_option( 'capabilities_capability_id', $capability_id ); } else if ( isset( $_POST['capability_id'] ) ) { // empty && isset => '' => all $capability_id = null; Groups_Options::delete_user_option( 'capabilities_capability_id' ); } } if ( isset( $_POST['row_count'] ) ) { if ( !wp_verify_nonce( $_POST[GROUPS_ADMIN_CAPABILITIES_NONCE_1], 'admin' ) ) { wp_die( __( 'Access denied.', 'groups' ) ); } } if ( isset( $_POST['paged'] ) ) { if ( !wp_verify_nonce( $_POST[GROUPS_ADMIN_CAPABILITIES_NONCE_2], 'admin' ) ) { wp_die( __( 'Access denied.', 'groups' ) ); } } $current_url = ( is_ssl() ? 'https://' : 'http://' ) . $_SERVER['HTTP_HOST'] . $_SERVER['REQUEST_URI']; $current_url = remove_query_arg( 'paged', $current_url ); $current_url = remove_query_arg( 'action', $current_url ); $current_url = remove_query_arg( 'capability_id', $current_url ); $capability_table = _groups_get_tablename( 'capability' ); $output .= '
' . '

' . __( 'Capabilities', 'groups' ) . // add capability sprintf( '', esc_attr( __( 'Click to add a new capability', 'groups' ) ), esc_url( $current_url . '&action=add' ) ) . sprintf( '%s', esc_attr( __( 'Add', 'groups' ) ), esc_url( GROUPS_PLUGIN_URL . 'images/add.png' ) ) . sprintf( '%s', stripslashes( wp_filter_nohtml_kses( __( 'New Capability', 'groups' ) ) ) ) . '' . // refresh capabilities sprintf( '', esc_attr( __( 'Click to refresh capabilities', 'groups' ) ), esc_url( wp_nonce_url( $current_url . '&action=refresh', 'refresh' ) ) ) . sprintf( '%s', esc_attr( __( 'Refresh', 'groups' ) ), esc_url( GROUPS_PLUGIN_URL . 'images/refresh.png' ) ) . sprintf( '%s', stripslashes( wp_filter_nohtml_kses( __( 'Refresh', 'groups' ) ) ) ) . '' . '

'; $output .= Groups_Admin::render_messages(); $row_count = isset( $_POST['row_count'] ) ? intval( $_POST['row_count'] ) : 0; if ($row_count <= 0) { $row_count = Groups_Options::get_user_option( 'capabilities_per_page', GROUPS_CAPABILITIES_PER_PAGE ); } else { Groups_Options::update_user_option('capabilities_per_page', $row_count ); } $offset = isset( $_GET['offset'] ) ? intval( $_GET['offset'] ) : 0; if ( $offset < 0 ) { $offset = 0; } $paged = isset( $_REQUEST['paged'] ) ? intval( $_REQUEST['paged'] ) : 0; if ( $paged < 0 ) { $paged = 0; } $orderby = isset( $_GET['orderby'] ) ? $_GET['orderby'] : null; switch ( $orderby ) { case 'capability_id' : case 'capability' : case 'description' : break; default: $orderby = 'name'; } $order = isset( $_GET['order'] ) ? $_GET['order'] : null; switch ( $order ) { case 'asc' : case 'ASC' : $switch_order = 'DESC'; break; case 'desc' : case 'DESC' : $switch_order = 'ASC'; break; default: $order = 'ASC'; $switch_order = 'DESC'; } $filters = array( " 1=%d " ); $filter_params = array( 1 ); if ( $capability_id ) { $filters[] = " $capability_table.capability_id = %d "; $filter_params[] = $capability_id; } if ( $capability ) { $filters[] = " $capability_table.capability LIKE '%%%s%%' "; $filter_params[] = $capability; } if ( !empty( $filters ) ) { $filters = " WHERE " . implode( " AND ", $filters ); } else { $filters = ''; } $count_query = $wpdb->prepare( "SELECT COUNT(*) FROM $capability_table $filters", $filter_params ); $count = $wpdb->get_var( $count_query ); if ( $count > $row_count ) { $paginate = true; } else { $paginate = false; } $pages = ceil ( $count / $row_count ); if ( $paged > $pages ) { $paged = $pages; } if ( $paged != 0 ) { $offset = ( $paged - 1 ) * $row_count; } $query = $wpdb->prepare( "SELECT * FROM $capability_table $filters ORDER BY $orderby $order LIMIT $row_count OFFSET $offset", $filter_params ); $results = $wpdb->get_results( $query, OBJECT ); $column_display_names = array( 'capability_id' => __( 'ID', 'groups' ), 'capability' => __( 'Capability', 'groups' ), 'description' => __( 'Description', 'groups' ) ); $output .= '
'; $output .= '
' . '
' . '
' . '' . __( 'Filters', 'groups' ) . '' . '' . ' ' . '' . ' ' . wp_nonce_field( 'admin', GROUPS_ADMIN_CAPABILITIES_FILTER_NONCE, true, false ) . '' . ' ' . '' . '' . '
' . '
' . '
'; if ( $paginate ) { require_once( GROUPS_CORE_LIB . '/class-groups-pagination.php' ); $pagination = new Groups_Pagination( $count, null, $row_count ); $output .= '
'; $output .= '
'; $output .= wp_nonce_field( 'admin', GROUPS_ADMIN_CAPABILITIES_NONCE_2, true, false ); $output .= '
'; $output .= '
'; $output .= $pagination->pagination( 'top' ); $output .= '
'; $output .= '
'; } $output .= '
'; $output .= '
'; $output .= '
'; $output .= ''; $output .= ''; $output .= wp_nonce_field( 'admin', GROUPS_ADMIN_CAPABILITIES_NONCE_1, true, false ); $output .= ''; $output .= '
'; $output .= '
'; $output .= '
'; $output .= '
'; $output .= '
'; $output .= '
'; $output .= '
'; $output .= ''; $output .= ''; $output .= '
'; $output .= '
'; $output .= '
'; $output .= wp_nonce_field( 'admin', GROUPS_ADMIN_GROUPS_ACTION_NONCE, true, false ); $output .= ''; $output .= ''; $output .= ''; $output .= ''; $output .= ''; foreach ( $column_display_names as $key => $column_display_name ) { $options = array( 'orderby' => $key, 'order' => $switch_order ); $class = $key; if ( !in_array($key, array( 'capabilities', 'edit', 'remove' ) ) ) { if ( strcmp( $key, $orderby ) == 0 ) { $lorder = strtolower( $order ); $class = "$key manage-column sorted $lorder"; } else { $class = "$key manage-column sortable"; } $column_display_name = sprintf( '%s', esc_url( add_query_arg( $options, $current_url ) ), esc_html( $column_display_name ) ); } else { $column_display_name = esc_html( $column_display_name ); } $output .= sprintf( '', esc_attr( $class ), $column_display_name ); } $output .= ''; $output .= ''; $output .= ''; if ( count( $results ) > 0 ) { for ( $i = 0; $i < count( $results ); $i++ ) { $result = $results[$i]; // Construct the "edit" URL. $edit_url = add_query_arg( array( 'capability_id' => intval( $result->capability_id ), 'action' => 'edit', 'paged' => $paged ), $current_url ); // Construct the "delete" URL. $delete_url = add_query_arg( array( 'capability_id' => intval( $result->capability_id ), 'action' => 'remove', 'paged' => $paged ), $current_url ); // Construct row actions for this group. $row_actions = '
' . '' . '' . '' . __( 'Edit', 'groups' ) . ''; if ( $result->capability !== Groups_Post_Access::READ_POST_CAPABILITY ) { $row_actions .= ' | '. '' . '' . '' . '' . __( 'Remove', 'groups' ) . '' . ''; } $row_actions .= '
'; // .row-actions $output .= ''; $output .= ''; $output .= ''; $output .= ''; $output .= ''; $output .= ''; } } else { $output .= ''; } $output .= ''; $output .= '
%s
'; $output .= ''; $output .= ''; $output .= $result->capability_id; $output .= ''; $output .= sprintf( '%s', esc_url( $edit_url ), stripslashes( wp_filter_nohtml_kses( $result->capability ) ) ); $output .= $row_actions; $output .= ''; $output .= stripslashes( wp_filter_nohtml_kses( $result->description ) ); $output .= '
' . __( 'There are no results.', 'groups' ) . '
'; $output .= Groups_UIE::render_add_titles( '.capabilities-overview table td' ); $output .= '
'; // #groups-action if ( $paginate ) { require_once( GROUPS_CORE_LIB . '/class-groups-pagination.php' ); $pagination = new Groups_Pagination($count, null, $row_count); $output .= '
'; $output .= $pagination->pagination( 'bottom' ); $output .= '
'; } $output .= '
'; // .capabilities-overview $output .= '
'; // .manage-capabilities echo $output; } // function groups_admin_capabilities()