diff --git a/includes/admin/class-site-health.php b/includes/admin/class-site-health.php index 45ceec2d..027e3502 100644 --- a/includes/admin/class-site-health.php +++ b/includes/admin/class-site-health.php @@ -1,8 +1,6 @@ common()->theme()->get_custom_templates_list(); + /** + * Return labels array with translations. + * + * @return array Labels array containing translations. + */ + public static function get_labels() { + if ( empty( self::$labels ) ) { + self::$labels = array( + 'yes' => __( 'Yes', 'ultimate-member' ), + 'no' => __( 'No', 'ultimate-member' ), + 'all' => __( 'All', 'ultimate-member' ), + 'default' => __( 'Default', 'ultimate-member' ), + 'nopages' => __( 'No predefined page', 'ultimate-member' ), + 'empty' => __( 'Empty', 'ultimate-member' ), + ); + } + return self::$labels; + } + + /** + * Register site status tests. + * + * @param array $tests The array of site status tests. + * + * @return array The modified array of site status tests. + */ + public function register_site_status_tests( $tests ) { + // Searching for custom templates and outdated versions. + $custom_templates = UM()->common()->theme()->get_custom_templates_list(); if ( ! empty( $custom_templates ) ) { $tests['direct']['um_override_templates'] = array( 'label' => esc_html__( 'Are the Ultimate Member templates out of date?', 'ultimate-member' ), @@ -42,6 +76,7 @@ class Site_Health { ); } + // Searching for outdated icons. $first_activation_date = get_option( 'um_first_activation_date', false ); if ( ! empty( $first_activation_date ) && $first_activation_date < 1716336000 ) { $tests['direct']['um_outdated_icons'] = array( @@ -67,6 +102,11 @@ class Site_Health { return $tests; } + /** + * Calculates the status of custom Ultimate Member templates and provides a detailed result array. + * + * @return array Result array containing details about the custom templates status. + */ public function override_templates_test() { $result = array( 'label' => __( 'You have the most recent version of custom Ultimate Member templates', 'ultimate-member' ), @@ -102,7 +142,9 @@ class Site_Health { } /** - * @return bool|array + * Retrieves outdated icons in Ultimate Member forms and provides details and actions for updating. + * + * @return array|bool Returns an array with description and actions for updating outdated icons, or null if nothing needs updating. */ private function get_outdated_icons() { $result = array( @@ -181,6 +223,17 @@ class Site_Health { ); } + /** + * Filters the site health test information about outdated icons. + * + * @hook um_get_outdated_icons_result + * + * @since 2.8.6 + * + * @param {array} $result The site health test information about outdated icons. + * + * @return {array} The site health test information about outdated icons. + */ $result = apply_filters( 'um_get_outdated_icons_result', $result, $old_icons ); if ( ! empty( $result['description'] ) ) { @@ -197,6 +250,11 @@ class Site_Health { return false; } + /** + * Retrieve information about outdated icons in Ultimate Member forms and settings. + * + * @return array Information about the status of icons, including label, status, badge, description, actions, and test name. + */ public function outdated_icons_test() { $result = array( 'label' => __( 'You have the most recent version of icons in Ultimate Member forms and settings', 'ultimate-member' ), @@ -226,10 +284,22 @@ class Site_Health { return $result; } + /** + * Check if a specific field is banned for a user based on the meta key. + * + * @param string $metakey The meta key to check if it's banned. + * + * @return bool True if the field is banned, false otherwise. + */ private static function field_is_banned( $metakey ) { return UM()->user()->is_metakey_banned( $metakey ) || in_array( strtolower( $metakey ), UM()->builtin()->blacklist_fields, true ); } + /** + * Retrieve information about banned fields in Ultimate Member forms. + * + * @return bool|array Information about banned fields, including description, actions, and form data. + */ public function get_banned_fields() { $result = array( 'description' => '', @@ -287,11 +357,13 @@ class Site_Health { foreach ( $break_forms as $form_id => $form_data ) { $fields = array(); foreach ( $form_data['fields'] as $metakey => $field_title ) { - $fields[] = sprintf( __( '%s (%s)', 'ultimate-member' ), $field_title, $metakey ); + // translators: %1$s is the field title, %2$s is the field metakey + $fields[] = sprintf( __( '%1$s (%2$s)', 'ultimate-member' ), $field_title, $metakey ); } $forms_description[] = '

' . sprintf( - __( 'Fields in %s (#ID: %s):', 'ultimate-member' ), + // translators: %1$s is the form link, %2$s is the form title, %3$s is the form ID + __( 'Fields in %2$s (#ID: %3$s):', 'ultimate-member' ), esc_url( $form_data['link'] ), esc_html( $form_data['title'] ), esc_html( $form_id ) @@ -308,6 +380,17 @@ class Site_Health { ); } + /** + * Filters the site health test information about banned fields. + * + * @hook um_get_banned_fields_result + * + * @since 2.10.3 + * + * @param {array} $result The site health test information about banned fields. + * + * @return {array} The site health test information about banned fields. + */ $result = apply_filters( 'um_get_banned_fields_result', $result ); if ( ! empty( $result['description'] ) ) { @@ -324,6 +407,11 @@ class Site_Health { return false; } + /** + * Retrieve information about banned fields in Ultimate Member forms. + * + * @return array Information about the status of banned fields, including label, status, badge, description, actions, and test name. + */ public function banned_fields_test() { $result = array( 'label' => __( 'You have correct Ultimate Member fields', 'ultimate-member' ), @@ -352,64 +440,46 @@ class Site_Health { return $result; } - private function get_roles() { - return UM()->roles()->get_roles(); + /** + * Retrieve role metadata by slug. + * + * @todo replace with UM()->roles()->role_data( $slug ); + * + * @param string $slug The slug of the role. + * + * @return mixed|false Role metadata if found, false if not found. + */ + private function get_role_meta( $slug ) { + return get_option( "um_role_{$slug}_meta", false ); } - private function get_forms() { - $forms_data = get_posts( - array( - 'post_type' => 'um_form', - 'posts_per_page' => -1, - ) + /** + * Retrieve field data based on the field key and field configuration. + * + * @param string $field_key The key of the field. + * @param array $field The configuration of the field. + * + * @return array Field data including label and value. + */ + private function get_field_data( $field_key, $field ) { + $row = array_key_exists( 'type', $field ) && 'row' === $field['type']; + $title = $row ? __( 'Row: ', 'ultimate-member' ) . $field['id'] : __( 'Field: ', 'ultimate-member' ) . $field['metakey']; + $field = array_map( + function ( $item ) { + if ( is_array( $item ) ) { + $item = maybe_serialize( $item ); + } + return $item; + }, + $field ); - $forms = array(); - foreach ( $forms_data as $form ) { - $forms[ 'ID#' . $form->ID ] = $form->post_title; - } - return $forms; - } - private function get_role_meta( $key ) { - return get_option( "um_role_{$key}_meta", false ); - } - - public function array_map( $item ) { - if ( is_array( $item ) ) { - $item = maybe_serialize( $item ); - } - return $item; - } - - private function get_field_data( $info, $key, $field_key, $field ) { - $row = array_key_exists( 'type', $field ) && 'row' === $field['type']; - $title = $row ? __( 'Row: ', 'ultimate-member' ) . $field['id'] : __( 'Field: ', 'ultimate-member' ) . $field['metakey']; - $field = array_map( array( &$this, 'array_map' ), $field ); - $field_info = array( - 'um-field_' . $field_key => array( + return array( + 'field_' . $field_key => array( 'label' => $title, 'value' => $field, ), ); - - return $field_info; - } - - private function get_member_directories() { - $query = new WP_Query(); - $member_directories = $query->query( - array( - 'post_type' => 'um_directory', - 'posts_per_page' => -1, - ) - ); - - $directories = array(); - foreach ( $member_directories as $directory ) { - $directories[ 'ID#' . $directory->ID ] = $directory->post_title; - } - - return $directories; } /** @@ -422,19 +492,71 @@ class Site_Health { * @return array The updated Site Health information. */ public function debug_information( $info ) { - $labels = array( - 'yes' => __( 'Yes', 'ultimate-member' ), - 'no' => __( 'No', 'ultimate-member' ), - 'all' => __( 'All', 'ultimate-member' ), - 'default' => __( 'Default', 'ultimate-member' ), - 'nopages' => __( 'No predefined page', 'ultimate-member' ), + $info['ultimate-member'] = array( + 'label' => __( 'Ultimate Member Settings', 'ultimate-member' ), + 'description' => __( 'This debug information for your Ultimate Member installation can assist you in getting support.', 'ultimate-member' ), + 'fields' => $this->settings_debug_information(), ); - $info['ultimate-member'] = array( - 'label' => __( 'Ultimate Member', 'ultimate-member' ), - 'description' => __( 'This debug information for your Ultimate Member installation can assist you in getting support.', 'ultimate-member' ), - 'fields' => array(), - ); + // User roles settings + $info = $this->roles_debug_information( $info ); + + // Forms settings + $info = $this->forms_debug_information( $info ); + + // Members directory + if ( UM()->options()->get( 'members_page' ) ) { + $info = $this->member_directories_debug_information( $info ); + } + + /** + * Filters the site health information. + * + * @hook um_site_health_extend + * + * @since 2.10.3 + * + * @param {array} $info The site health info to be filtered. + * + * @return {array} The filtered site health info. + */ + return apply_filters( 'um_site_health_extend', $info ); + } + + /** + * Retrieve debug information for various settings in the application. + * + * @return array Debug information for general, access, emails, appearance, advanced, and license settings. + */ + public function settings_debug_information() { + // General settings + $general = $this->general_settings_debug_information(); + + // Access settings + $access = $this->access_settings_debug_information(); + + // Emails settings + $emails = $this->emails_settings_debug_information(); + + // Appearance settings + $appearance = $this->appearance_settings_debug_information(); + + // Advanced settings + $advanced = $this->advanced_settings_debug_information(); + + // License settings + $license = $this->license_settings_debug_information(); + + return array_merge( $general, $access, $emails, $appearance, $advanced, $license ); + } + + /** + * Retrieve debug information about general settings in Ultimate Member. + * + * @return array Information about the general settings including pages, user settings, and related options. + */ + public function general_settings_debug_information() { + $labels = self::get_labels(); // Pages settings. $pages = array(); @@ -456,10 +578,12 @@ class Site_Health { $pages[ $page_title ] = sprintf( __( '%1$s (ID#%2$d) | %3$s', 'ultimate-member' ), get_the_title( $predefined_page_id ), $predefined_page_id, get_permalink( $predefined_page_id ) ); } - $pages = apply_filters( 'um_debug_information_pages', $pages ); - $pages_settings = array( - 'um-pages' => array( + 'pages_separator' => array( + 'label' => __( 'General > Pages', 'ultimate-member' ), + 'value' => '---------------------------------------------------------------------', + ), + 'pages' => array( 'label' => __( 'Pages', 'ultimate-member' ), 'value' => $pages, ), @@ -470,86 +594,57 @@ class Site_Health { $display_name = UM()->config()->display_name_options; $user_settings = array( - 'um-permalink_base' => array( + 'user_separator' => array( + 'label' => __( 'General > Users', 'ultimate-member' ), + 'value' => '---------------------------------------------------------------------', + ), + 'register_role' => array( + 'label' => __( 'Registration Default Role', 'ultimate-member' ), + 'value' => ! empty( UM()->options()->get( 'register_role' ) ) ? UM()->options()->get( 'register_role' ) : __( 'Default', 'ultimate-member' ), + ), + 'permalink_base' => array( 'label' => __( 'Profile Permalink Base', 'ultimate-member' ), 'value' => isset( $permalink_base[ UM()->options()->get( 'permalink_base' ) ] ) ? $permalink_base[ UM()->options()->get( 'permalink_base' ) ] : $labels['no'], ), - 'um-display_name' => array( - 'label' => __( 'User Display Name', 'ultimate-member' ), - 'value' => isset( $display_name[ UM()->options()->get( 'display_name' ) ] ) ? $display_name[ UM()->options()->get( 'display_name' ) ] : $labels['no'], - ), - 'um-author_redirect' => array( - 'label' => __( 'Automatically redirect author page to their profile?', 'ultimate-member' ), - 'value' => UM()->options()->get( 'author_redirect' ) ? $labels['yes'] : $labels['no'], - ), - 'um-members_page' => array( - 'label' => __( 'Enable Members Directory', 'ultimate-member' ), - 'value' => UM()->options()->get( 'members_page' ) ? $labels['yes'] : $labels['no'], - ), - 'um-toggle_password' => array( - 'label' => __( 'Show/hide password button', 'ultimate-member' ), - 'value' => UM()->options()->get( 'toggle_password' ) ? $labels['yes'] : $labels['no'], - ), - 'um-require_strongpass' => array( - 'label' => __( 'Require Strong Passwords', 'ultimate-member' ), - 'value' => UM()->options()->get( 'require_strongpass' ) ? $labels['yes'] : $labels['no'], - ), - 'um-password_min_chars' => array( - 'label' => __( 'Require Strong Passwords', 'ultimate-member' ), - 'value' => UM()->options()->get( 'password_min_chars' ), - ), - 'um-password_max_chars' => array( - 'label' => __( 'Require Strong Passwords', 'ultimate-member' ), - 'value' => UM()->options()->get( 'password_max_chars' ), - ), - 'um-profile_noindex' => array( - 'label' => __( 'Avoid indexing profile by search engines', 'ultimate-member' ), - 'value' => UM()->options()->get( 'profile_noindex' ) ? $labels['yes'] : $labels['no'], - ), - 'um-activation_link_expiry_time' => array( - 'label' => __( 'Activation link lifetime', 'ultimate-member' ), - 'value' => UM()->options()->get( 'activation_link_expiry_time' ), - ), - 'um-use_gravatars' => array( - 'label' => __( 'Use Gravatars?', 'ultimate-member' ), - 'value' => UM()->options()->get( 'use_gravatars' ) ? $labels['yes'] : $labels['no'], - ), - 'um-admin_ignore_user_status' => array( - 'label' => __( 'Ignore the "User Role > Registration Options" if this user is added from the wp-admin dashboard', 'ultimate-member' ), - 'value' => UM()->options()->get( 'admin_ignore_user_status' ) ? $labels['yes'] : $labels['no'], - ), - 'um-delete_comments' => array( - 'label' => __( 'Deleting user comments after deleting a user', 'ultimate-member' ), - 'value' => UM()->options()->get( 'delete_comments' ) ? $labels['yes'] : $labels['no'], - ), ); if ( 'custom_meta' === UM()->options()->get( 'permalink_base' ) ) { - $user_settings = UM()->array_insert_before( - $user_settings, - 'um-display_name', - array( - 'um-permalink_base_custom_meta' => array( - 'label' => __( 'Profile Permalink Base Custom Meta Key', 'ultimate-member' ), - 'value' => UM()->options()->get( 'permalink_base_custom_meta' ), - ), - ) + $user_settings['permalink_base_custom_meta'] = array( + 'label' => __( 'Profile Permalink Base Custom Meta Key', 'ultimate-member' ), + 'value' => UM()->options()->get( 'permalink_base_custom_meta' ), ); } + $user_settings['display_name'] = array( + 'label' => __( 'User Display Name', 'ultimate-member' ), + 'value' => isset( $display_name[ UM()->options()->get( 'display_name' ) ] ) ? $display_name[ UM()->options()->get( 'display_name' ) ] : $labels['no'], + ); + if ( 'field' === UM()->options()->get( 'display_name' ) ) { - $user_settings = UM()->array_insert_before( - $user_settings, - 'um-author_redirect', - array( - 'um-display_name_field' => array( - 'label' => __( 'Display Name Custom Field(s)', 'ultimate-member' ), - 'value' => UM()->options()->get( 'display_name_field' ), - ), - ) + $user_settings['display_name_field'] = array( + 'label' => __( 'Display Name Custom Field(s)', 'ultimate-member' ), + 'value' => UM()->options()->get( 'display_name_field' ), ); } + $user_settings = array_merge( + $user_settings, + array( + 'author_redirect' => array( + 'label' => __( 'Hide author pages (enable author page redirect to user profile)', 'ultimate-member' ), + 'value' => UM()->options()->get( 'author_redirect' ) ? $labels['yes'] : $labels['no'], + ), + 'members_page' => array( + 'label' => __( 'Enable Members Directory', 'ultimate-member' ), + 'value' => UM()->options()->get( 'members_page' ) ? $labels['yes'] : $labels['no'], + ), + 'use_gravatars' => array( + 'label' => __( 'Use Gravatars?', 'ultimate-member' ), + 'value' => UM()->options()->get( 'use_gravatars' ) ? $labels['yes'] : $labels['no'], + ), + ) + ); + if ( UM()->options()->get( 'use_gravatars' ) ) { $gravatar_options = array( 'default' => __( 'Default', 'ultimate-member' ), @@ -562,32 +657,139 @@ class Site_Health { 'blank' => __( 'Blank ( a transparent PNG image )', 'ultimate-member' ), ); - $user_settings['um-use_um_gravatar_default_builtin_image'] = array( + $user_settings['use_um_gravatar_default_builtin_image'] = array( 'label' => __( 'Use Gravatar builtin image', 'ultimate-member' ), 'value' => $gravatar_options[ UM()->options()->get( 'use_um_gravatar_default_builtin_image' ) ], ); if ( 'default' === UM()->options()->get( 'use_um_gravatar_default_builtin_image' ) ) { - $user_settings['um-use_um_gravatar_default_image'] = array( - 'label' => __( 'Use Default plugin avatar as Gravatar\'s Default avatar', 'ultimate-member' ), + $user_settings['use_um_gravatar_default_image'] = array( + 'label' => __( 'Replace Gravatar\'s Default avatar (Set Default plugin avatar as Gravatar\'s Default avatar)', 'ultimate-member' ), 'value' => UM()->options()->get( 'use_um_gravatar_default_image' ) ? $labels['yes'] : $labels['no'], ); } } + $user_settings = array_merge( + $user_settings, + array( + 'admin_ignore_user_status' => array( + 'label' => __( 'Ignore the "User Role > Registration Options" if this user is added from the wp-admin dashboard', 'ultimate-member' ), + 'value' => UM()->options()->get( 'admin_ignore_user_status' ) ? $labels['yes'] : $labels['no'], + ), + 'delete_comments' => array( + 'label' => __( 'Delete user comments (enable deleting user comments after deleting a user)', 'ultimate-member' ), + 'value' => UM()->options()->get( 'delete_comments' ) ? $labels['yes'] : $labels['no'], + ), + 'toggle_password' => array( + 'label' => __( 'Toggle Password Visibility (enable password show/hide icon on password field)', 'ultimate-member' ), + 'value' => UM()->options()->get( 'toggle_password' ) ? $labels['yes'] : $labels['no'], + ), + 'require_strongpass' => array( + 'label' => __( 'Require Strong Passwords', 'ultimate-member' ), + 'value' => UM()->options()->get( 'require_strongpass' ) ? $labels['yes'] : $labels['no'], + ), + ) + ); + + if ( UM()->options()->get( 'require_strongpass' ) ) { + $user_settings = array_merge( + $user_settings, + array( + 'password_min_chars' => array( + 'label' => __( 'Password minimum length', 'ultimate-member' ), + 'value' => UM()->options()->get( 'password_min_chars' ), + ), + 'password_max_chars' => array( + 'label' => __( 'Password maximum length', 'ultimate-member' ), + 'value' => UM()->options()->get( 'password_max_chars' ), + ), + ) + ); + } + + $user_settings = array_merge( + $user_settings, + array( + 'activation_link_expiry_time' => array( + 'label' => __( 'Email activation link expiration (days)', 'ultimate-member' ), + 'value' => UM()->options()->get( 'activation_link_expiry_time' ) ? UM()->options()->get( 'activation_link_expiry_time' ) : __( 'Not expired', 'ultimate-member' ), + ), + 'profile_noindex' => array( + 'label' => __( 'Avoid indexing profile by search engines', 'ultimate-member' ), + 'value' => UM()->options()->get( 'profile_noindex' ) ? $labels['yes'] : $labels['no'], + ), + 'profile_title' => array( + 'label' => __( 'User Profile Title', 'ultimate-member' ), + 'value' => stripslashes( UM()->options()->get( 'profile_title' ) ), + ), + 'profile_desc' => array( + 'label' => __( 'User Profile Dynamic Meta Description', 'ultimate-member' ), + 'value' => stripslashes( UM()->options()->get( 'profile_desc' ) ), + ), + ) + ); + // Account settings $account_settings = array( - 'um-account_tab_password' => array( + 'account_separator' => array( + 'label' => __( 'General > Account', 'ultimate-member' ), + 'value' => '---------------------------------------------------------------------', + ), + 'account_name' => array( + 'label' => __( 'Display First & Last name fields (enable to display First & Last name fields)', 'ultimate-member' ), + 'value' => UM()->options()->get( 'account_name' ) ? $labels['yes'] : $labels['no'], + ), + 'account_email' => array( + 'label' => __( 'Allow users to change email (enable changing email via the account page)', 'ultimate-member' ), + 'value' => UM()->options()->get( 'account_email' ) ? $labels['yes'] : $labels['no'], + ), + 'account_general_password' => array( + 'label' => __( 'Require password to update account (enable required password)', 'ultimate-member' ), + 'value' => UM()->options()->get( 'account_general_password' ) ? $labels['yes'] : $labels['no'], + ), + 'account_tab_password' => array( 'label' => __( 'Password Account Tab', 'ultimate-member' ), 'value' => UM()->options()->get( 'account_tab_password' ) ? $labels['yes'] : $labels['no'], ), - 'um-account_tab_privacy' => array( + 'account_tab_privacy' => array( 'label' => __( 'Privacy Account Tab', 'ultimate-member' ), 'value' => UM()->options()->get( 'account_tab_privacy' ) ? $labels['yes'] : $labels['no'], ), ); + if ( UM()->options()->get( 'account_name' ) ) { + $account_settings = UM()->array_insert_before( + $account_settings, + 'account_email', + array( + 'account_name_disable' => array( + 'label' => __( 'Disable First & Last name field editing', 'ultimate-member' ), + 'value' => UM()->options()->get( 'account_name_disable' ) ? $labels['yes'] : $labels['no'], + ), + 'account_name_require' => array( + 'label' => __( 'Require First & Last Name', 'ultimate-member' ), + 'value' => UM()->options()->get( 'account_name_require' ) ? $labels['yes'] : $labels['no'], + ), + ) + ); + } + + if ( UM()->options()->get( 'account_tab_privacy' ) ) { + $account_settings['account_hide_in_directory'] = array( + 'label' => __( 'Allow users to hide their profiles from directory', 'ultimate-member' ), + 'value' => UM()->options()->get( 'account_hide_in_directory' ) ? $labels['yes'] : $labels['no'], + ); + + if ( UM()->options()->get( 'account_hide_in_directory' ) ) { + $account_settings['account_hide_in_directory_default'] = array( + 'label' => __( 'Hide profiles from directory by default', 'ultimate-member' ), + 'value' => UM()->options()->get( 'account_hide_in_directory_default' ), + ); + } + } + if ( false !== UM()->account()->is_notifications_tab_visible() ) { - $account_settings['um-account_tab_notifications'] = array( + $account_settings['account_tab_notifications'] = array( 'label' => __( 'Notifications Account Tab', 'ultimate-member' ), 'value' => UM()->options()->get( 'account_tab_notifications' ) ? $labels['yes'] : $labels['no'], ); @@ -596,56 +798,25 @@ class Site_Health { $account_settings = array_merge( $account_settings, array( - 'um-account_tab_delete' => array( + 'account_tab_delete' => array( 'label' => __( 'Delete Account Tab', 'ultimate-member' ), 'value' => UM()->options()->get( 'account_tab_delete' ) ? $labels['yes'] : $labels['no'], ), - 'um-delete_account_text' => array( - 'label' => __( 'Account Deletion Custom Text', 'ultimate-member' ), - 'value' => UM()->options()->get( 'delete_account_text' ), - ), - 'um-delete_account_no_pass_required_text' => array( - 'label' => __( 'Account Deletion without password Custom Text', 'ultimate-member' ), - 'value' => UM()->options()->get( 'delete_account_no_pass_required_text' ), - ), - 'um-account_name' => array( - 'label' => __( 'Add a First & Last Name fields', 'ultimate-member' ), - 'value' => UM()->options()->get( 'account_name' ) ? $labels['yes'] : $labels['no'], - ), ) ); - if ( UM()->options()->get( 'account_name' ) ) { - $account_settings['um-account_name_disable'] = array( - 'label' => __( 'Disable First & Last name field editing', 'ultimate-member' ), - 'value' => UM()->options()->get( 'account_name_disable' ) ? $labels['yes'] : $labels['no'], - ); - $account_settings['um-account_name_require'] = array( - 'label' => __( 'Require First & Last Name', 'ultimate-member' ), - 'value' => UM()->options()->get( 'account_name_require' ) ? $labels['yes'] : $labels['no'], - ); - } - - $account_settings['um-account_email'] = array( - 'label' => __( 'Allow users to change email', 'ultimate-member' ), - 'value' => UM()->options()->get( 'account_email' ) ? $labels['yes'] : $labels['no'], - ); - - $account_settings['um-account_general_password'] = array( - 'label' => __( 'Password is required?', 'ultimate-member' ), - 'value' => UM()->options()->get( 'account_general_password' ) ? $labels['yes'] : $labels['no'], - ); - - $account_settings['um-account_hide_in_directory'] = array( - 'label' => __( 'Allow users to hide their profiles from directory', 'ultimate-member' ), - 'value' => UM()->options()->get( 'account_hide_in_directory' ) ? $labels['yes'] : $labels['no'], - ); - - if ( UM()->options()->get( 'account_hide_in_directory' ) ) { - $account_settings['um-account_hide_in_directory_default'] = array( - 'label' => __( 'Hide profiles from directory by default', 'ultimate-member' ), - 'value' => UM()->options()->get( 'account_hide_in_directory_default' ), - ); + if ( UM()->options()->get( 'account_tab_delete' ) ) { + if ( UM()->account()->current_password_is_required( 'delete' ) ) { + $account_settings['delete_account_text'] = array( + 'label' => __( 'Account Deletion Text', 'ultimate-member' ), + 'value' => UM()->options()->get( 'delete_account_text' ), + ); + } else { + $account_settings['delete_account_no_pass_required_text'] = array( + 'label' => __( 'Account Deletion without password Text', 'ultimate-member' ), + 'value' => UM()->options()->get( 'delete_account_no_pass_required_text' ), + ); + } } // Uploads settings @@ -664,40 +835,55 @@ class Site_Health { } } $uploads_settings = array( - 'um-profile_photo_max_size' => array( - 'label' => __( 'Profile Photo Maximum File Size (bytes)', 'ultimate-member' ), - 'value' => UM()->options()->get( 'profile_photo_max_size' ), + 'uploads_separator' => array( + 'label' => __( 'General > Uploads', 'ultimate-member' ), + 'value' => '---------------------------------------------------------------------', ), - 'um-cover_photo_max_size' => array( - 'label' => __( 'Cover Photo Maximum File Size (bytes)', 'ultimate-member' ), - 'value' => UM()->options()->get( 'cover_photo_max_size' ), - ), - 'um-photo_thumb_sizes' => array( - 'label' => __( 'Profile Photo Thumbnail Sizes (px)', 'ultimate-member' ), - 'value' => $profile_sizes_list, - ), - 'um-cover_thumb_sizes' => array( - 'label' => __( 'Cover Photo Thumbnail Sizes (px)', 'ultimate-member' ), - 'value' => $cover_sizes_list, - ), - 'um-image_orientation_by_exif' => array( + 'image_orientation_by_exif' => array( 'label' => __( 'Change image orientation', 'ultimate-member' ), 'value' => UM()->options()->get( 'image_orientation_by_exif' ) ? $labels['yes'] : $labels['no'], ), - 'um-image_compression' => array( + 'image_compression' => array( 'label' => __( 'Image Quality', 'ultimate-member' ), 'value' => UM()->options()->get( 'image_compression' ), ), - 'um-image_max_width' => array( + 'image_max_width' => array( 'label' => __( 'Image Upload Maximum Width (px)', 'ultimate-member' ), 'value' => UM()->options()->get( 'image_max_width' ), ), - 'um-cover_min_width' => array( + 'profile_photo_max_size' => array( + 'label' => __( 'Profile Photo Maximum File Size (bytes)', 'ultimate-member' ), + 'value' => UM()->options()->get( 'profile_photo_max_size' ), + ), + 'photo_thumb_sizes' => array( + 'label' => __( 'Profile Photo Thumbnail Sizes (px)', 'ultimate-member' ), + 'value' => $profile_sizes_list, + ), + 'cover_photo_max_size' => array( + 'label' => __( 'Cover Photo Maximum File Size (bytes)', 'ultimate-member' ), + 'value' => UM()->options()->get( 'cover_photo_max_size' ), + ), + 'cover_min_width' => array( 'label' => __( 'Cover Photo Minimum Width (px)', 'ultimate-member' ), 'value' => UM()->options()->get( 'cover_min_width' ), ), + 'cover_thumb_sizes' => array( + 'label' => __( 'Cover Photo Thumbnail Sizes (px)', 'ultimate-member' ), + 'value' => $cover_sizes_list, + ), ); + return array_merge( $pages_settings, $user_settings, $account_settings, $uploads_settings ); + } + + /** + * Retrieve debug information related to access settings in Ultimate Member. + * + * @return array Debug information about access settings, including restrictions, accessible options, and other settings. + */ + public function access_settings_debug_information() { + $labels = self::get_labels(); + // Content Restriction settings $restricted_posts = UM()->options()->get( 'restricted_access_post_metabox' ); $restricted_posts_list = ''; @@ -717,7 +903,11 @@ class Site_Health { $accessible = absint( UM()->options()->get( 'accessible' ) ); $restrict_settings = array( - 'um-accessible' => array( + 'access_separator' => array( + 'label' => __( 'Access > Restriction Content', 'ultimate-member' ), + 'value' => '---------------------------------------------------------------------', + ), + 'accessible' => array( 'label' => __( 'Global Site Access', 'ultimate-member' ), 'value' => 0 === $accessible ? __( 'Site accessible to Everyone', 'ultimate-member' ) : __( 'Site accessible to Logged In Users', 'ultimate-member' ), ), @@ -729,115 +919,125 @@ class Site_Health { if ( ! empty( $exclude_uris ) ) { $exclude_uris_list = implode( ', ', $exclude_uris ); } - $restrict_settings['um-access_redirect'] = array( + $restrict_settings['access_redirect'] = array( 'label' => __( 'Custom Redirect URL', 'ultimate-member' ), 'value' => UM()->options()->get( 'access_redirect' ), ); - $restrict_settings['um-access_exclude_uris'] = array( + $restrict_settings['access_exclude_uris'] = array( 'label' => __( 'Exclude the following URLs', 'ultimate-member' ), 'value' => $exclude_uris_list, ); - $restrict_settings['um-home_page_accessible'] = array( + $restrict_settings['home_page_accessible'] = array( 'label' => __( 'Allow Homepage to be accessible', 'ultimate-member' ), 'value' => UM()->options()->get( 'home_page_accessible' ) ? $labels['yes'] : $labels['no'], ); - $restrict_settings['um-category_page_accessible'] = array( + $restrict_settings['category_page_accessible'] = array( 'label' => __( 'Allow Category pages to be accessible', 'ultimate-member' ), 'value' => UM()->options()->get( 'category_page_accessible' ) ? $labels['yes'] : $labels['no'], ); } - $restrict_settings['um-restricted_post_title_replace'] = array( - 'label' => __( 'Restricted Content Titles', 'ultimate-member' ), + $restrict_settings['restricted_post_title_replace'] = array( + 'label' => __( 'Restricted Post Title', 'ultimate-member' ), 'value' => UM()->options()->get( 'restricted_post_title_replace' ) ? $labels['yes'] : $labels['no'], ); if ( UM()->options()->get( 'restricted_post_title_replace' ) ) { - $restrict_settings['um-restricted_access_post_title'] = array( - 'label' => __( 'Restricted Content Title Text', 'ultimate-member' ), + $restrict_settings['restricted_access_post_title'] = array( + 'label' => __( 'Restricted Access Post Title', 'ultimate-member' ), 'value' => stripslashes( UM()->options()->get( 'restricted_access_post_title' ) ), ); } - $restrict_settings['um-restricted_access_message'] = array( + $restrict_settings['restricted_access_message'] = array( 'label' => __( 'Restricted Access Message', 'ultimate-member' ), 'value' => stripslashes( UM()->options()->get( 'restricted_access_message' ) ), ); - $restrict_settings['um-restricted_blocks'] = array( - 'label' => __( 'Enable the "Content Restriction" settings for the Gutenberg Blocks', 'ultimate-member' ), + $restrict_settings['restricted_blocks'] = array( + 'label' => __( 'Restricted Gutenberg Blocks (enable the "Content Restriction" settings for the Gutenberg Blocks)', 'ultimate-member' ), 'value' => UM()->options()->get( 'restricted_blocks' ) ? $labels['yes'] : $labels['no'], ); if ( UM()->options()->get( 'restricted_blocks' ) ) { - $restrict_settings['um-restricted_block_message'] = array( + $restrict_settings['restricted_block_message'] = array( 'label' => __( 'Restricted Access Block Message', 'ultimate-member' ), 'value' => stripslashes( UM()->options()->get( 'restricted_block_message' ) ), ); } - $restrict_settings['um-restricted_access_post_metabox'] = array( + $restrict_settings['restricted_access_post_metabox'] = array( 'label' => __( 'Enable the "Content Restriction" settings for post types', 'ultimate-member' ), 'value' => $restricted_posts_list, ); - $restrict_settings['um-restricted_access_taxonomy_metabox'] = array( + $restrict_settings['restricted_access_taxonomy_metabox'] = array( 'label' => __( 'Enable the "Content Restriction" settings for taxonomies', 'ultimate-member' ), 'value' => $restricted_taxonomy_list, ); // Access other settings - $blocked_emails = str_replace( '
', ', ', nl2br( UM()->options()->get( 'blocked_emails' ) ) ); - $blocked_words = str_replace( '
', ', ', nl2br( UM()->options()->get( 'blocked_words' ) ) ); - $allowed_callbacks = str_replace( '
', ', ', nl2br( UM()->options()->get( 'allowed_choice_callbacks' ) ) ); + $blocked_emails = str_replace( '
', ', ', nl2br( UM()->options()->get( 'blocked_emails' ) ) ); + $blocked_words = str_replace( '
', ', ', nl2br( UM()->options()->get( 'blocked_words' ) ) ); $access_other_settings = array( - 'um-enable_reset_password_limit' => array( + 'access_other_separator' => array( + 'label' => __( 'Access > Other', 'ultimate-member' ), + 'value' => '---------------------------------------------------------------------', + ), + 'enable_reset_password_limit' => array( 'label' => __( 'Enable the Reset Password Limit?', 'ultimate-member' ), 'value' => UM()->options()->get( 'enable_reset_password_limit' ) ? $labels['yes'] : $labels['no'], ), ); if ( UM()->options()->get( 'enable_reset_password_limit' ) ) { - $access_other_settings['um-reset_password_limit_number'] = array( - 'label' => __( 'Reset Password Limit ', 'ultimate-member' ), + $access_other_settings['reset_password_limit_number'] = array( + 'label' => __( 'Password Limit (maximum reset password limit)', 'ultimate-member' ), 'value' => UM()->options()->get( 'reset_password_limit_number' ), ); } - $access_other_settings['um-change_password_request_limit'] = array( + $access_other_settings['change_password_request_limit'] = array( 'label' => __( 'Change Password request limit ', 'ultimate-member' ), - 'value' => UM()->options()->get( 'change_password_request_limit' ), + 'value' => UM()->options()->get( 'change_password_request_limit' ) ? $labels['yes'] : $labels['no'], ); - $access_other_settings['um-only_approved_user_reset_password'] = array( + $access_other_settings['only_approved_user_reset_password'] = array( 'label' => __( 'Only approved user Reset Password', 'ultimate-member' ), - 'value' => UM()->options()->get( 'only_approved_user_reset_password' ), + 'value' => UM()->options()->get( 'only_approved_user_reset_password' ) ? $labels['yes'] : $labels['no'], ); - $access_other_settings['um-blocked_emails'] = array( + $access_other_settings['blocked_emails'] = array( 'label' => __( 'Blocked Email Addresses', 'ultimate-member' ), 'value' => stripslashes( $blocked_emails ), ); - $access_other_settings['um-blocked_words'] = array( + $access_other_settings['blocked_words'] = array( 'label' => __( 'Blacklist Words', 'ultimate-member' ), 'value' => stripslashes( $blocked_words ), ); - $access_other_settings['um-allowed_choice_callbacks'] = array( - 'label' => __( 'Allowed Choice Callbacks', 'ultimate-member' ), - 'value' => stripslashes( $allowed_callbacks ), - ); - $access_other_settings['um-allow_url_redirect_confirm'] = array( - 'label' => __( 'Allow external link redirect confirm ', 'ultimate-member' ), - 'value' => UM()->options()->get( 'allow_url_redirect_confirm' ) ? $labels['yes'] : $labels['no'], - ); + + return array_merge( $restrict_settings, $access_other_settings ); + } + + /** + * Retrieve debug information about the email settings in Ultimate Member. + * + * @return array Information about the email settings, including labels, values, and template status. + */ + public function emails_settings_debug_information() { + $labels = self::get_labels(); // Email settings $email_settings = array( - 'um-admin_email' => array( + 'email_separator' => array( + 'label' => __( 'Emails', 'ultimate-member' ), + 'value' => '---------------------------------------------------------------------', + ), + 'admin_email' => array( 'label' => __( 'Admin Email Address', 'ultimate-member' ), 'value' => UM()->options()->get( 'admin_email' ), ), - 'um-mail_from' => array( + 'mail_from' => array( 'label' => __( 'Mail appears from', 'ultimate-member' ), 'value' => UM()->options()->get( 'mail_from' ), ), - 'um-mail_from_addr' => array( + 'mail_from_addr' => array( 'label' => __( 'Mail appears from address', 'ultimate-member' ), 'value' => UM()->options()->get( 'mail_from_addr' ), ), - 'um-email_html' => array( + 'email_html' => array( 'label' => __( 'Use HTML for Emails?', 'ultimate-member' ), 'value' => UM()->options()->get( 'email_html' ) ? $labels['yes'] : $labels['no'], ), @@ -845,14 +1045,20 @@ class Site_Health { $emails = UM()->config()->email_notifications; foreach ( $emails as $key => $email ) { + $email_settings[ $key . '-enabled' ] = array( + // translators: %s is email template title. + 'label' => sprintf( __( 'Email "%s" Enabled', 'ultimate-member' ), $email['title'] ), + 'value' => UM()->options()->get( $key . '_on' ) ? $labels['yes'] : $labels['no'], + ); + if ( UM()->options()->get( $key . '_on' ) ) { - $email_settings[ 'um-' . $key ] = array( + $email_settings[ $key . '-subject' ] = array( // translators: %s is email template title. 'label' => sprintf( __( '"%s" Subject', 'ultimate-member' ), $email['title'] ), 'value' => UM()->options()->get( $key . '_sub' ), ); - $email_settings[ 'um-theme_' . $key ] = array( + $email_settings[ $key . '-in-theme' ] = array( // translators: %s is email template title. 'label' => sprintf( __( 'Template "%s" in theme?', 'ultimate-member' ), $email['title'] ), 'value' => '' !== locate_template( array( 'ultimate-member/emails/' . $key . '.php' ) ) ? $labels['yes'] : $labels['no'], @@ -860,7 +1066,17 @@ class Site_Health { } } - // Appearance settings. + return $email_settings; + } + + /** + * Retrieve debug information related to appearance settings in Ultimate Member. + * + * @return array Debug information about appearance settings, including profile template, profile photo settings, cover photo settings, and more. + */ + public function appearance_settings_debug_information() { + $labels = self::get_labels(); + // > Profile section. $icons_display_options = array( 'field' => __( 'Show inside text field', 'ultimate-member' ), @@ -878,108 +1094,134 @@ class Site_Health { $profile_secondary_btn = UM()->options()->get( 'profile_secondary_btn' ); $profile_cover_enabled = UM()->options()->get( 'profile_cover_enabled' ); $profile_empty_text = UM()->options()->get( 'profile_empty_text' ); + $default_avatar = UM()->options()->get( 'default_avatar' ); + $default_cover = UM()->options()->get( 'default_cover' ); $appearance_settings = array( - 'um-profile_template' => array( + 'appearance_separator' => array( + 'label' => __( 'Appearance > Profile', 'ultimate-member' ), + 'value' => '---------------------------------------------------------------------', + ), + 'profile_template' => array( 'label' => __( 'Profile Default Template', 'ultimate-member' ), // translators: %1$s - profile template name, %2$s - profile template filename 'value' => sprintf( __( '%1$s (filename: %2$s.php)', 'ultimate-member' ), $profile_template_title, $profile_template_key ), ), - 'um-profile_max_width' => array( + 'profile_max_width' => array( 'label' => __( 'Profile Maximum Width', 'ultimate-member' ), 'value' => UM()->options()->get( 'profile_max_width' ), ), - 'um-profile_area_max_width' => array( + 'profile_area_max_width' => array( 'label' => __( 'Profile Area Maximum Width', 'ultimate-member' ), 'value' => UM()->options()->get( 'profile_area_max_width' ), ), - 'um-profile_icons' => array( - 'label' => __( 'Profile Field Icons', 'ultimate-member' ), - 'value' => $icons_display_options[ UM()->options()->get( 'profile_icons' ) ], + 'default_avatar' => array( + 'label' => __( 'Default Profile Photo', 'ultimate-member' ), + 'value' => ! empty( $default_avatar['url'] ) ? $default_avatar['url'] : '', ), - 'um-profile_primary_btn_word' => array( - 'label' => __( 'Profile Primary Button Text', 'ultimate-member' ), - 'value' => UM()->options()->get( 'profile_primary_btn_word' ), + 'disable_profile_photo_upload' => array( + 'label' => __( 'Disable Profile Photo Upload', 'ultimate-member' ), + 'value' => UM()->options()->get( 'disable_profile_photo_upload' ) ? $labels['yes'] : $labels['no'], ), - 'um-profile_secondary_btn' => array( - 'label' => __( 'Profile Secondary Button', 'ultimate-member' ), - 'value' => $profile_secondary_btn ? $labels['yes'] : $labels['no'], + 'profile_photosize' => array( + 'label' => __( 'Profile Photo Size', 'ultimate-member' ), + 'value' => UM()->options()->get( 'profile_photosize' ) . 'x' . UM()->options()->get( 'profile_photosize' ) . 'px', + ), + 'default_cover' => array( + 'label' => __( 'Default Cover Photo', 'ultimate-member' ), + 'value' => ! empty( $default_cover['url'] ) ? $default_cover['url'] : '', + ), + 'profile_cover_enabled' => array( + 'label' => __( 'Profile Cover Photos', 'ultimate-member' ), + 'value' => $profile_cover_enabled ? $labels['yes'] : $labels['no'], ), ); + + if ( ! empty( $profile_cover_enabled ) ) { + $appearance_settings['profile_coversize'] = array( + 'label' => __( 'Profile Cover Size', 'ultimate-member' ), + 'value' => UM()->options()->get( 'profile_coversize' ) . 'px', + ); + $appearance_settings['profile_cover_ratio'] = array( + 'label' => __( 'Profile Cover Ratio', 'ultimate-member' ), + 'value' => UM()->options()->get( 'profile_cover_ratio' ), + ); + } + + $appearance_settings = array_merge( + $appearance_settings, + array( + 'profile_show_metaicon' => array( + 'label' => __( 'Profile Header Meta Text Icon', 'ultimate-member' ), + 'value' => UM()->options()->get( 'profile_show_metaicon' ) ? $labels['yes'] : $labels['no'], + ), + 'profile_show_name' => array( + 'label' => __( 'Show display name in profile header', 'ultimate-member' ), + 'value' => UM()->options()->get( 'profile_show_name' ) ? $labels['yes'] : $labels['no'], + ), + 'profile_show_social_links' => array( + 'label' => __( 'Show social links in profile header', 'ultimate-member' ), + 'value' => UM()->options()->get( 'profile_show_social_links' ) ? $labels['yes'] : $labels['no'], + ), + 'profile_show_bio' => array( + 'label' => __( 'Show user description in profile header', 'ultimate-member' ), + 'value' => UM()->options()->get( 'profile_show_bio' ) ? $labels['yes'] : $labels['no'], + ), + ) + ); + + if ( UM()->options()->get( 'profile_show_bio' ) ) { + $appearance_settings['profile_bio_maxchars'] = array( + 'label' => __( 'User description maximum chars', 'ultimate-member' ), + 'value' => UM()->options()->get( 'profile_bio_maxchars' ), + ); + } + + $appearance_settings = array_merge( + $appearance_settings, + array( + 'profile_show_html_bio' => array( + 'label' => __( 'Enable HTML support for user description', 'ultimate-member' ), + 'value' => UM()->options()->get( 'profile_show_html_bio' ) ? $labels['yes'] : $labels['no'], + ), + 'profile_header_menu' => array( + 'label' => __( 'Profile Header Menu Position', 'ultimate-member' ), + 'value' => $profile_header_menu_options[ UM()->options()->get( 'profile_header_menu' ) ], + ), + 'profile_primary_btn_word' => array( + 'label' => __( 'Profile Primary Button Text', 'ultimate-member' ), + 'value' => UM()->options()->get( 'profile_primary_btn_word' ), + ), + 'profile_secondary_btn' => array( + 'label' => __( 'Profile Secondary Button', 'ultimate-member' ), + 'value' => $profile_secondary_btn ? $labels['yes'] : $labels['no'], + ), + ) + ); + if ( ! empty( $profile_secondary_btn ) ) { - $appearance_settings['um-profile_secondary_btn_word'] = array( + $appearance_settings['profile_secondary_btn_word'] = array( 'label' => __( 'Profile Secondary Button Text ', 'ultimate-member' ), 'value' => UM()->options()->get( 'profile_secondary_btn_word' ), ); } - $default_avatar = UM()->options()->get( 'default_avatar' ); - $default_cover = UM()->options()->get( 'default_cover' ); + $appearance_settings = array_merge( + $appearance_settings, + array( + 'profile_icons' => array( + 'label' => __( 'Profile Field Icons', 'ultimate-member' ), + 'value' => $icons_display_options[ UM()->options()->get( 'profile_icons' ) ], + ), + 'profile_empty_text' => array( + 'label' => __( 'Show a custom message if profile is empty', 'ultimate-member' ), + 'value' => $profile_empty_text ? $labels['yes'] : $labels['no'], + ), + ) + ); - $appearance_settings['um-default_avatar'] = array( - 'label' => __( 'Default Profile Photo', 'ultimate-member' ), - 'value' => ! empty( $default_avatar['url'] ) ? $default_avatar['url'] : '', - ); - $appearance_settings['um-default_cover'] = array( - 'label' => __( 'Default Cover Photo', 'ultimate-member' ), - 'value' => ! empty( $default_cover['url'] ) ? $default_cover['url'] : '', - ); - $appearance_settings['um-disable_profile_photo_upload'] = array( - 'label' => __( 'Disable Profile Photo Upload', 'ultimate-member' ), - 'value' => UM()->options()->get( 'disable_profile_photo_upload' ) ? $labels['yes'] : $labels['no'], - ); - $appearance_settings['um-profile_photosize'] = array( - 'label' => __( 'Profile Photo Size', 'ultimate-member' ), - 'value' => UM()->options()->get( 'profile_photosize' ) . 'x' . UM()->options()->get( 'profile_photosize' ) . 'px', - ); - $appearance_settings['um-profile_cover_enabled'] = array( - 'label' => __( 'Profile Cover Photos', 'ultimate-member' ), - 'value' => $profile_cover_enabled ? $labels['yes'] : $labels['no'], - ); - if ( ! empty( $profile_cover_enabled ) ) { - $appearance_settings['um-profile_coversize'] = array( - 'label' => __( 'Profile Cover Size', 'ultimate-member' ), - 'value' => UM()->options()->get( 'profile_coversize' ) . 'px', - ); - $appearance_settings['um-profile_cover_ratio'] = array( - 'label' => __( 'Profile Cover Ratio', 'ultimate-member' ), - 'value' => UM()->options()->get( 'profile_cover_ratio' ), - ); - } - $appearance_settings['um-profile_show_metaicon'] = array( - 'label' => __( 'Profile Header Meta Text Icon', 'ultimate-member' ), - 'value' => UM()->options()->get( 'profile_show_metaicon' ) ? $labels['yes'] : $labels['no'], - ); - $appearance_settings['um-profile_show_name'] = array( - 'label' => __( 'Show display name in profile header', 'ultimate-member' ), - 'value' => UM()->options()->get( 'profile_show_name' ) ? $labels['yes'] : $labels['no'], - ); - $appearance_settings['um-profile_show_social_links'] = array( - 'label' => __( 'Show social links in profile header', 'ultimate-member' ), - 'value' => UM()->options()->get( 'profile_show_social_links' ) ? $labels['yes'] : $labels['no'], - ); - $appearance_settings['um-profile_show_bio'] = array( - 'label' => __( 'Show user description in header', 'ultimate-member' ), - 'value' => UM()->options()->get( 'profile_show_bio' ) ? $labels['yes'] : $labels['no'], - ); - $appearance_settings['um-profile_show_html_bio'] = array( - 'label' => __( 'Enable HTML support for user description', 'ultimate-member' ), - 'value' => UM()->options()->get( 'profile_show_html_bio' ) ? $labels['yes'] : $labels['no'], - ); - $appearance_settings['um-profile_bio_maxchars'] = array( - 'label' => __( 'User description maximum chars', 'ultimate-member' ), - 'value' => UM()->options()->get( 'profile_bio_maxchars' ), - ); - $appearance_settings['um-profile_header_menu'] = array( - 'label' => __( 'Profile Header Menu Position', 'ultimate-member' ), - 'value' => $profile_header_menu_options[ UM()->options()->get( 'profile_header_menu' ) ], - ); - $appearance_settings['um-profile_empty_text'] = array( - 'label' => __( 'Show a custom message if profile is empty', 'ultimate-member' ), - 'value' => $profile_empty_text ? $labels['yes'] : $labels['no'], - ); if ( ! empty( $profile_empty_text ) ) { - $appearance_settings['um-profile_empty_text_emo'] = array( + $appearance_settings['profile_empty_text_emo'] = array( 'label' => __( 'Show the emoticon', 'ultimate-member' ), 'value' => UM()->options()->get( 'profile_empty_text_emo' ) ? $labels['yes'] : $labels['no'], ); @@ -988,29 +1230,17 @@ class Site_Health { // > Profile Menu section. $profile_menu = UM()->options()->get( 'profile_menu' ); - $appearance_settings['um-profile_menu'] = array( + $appearance_settings['appearance_profile_menu_separator'] = array( + 'label' => __( 'Appearance > Profile Menu', 'ultimate-member' ), + 'value' => '---------------------------------------------------------------------', + ); + + $appearance_settings['profile_menu'] = array( 'label' => __( 'Enable profile menu', 'ultimate-member' ), 'value' => $profile_menu ? $labels['yes'] : $labels['no'], ); if ( ! empty( $profile_menu ) ) { - /** - * Filters a privacy list extend. - * - * @since 2.7.0 - * @hook um_profile_tabs_privacy_list - * - * @param {array} $privacy_option Add options for profile tabs' privacy. - * - * @return {array} Options for profile tabs' privacy. - * - * @example Add options for profile tabs' privacy. - * function um_profile_menu_link_attrs( $privacy_option ) { - * // your code here - * return $privacy_option; - * } - * add_filter( 'um_profile_tabs_privacy_list', 'um_profile_tabs_privacy_list', 10, 1 ); - */ $privacy_option = UM()->profile()->tabs_privacy(); $tabs = UM()->profile()->tabs(); @@ -1021,7 +1251,7 @@ class Site_Health { $tab_enabled = UM()->options()->get( 'profile_tab_' . $id ); - $appearance_settings[ 'um-profile_tab_' . $id ] = array( + $appearance_settings[ 'profile_tab_' . $id ] = array( // translators: %s Profile Tab Title 'label' => sprintf( __( '%s Tab', 'ultimate-member' ), $tab['name'] ), 'value' => $tab_enabled ? $labels['yes'] : $labels['no'], @@ -1030,7 +1260,7 @@ class Site_Health { if ( ! isset( $tab['default_privacy'] ) && ! empty( $tab_enabled ) ) { $privacy = UM()->options()->get( 'profile_tab_' . $id . '_privacy' ); if ( is_numeric( $privacy ) ) { - $appearance_settings[ 'um-profile_tab_' . $id . '_privacy' ] = array( + $appearance_settings[ 'profile_tab_' . $id . '_privacy' ] = array( // translators: %s Profile Tab Title 'label' => sprintf( __( 'Who can see %s Tab?', 'ultimate-member' ), $tab['name'] ), 'value' => $privacy_option[ UM()->options()->get( 'profile_tab_' . $id . '_privacy' ) ], @@ -1057,46 +1287,11 @@ class Site_Health { */ $appearance_settings = apply_filters( 'um_profile_tabs_site_health', $appearance_settings ); - /** - * Filters user profile tabs - * - * @since 2.7.0 - * @hook um_profile_tabs - * - * @param {array} $tabs tabs list. - * - * @return {array} tabs list. - * - * @example Add options for profile tabs' privacy. - * function um_profile_tabs( $tabs ) { - * // your code here - * return $tabs; - * } - * add_filter( 'um_profile_tabs', 'um_profile_tabs', 10, 1 ); - */ - $tabs_options = apply_filters( - 'um_profile_tabs', - array( - 'main' => array( - 'name' => __( 'About', 'ultimate-member' ), - 'icon' => 'um-faicon-user', - ), - 'posts' => array( - 'name' => __( 'Posts', 'ultimate-member' ), - 'icon' => 'um-faicon-pencil', - ), - 'comments' => array( - 'name' => __( 'Comments', 'ultimate-member' ), - 'icon' => 'um-faicon-comment', - ), - ) - ); - - $appearance_settings['um-profile_menu_default_tab'] = array( + $appearance_settings['profile_menu_default_tab'] = array( 'label' => __( 'Profile menu default tab', 'ultimate-member' ), - 'value' => $tabs_options[ UM()->options()->get( 'profile_menu_default_tab' ) ], + 'value' => isset( $tabs[ UM()->options()->get( 'profile_menu_default_tab' ) ]['name'] ) ? $tabs[ UM()->options()->get( 'profile_menu_default_tab' ) ]['name'] : '', ); - $appearance_settings['um-profile_menu_icons'] = array( + $appearance_settings['profile_menu_icons'] = array( 'label' => __( 'Enable menu icons in desktop view', 'ultimate-member' ), 'value' => UM()->options()->get( 'profile_menu_icons' ) ? $labels['yes'] : $labels['no'], ); @@ -1114,44 +1309,51 @@ class Site_Health { 'right' => __( 'Right aligned', 'ultimate-member' ), ); - $appearance_settings['um-register_template'] = array( - 'label' => __( 'Registration Default Template', 'ultimate-member' ), - // translators: %1$s - register template name, %2$s - register template filename - 'value' => sprintf( __( '%1$s (filename: %2$s.php)', 'ultimate-member' ), $register_template_title, $register_template_key ), - ); - $appearance_settings['um-register_max_width'] = array( - 'label' => __( 'Registration Maximum Width', 'ultimate-member' ), - 'value' => UM()->options()->get( 'register_max_width' ), - ); - $appearance_settings['um-register_align'] = array( - 'label' => __( 'Registration Shortcode Alignment', 'ultimate-member' ), - 'value' => $form_align_options[ UM()->options()->get( 'register_align' ) ], - ); - $appearance_settings['um-register_icons'] = array( - 'label' => __( 'Registration Field Icons', 'ultimate-member' ), - 'value' => $icons_display_options[ UM()->options()->get( 'register_icons' ) ], - ); - $appearance_settings['um-register_primary_btn_word'] = array( - 'label' => __( 'Registration Primary Button Text ', 'ultimate-member' ), - 'value' => UM()->options()->get( 'register_primary_btn_word' ), - ); - $appearance_settings['um-register_secondary_btn'] = array( - 'label' => __( 'Registration Secondary Button', 'ultimate-member' ), - 'value' => $register_secondary_btn ? $labels['yes'] : $labels['no'], + $appearance_settings = array_merge( + $appearance_settings, + array( + 'appearance_register_separator' => array( + 'label' => __( 'Appearance > Registration Form', 'ultimate-member' ), + 'value' => '---------------------------------------------------------------------', + ), + 'register_template' => array( + 'label' => __( 'Registration Default Template', 'ultimate-member' ), + // translators: %1$s - register template name, %2$s - register template filename + 'value' => sprintf( __( '%1$s (filename: %2$s.php)', 'ultimate-member' ), $register_template_title, $register_template_key ), + ), + 'register_max_width' => array( + 'label' => __( 'Registration Maximum Width', 'ultimate-member' ), + 'value' => UM()->options()->get( 'register_max_width' ), + ), + 'register_align' => array( + 'label' => __( 'Registration Shortcode Alignment', 'ultimate-member' ), + 'value' => $form_align_options[ UM()->options()->get( 'register_align' ) ], + ), + 'register_primary_btn_word' => array( + 'label' => __( 'Registration Primary Button Text ', 'ultimate-member' ), + 'value' => UM()->options()->get( 'register_primary_btn_word' ), + ), + 'register_secondary_btn' => array( + 'label' => __( 'Registration Secondary Button', 'ultimate-member' ), + 'value' => $register_secondary_btn ? $labels['yes'] : $labels['no'], + ), + ) ); + if ( ! empty( $register_secondary_btn ) ) { - $appearance_settings['um-register_secondary_btn_word'] = array( + $appearance_settings['register_secondary_btn_word'] = array( 'label' => __( 'Registration Secondary Button Text', 'ultimate-member' ), 'value' => UM()->options()->get( 'register_secondary_btn_word' ), ); - $appearance_settings['um-register_secondary_btn_url'] = array( + $appearance_settings['register_secondary_btn_url'] = array( 'label' => __( 'Registration Secondary Button URL', 'ultimate-member' ), 'value' => UM()->options()->get( 'register_secondary_btn_url' ), ); } - $appearance_settings['um-register_role'] = array( - 'label' => __( 'Registration Default Role', 'ultimate-member' ), - 'value' => ! empty( UM()->options()->get( 'register_role' ) ) ? UM()->options()->get( 'register_role' ) : __( 'Default', 'ultimate-member' ), + + $appearance_settings['register_icons'] = array( + 'label' => __( 'Registration Field Icons', 'ultimate-member' ), + 'value' => $icons_display_options[ UM()->options()->get( 'register_icons' ) ], ); // > Login Form section. @@ -1160,91 +1362,116 @@ class Site_Health { $login_template_title = array_key_exists( $login_template_key, $login_templates ) ? $login_templates[ $login_template_key ] : __( 'No template name', 'ultimate-member' ); $login_secondary_btn = UM()->options()->get( 'login_secondary_btn' ); - $appearance_settings['um-login_template'] = array( - 'label' => __( 'Login Default Template', 'ultimate-member' ), - // translators: %1$s - login template name, %2$s - login template filename - 'value' => sprintf( __( '%1$s (filename: %2$s.php)', 'ultimate-member' ), $login_template_title, $login_template_key ), - ); - $appearance_settings['um-login_max_width'] = array( - 'label' => __( 'Login Maximum Width', 'ultimate-member' ), - 'value' => UM()->options()->get( 'login_max_width' ), - ); - $appearance_settings['um-login_align'] = array( - 'label' => __( 'Login Shortcode Alignment', 'ultimate-member' ), - 'value' => $form_align_options[ UM()->options()->get( 'login_align' ) ], - ); - $appearance_settings['um-login_icons'] = array( - 'label' => __( 'Login Field Icons', 'ultimate-member' ), - 'value' => $icons_display_options[ UM()->options()->get( 'login_icons' ) ], - ); - $appearance_settings['um-login_primary_btn_word'] = array( - 'label' => __( 'Login Primary Button Text', 'ultimate-member' ), - 'value' => UM()->options()->get( 'login_primary_btn_word' ), - ); - $appearance_settings['um-login_secondary_btn'] = array( - 'label' => __( 'Login Secondary Button', 'ultimate-member' ), - 'value' => $login_secondary_btn ? $labels['yes'] : $labels['no'], + $appearance_settings = array_merge( + $appearance_settings, + array( + 'appearance_login_separator' => array( + 'label' => __( 'Appearance > Login Form', 'ultimate-member' ), + 'value' => '---------------------------------------------------------------------', + ), + 'login_template' => array( + 'label' => __( 'Login Default Template', 'ultimate-member' ), + // translators: %1$s - login template name, %2$s - login template filename + 'value' => sprintf( __( '%1$s (filename: %2$s.php)', 'ultimate-member' ), $login_template_title, $login_template_key ), + ), + 'login_max_width' => array( + 'label' => __( 'Login Maximum Width', 'ultimate-member' ), + 'value' => UM()->options()->get( 'login_max_width' ), + ), + 'login_align' => array( + 'label' => __( 'Login Shortcode Alignment', 'ultimate-member' ), + 'value' => $form_align_options[ UM()->options()->get( 'login_align' ) ], + ), + 'login_primary_btn_word' => array( + 'label' => __( 'Login Primary Button Text', 'ultimate-member' ), + 'value' => UM()->options()->get( 'login_primary_btn_word' ), + ), + 'login_secondary_btn' => array( + 'label' => __( 'Login Secondary Button', 'ultimate-member' ), + 'value' => $login_secondary_btn ? $labels['yes'] : $labels['no'], + ), + ) ); + if ( ! empty( $login_secondary_btn ) ) { - $appearance_settings['um-login_secondary_btn_word'] = array( + $appearance_settings['login_secondary_btn_word'] = array( 'label' => __( 'Login Secondary Button Text', 'ultimate-member' ), 'value' => UM()->options()->get( 'login_secondary_btn_word' ), ); - $appearance_settings['um-login_secondary_btn_url'] = array( + $appearance_settings['login_secondary_btn_url'] = array( 'label' => __( 'Login Secondary Button URL', 'ultimate-member' ), 'value' => UM()->options()->get( 'login_secondary_btn_url' ), ); } - $appearance_settings['um-login_forgot_pass_link'] = array( - 'label' => __( 'Login Forgot Password Link', 'ultimate-member' ), - 'value' => UM()->options()->get( 'login_forgot_pass_link' ) ? $labels['yes'] : $labels['no'], - ); - $appearance_settings['um-login_show_rememberme'] = array( - 'label' => __( 'Show "Remember Me"', 'ultimate-member' ), - 'value' => UM()->options()->get( 'login_show_rememberme' ) ? $labels['yes'] : $labels['no'], + + $appearance_settings = array_merge( + $appearance_settings, + array( + 'login_forgot_pass_link' => array( + 'label' => __( 'Login Forgot Password Link', 'ultimate-member' ), + 'value' => UM()->options()->get( 'login_forgot_pass_link' ) ? $labels['yes'] : $labels['no'], + ), + 'login_show_rememberme' => array( + 'label' => __( 'Show "Remember Me" checkbox', 'ultimate-member' ), + 'value' => UM()->options()->get( 'login_show_rememberme' ), + ), + 'login_icons' => array( + 'label' => __( 'Login Field Icons', 'ultimate-member' ), + 'value' => $icons_display_options[ UM()->options()->get( 'login_icons' ) ], + ), + ) ); - // Misc settings. - $misc_settings = array( - 'um-form_asterisk' => array( - 'label' => __( 'Show an asterisk for required fields', 'ultimate-member' ), + return $appearance_settings; + } + + /** + * Retrieve advanced settings debug information for Ultimate Member. + * + * @return array An array containing detailed information about various advanced settings, including labels and values. + */ + public function advanced_settings_debug_information() { + $labels = self::get_labels(); + + $general = array( + 'advanced_separator' => array( + 'label' => __( 'Advanced > General', 'ultimate-member' ), + 'value' => '---------------------------------------------------------------------', + ), + 'form_asterisk' => array( + 'label' => __( 'Required fields\' asterisk (Show an asterisk for required fields)', 'ultimate-member' ), 'value' => UM()->options()->get( 'form_asterisk' ) ? $labels['yes'] : $labels['no'], ), - 'um-profile_title' => array( - 'label' => __( 'User Profile Title', 'ultimate-member' ), - 'value' => stripslashes( UM()->options()->get( 'profile_title' ) ), - ), - 'um-profile_desc' => array( - 'label' => __( 'User Profile Dynamic Meta Description', 'ultimate-member' ), - 'value' => stripslashes( UM()->options()->get( 'profile_desc' ) ), - ), - 'um-um_profile_object_cache_stop' => array( + 'profile_object_cache_stop' => array( 'label' => __( 'Disable Cache User Profile', 'ultimate-member' ), 'value' => UM()->options()->get( 'um_profile_object_cache_stop' ) ? $labels['yes'] : $labels['no'], ), - 'um-enable_blocks' => array( + 'uninstall_on_delete' => array( + 'label' => __( 'Remove Data on Uninstall?', 'ultimate-member' ), + 'value' => UM()->options()->get( 'uninstall_on_delete' ) ? $labels['yes'] : $labels['no'], + ), + ); + + $feature = array( + 'advanced_features_separator' => array( + 'label' => __( 'Advanced > Features', 'ultimate-member' ), + 'value' => '---------------------------------------------------------------------', + ), + 'enable_blocks' => array( 'label' => __( 'Enable Gutenberg Blocks', 'ultimate-member' ), 'value' => UM()->options()->get( 'enable_blocks' ) ? $labels['yes'] : $labels['no'], ), - 'um-enable_as_email_sending' => array( - 'label' => __( 'Email sending by Action Scheduler', 'ultimate-member' ), - 'value' => UM()->options()->get( 'enable_as_email_sending' ) ? $labels['yes'] : $labels['no'], - ), - 'um-rest_api_version' => array( - 'label' => __( 'REST API version', 'ultimate-member' ), - 'value' => UM()->options()->get( 'rest_api_version' ), - ), - 'um-disable_restriction_pre_queries' => array( - 'label' => __( 'Disable pre-queries for restriction content logic (advanced)', 'ultimate-member' ), - 'value' => UM()->options()->get( 'disable_restriction_pre_queries' ) ? $labels['yes'] : $labels['no'], - ), - 'um-member_directory_own_table' => array( + 'member_directory_own_table' => array( 'label' => __( 'Enable custom table for usermeta', 'ultimate-member' ), 'value' => UM()->options()->get( 'member_directory_own_table' ) ? $labels['yes'] : $labels['no'], ), - 'um-uninstall_on_delete' => array( - 'label' => __( 'Remove Data on Uninstall?', 'ultimate-member' ), - 'value' => UM()->options()->get( 'uninstall_on_delete' ) ? $labels['yes'] : $labels['no'], + 'enable_as_email_sending' => array( + 'label' => __( 'Email sending by Action Scheduler', 'ultimate-member' ), + 'value' => UM()->options()->get( 'enable_as_email_sending' ) ? $labels['yes'] : $labels['no'], + ), + 'disable_restriction_pre_queries' => array( + 'label' => __( 'Disable pre-queries for restriction content logic (advanced)', 'ultimate-member' ), + 'value' => UM()->options()->get( 'disable_restriction_pre_queries' ) ? $labels['yes'] : $labels['no'], ), ); @@ -1262,27 +1489,31 @@ class Site_Health { } $secure_settings = array( - 'um-banned_capabilities' => array( + 'advanced_security_separator' => array( + 'label' => __( 'Advanced > Security', 'ultimate-member' ), + 'value' => '---------------------------------------------------------------------', + ), + 'banned_capabilities' => array( 'label' => __( 'Banned Administrative Capabilities', 'ultimate-member' ), 'value' => ! empty( $banned_capabilities ) ? implode( ', ', $banned_capabilities ) : '', ), - 'um-lock_register_forms' => array( + 'lock_register_forms' => array( 'label' => __( 'Lock All Register Forms', 'ultimate-member' ), 'value' => UM()->options()->get( 'lock_register_forms' ) ? $labels['yes'] : $labels['no'], ), - 'um-display_login_form_notice' => array( + 'display_login_form_notice' => array( 'label' => __( 'Display Login form notice to reset passwords', 'ultimate-member' ), 'value' => UM()->options()->get( 'display_login_form_notice' ) ? $labels['yes'] : $labels['no'], ), - 'um-secure_ban_admins_accounts' => array( - 'label' => __( 'Enable ban for administrative capabilities', 'ultimate-member' ), + 'secure_ban_admins_accounts' => array( + 'label' => __( 'Administrative capabilities ban (enable ban for administrative capabilities)', 'ultimate-member' ), 'value' => $secure_ban_admins_accounts ? $labels['yes'] : $labels['no'], ), ); if ( ! empty( $secure_ban_admins_accounts ) ) { $secure_notify_admins_banned_accounts = UM()->options()->get( 'secure_notify_admins_banned_accounts' ); - $secure_settings['um-secure_notify_admins_banned_accounts'] = array( + $secure_settings['secure_notify_admins_banned_accounts'] = array( 'label' => __( 'Notify Administrators', 'ultimate-member' ), 'value' => $secure_notify_admins_banned_accounts ? $labels['yes'] : $labels['no'], ); @@ -1293,7 +1524,7 @@ class Site_Health { 'daily' => __( 'Daily', 'ultimate-member' ), ); - $secure_settings['um-secure_notify_admins_banned_accounts__interval'] = array( + $secure_settings['secure_notify_admins_banned_accounts__interval'] = array( 'label' => __( 'Notification Schedule', 'ultimate-member' ), 'value' => $secure_notify_admins_banned_accounts_options[ UM()->options()->get( 'secure_notify_admins_banned_accounts__interval' ) ], ); @@ -1303,14 +1534,42 @@ class Site_Health { $secure_allowed_redirect_hosts = UM()->options()->get( 'secure_allowed_redirect_hosts' ); $secure_allowed_redirect_hosts = explode( PHP_EOL, $secure_allowed_redirect_hosts ); - $secure_settings['um-secure_allowed_redirect_hosts'] = array( + $secure_settings['secure_allowed_redirect_hosts'] = array( 'label' => __( 'Allowed hosts for safe redirect', 'ultimate-member' ), 'value' => $secure_allowed_redirect_hosts, ); + $developers = array( + 'advanced_developers_separator' => array( + 'label' => __( 'Advanced > Developers', 'ultimate-member' ), + 'value' => '---------------------------------------------------------------------', + ), + 'allowed_choice_callbacks' => array( + 'label' => __( 'Allowed Choice Callbacks', 'ultimate-member' ), + 'value' => UM()->options()->get( 'allowed_choice_callbacks' ), + ), + 'rest_api_version' => array( + 'label' => __( 'REST API version', 'ultimate-member' ), + 'value' => UM()->options()->get( 'rest_api_version' ), + ), + 'allow_url_redirect_confirm' => array( + 'label' => __( 'Allow external link redirect confirm (enable JS.confirm for external links)', 'ultimate-member' ), + 'value' => UM()->options()->get( 'allow_url_redirect_confirm' ) ? $labels['yes'] : $labels['no'], + ), + ); + + return array_merge( $general, $feature, $secure_settings, $developers ); + } + + /** + * Retrieve license settings debug information for Ultimate Member. + * + * @return array License settings for Site Health, including label and value. + */ + public function license_settings_debug_information() { // Licenses settings. $license_settings = array( - 'um-licenses' => array( + 'licenses' => array( 'label' => __( 'Licenses', 'ultimate-member' ), 'value' => array(), ), @@ -1333,17 +1592,28 @@ class Site_Health { * } * add_filter( 'um_licenses_site_health', 'um_licenses_site_health', 10, 1 ); */ - $license_settings = apply_filters( 'um_licenses_site_health', $license_settings ); + return apply_filters( 'um_licenses_site_health', $license_settings ); + } - $info['ultimate-member']['fields'] = array_merge( $info['ultimate-member']['fields'], $pages_settings, $user_settings, $account_settings, $uploads_settings, $restrict_settings, $access_other_settings, $email_settings, $appearance_settings, $misc_settings, $secure_settings, $license_settings ); + /** + * Retrieve information about roles and role settings in the site health check. + * + * @param array $info The existing site health information array. + * + * @return array Updated site health information including user roles and their settings. + */ + public function roles_debug_information( $info ) { + $labels = self::get_labels(); + + $all_roles = UM()->roles()->get_roles(); // User roles settings $roles_array = array(); - foreach ( $this->get_roles() as $key => $role ) { - if ( strpos( $key, 'um_' ) === 0 ) { - $key = substr( $key, 3 ); + foreach ( $all_roles as $slug => $role ) { + if ( strpos( $slug, 'um_' ) === 0 ) { + $slug = substr( $slug, 3 ); } - $rolemeta = $this->get_role_meta( $key ); + $rolemeta = $this->get_role_meta( $slug ); if ( false === $rolemeta ) { continue; } @@ -1356,69 +1626,56 @@ class Site_Health { } $info['ultimate-member-user-roles'] = array( - 'label' => __( 'User roles', 'ultimate-member' ), + 'label' => __( 'Ultimate Member User Roles', 'ultimate-member' ), 'description' => __( 'This debug information about user roles.', 'ultimate-member' ), 'fields' => array( - 'um-roles' => array( + 'roles' => array( 'label' => __( 'User Roles (priority)', 'ultimate-member' ), 'value' => implode( ', ', $roles_array ), ), - 'um-register_role' => array( + 'register_role' => array( 'label' => __( 'WordPress Default New User Role', 'ultimate-member' ), - 'value' => get_option( 'default_role' ), + 'value' => $all_roles[ get_option( 'default_role' ) ], ), ), ); - foreach ( $this->get_roles() as $key => $role ) { - if ( strpos( $key, 'um_' ) === 0 ) { - $key = substr( $key, 3 ); + foreach ( $all_roles as $slug => $role ) { + if ( strpos( $slug, 'um_' ) === 0 ) { + $slug = substr( $slug, 3 ); } - $rolemeta = $this->get_role_meta( $key ); + $rolemeta = $this->get_role_meta( $slug ); if ( false === $rolemeta ) { continue; } - $info[ 'ultimate-member-' . $key ] = array( - 'label' => ' - ' . $role . __( ' role settings', 'ultimate-member' ), - 'description' => __( 'This debug information about user role.', 'ultimate-member' ), - 'fields' => array(), - ); + $debug_info = array(); if ( array_key_exists( '_um_can_access_wpadmin', $rolemeta ) ) { - $info[ 'ultimate-member-' . $key ]['fields'] = array_merge( - $info[ 'ultimate-member-' . $key ]['fields'], - array( - 'um-can_access_wpadmin' => array( - 'label' => __( 'Can access wp-admin?', 'ultimate-member' ), - 'value' => $rolemeta['_um_can_access_wpadmin'] ? $labels['yes'] : $labels['no'], - ), - ) + $debug_info[] = array( + 'can_access_wpadmin' => array( + 'label' => __( 'Can access wp-admin?', 'ultimate-member' ), + 'value' => $rolemeta['_um_can_access_wpadmin'] ? $labels['yes'] : $labels['no'], + ), ); } if ( array_key_exists( '_um_can_not_see_adminbar', $rolemeta ) ) { - $info[ 'ultimate-member-' . $key ]['fields'] = array_merge( - $info[ 'ultimate-member-' . $key ]['fields'], - array( - 'um-can_not_see_adminbar' => array( - 'label' => __( 'Force hiding adminbar in frontend?', 'ultimate-member' ), - 'value' => $rolemeta['_um_can_not_see_adminbar'] ? $labels['yes'] : $labels['no'], - ), - ) + $debug_info[] = array( + 'can_not_see_adminbar' => array( + 'label' => __( 'Force hiding adminbar in frontend?', 'ultimate-member' ), + 'value' => $rolemeta['_um_can_not_see_adminbar'] ? $labels['yes'] : $labels['no'], + ), ); } if ( array_key_exists( '_um_can_edit_everyone', $rolemeta ) ) { - $info[ 'ultimate-member-' . $key ]['fields'] = array_merge( - $info[ 'ultimate-member-' . $key ]['fields'], - array( - 'um-can_edit_everyone' => array( - 'label' => __( 'Can edit other member accounts?', 'ultimate-member' ), - 'value' => $rolemeta['_um_can_edit_everyone'] ? $labels['yes'] : $labels['no'], - ), - ) + $debug_info[] = array( + 'can_edit_everyone' => array( + 'label' => __( 'Can edit other member accounts?', 'ultimate-member' ), + 'value' => $rolemeta['_um_can_edit_everyone'] ? $labels['yes'] : $labels['no'], + ), ); } @@ -1433,26 +1690,20 @@ class Site_Health { } } - $info[ 'ultimate-member-' . $key ]['fields'] = array_merge( - $info[ 'ultimate-member-' . $key ]['fields'], - array( - 'um-can_edit_roles' => array( - 'label' => __( 'Can edit these user roles only', 'ultimate-member' ), - 'value' => ! empty( $can_edit_roles ) ? implode( ', ', $can_edit_roles ) : $labels['all'], - ), - ) + $debug_info[] = array( + 'can_edit_roles' => array( + 'label' => __( 'Can edit these user roles only', 'ultimate-member' ), + 'value' => ! empty( $can_edit_roles ) ? implode( ', ', $can_edit_roles ) : $labels['all'], + ), ); } if ( array_key_exists( '_um_can_delete_everyone', $rolemeta ) ) { - $info[ 'ultimate-member-' . $key ]['fields'] = array_merge( - $info[ 'ultimate-member-' . $key ]['fields'], - array( - 'um-can_delete_everyone' => array( - 'label' => __( 'Can delete other member accounts?', 'ultimate-member' ), - 'value' => $rolemeta['_um_can_delete_everyone'] ? $labels['yes'] : $labels['no'], - ), - ) + $debug_info[] = array( + 'can_delete_everyone' => array( + 'label' => __( 'Can delete other member accounts?', 'ultimate-member' ), + 'value' => $rolemeta['_um_can_delete_everyone'] ? $labels['yes'] : $labels['no'], + ), ); } @@ -1467,50 +1718,38 @@ class Site_Health { } } - $info[ 'ultimate-member-' . $key ]['fields'] = array_merge( - $info[ 'ultimate-member-' . $key ]['fields'], - array( - 'um-can_delete_roles' => array( - 'label' => __( 'Can delete these user roles only', 'ultimate-member' ), - 'value' => ! empty( $can_delete_roles ) ? implode( ', ', $can_delete_roles ) : $labels['all'], - ), - ) + $debug_info[] = array( + 'can_delete_roles' => array( + 'label' => __( 'Can delete these user roles only', 'ultimate-member' ), + 'value' => ! empty( $can_delete_roles ) ? implode( ', ', $can_delete_roles ) : $labels['all'], + ), ); } if ( array_key_exists( '_um_can_edit_profile', $rolemeta ) ) { - $info[ 'ultimate-member-' . $key ]['fields'] = array_merge( - $info[ 'ultimate-member-' . $key ]['fields'], - array( - 'um-can_edit_profile' => array( - 'label' => __( 'Can edit their profile?', 'ultimate-member' ), - 'value' => $rolemeta['_um_can_edit_profile'] ? $labels['yes'] : $labels['no'], - ), - ) + $debug_info[] = array( + 'can_edit_profile' => array( + 'label' => __( 'Can edit their profile?', 'ultimate-member' ), + 'value' => $rolemeta['_um_can_edit_profile'] ? $labels['yes'] : $labels['no'], + ), ); } if ( array_key_exists( '_um_can_delete_profile', $rolemeta ) ) { - $info[ 'ultimate-member-' . $key ]['fields'] = array_merge( - $info[ 'ultimate-member-' . $key ]['fields'], - array( - 'um-can_delete_profile' => array( - 'label' => __( 'Can delete their account?', 'ultimate-member' ), - 'value' => $rolemeta['_um_can_delete_profile'] ? $labels['yes'] : $labels['no'], - ), - ) + $debug_info[] = array( + 'can_delete_profile' => array( + 'label' => __( 'Can delete their account?', 'ultimate-member' ), + 'value' => $rolemeta['_um_can_delete_profile'] ? $labels['yes'] : $labels['no'], + ), ); } if ( array_key_exists( '_um_can_view_all', $rolemeta ) ) { - $info[ 'ultimate-member-' . $key ]['fields'] = array_merge( - $info[ 'ultimate-member-' . $key ]['fields'], - array( - 'um-can_view_all' => array( - 'label' => __( 'Can view other member profiles?', 'ultimate-member' ), - 'value' => $rolemeta['_um_can_view_all'] ? $labels['yes'] : $labels['no'], - ), - ) + $debug_info[] = array( + 'can_view_all' => array( + 'label' => __( 'Can view other member profiles?', 'ultimate-member' ), + 'value' => $rolemeta['_um_can_view_all'] ? $labels['yes'] : $labels['no'], + ), ); } @@ -1525,14 +1764,29 @@ class Site_Health { } } - $info[ 'ultimate-member-' . $key ]['fields'] = array_merge( - $info[ 'ultimate-member-' . $key ]['fields'], - array( - 'um-can_view_roles' => array( - 'label' => __( 'Can view these user roles only', 'ultimate-member' ), - 'value' => ! empty( $can_view_roles ) ? implode( ', ', $can_view_roles ) : $labels['all'], - ), - ) + $debug_info[] = array( + 'can_view_roles' => array( + 'label' => __( 'Can view these user roles only', 'ultimate-member' ), + 'value' => ! empty( $can_view_roles ) ? implode( ', ', $can_view_roles ) : $labels['all'], + ), + ); + } + + if ( array_key_exists( '_um_can_make_private_profile', $rolemeta ) ) { + $debug_info[] = array( + 'can_make_private_profile' => array( + 'label' => __( 'Can make their profile private?', 'ultimate-member' ), + 'value' => $rolemeta['_um_can_make_private_profile'] ? $labels['yes'] : $labels['no'], + ), + ); + } + + if ( array_key_exists( '_um_can_access_private_profile', $rolemeta ) ) { + $debug_info[] = array( + 'can_access_private_profile' => array( + 'label' => __( 'Can view/access private profiles?', 'ultimate-member' ), + 'value' => $rolemeta['_um_can_access_private_profile'] ? $labels['yes'] : $labels['no'], + ), ); } @@ -1547,53 +1801,23 @@ class Site_Health { $default_homepage = __( 'No such option', 'ultimate-member' ); } - if ( array_key_exists( '_um_can_make_private_profile', $rolemeta ) ) { - $info[ 'ultimate-member-' . $key ]['fields'] = array_merge( - $info[ 'ultimate-member-' . $key ]['fields'], - array( - 'um-can_make_private_profile' => array( - 'label' => __( 'Can make their profile private?', 'ultimate-member' ), - 'value' => $rolemeta['_um_can_make_private_profile'] ? $labels['yes'] : $labels['no'], - ), - ) - ); - } - - if ( array_key_exists( '_um_can_access_private_profile', $rolemeta ) ) { - $info[ 'ultimate-member-' . $key ]['fields'] = array_merge( - $info[ 'ultimate-member-' . $key ]['fields'], - array( - 'um-can_access_private_profile' => array( - 'label' => __( 'Can view/access private profiles?', 'ultimate-member' ), - 'value' => $rolemeta['_um_can_access_private_profile'] ? $labels['yes'] : $labels['no'], - ), - ) - ); - } - - $info[ 'ultimate-member-' . $key ]['fields'] = array_merge( - $info[ 'ultimate-member-' . $key ]['fields'], - array( - 'um-profile_noindex' => array( - 'label' => __( 'Avoid indexing profile by search engines', 'ultimate-member' ), - 'value' => $profile_noindex, - ), - 'um-default_homepage' => array( - 'label' => __( 'Can view default homepage?', 'ultimate-member' ), - 'value' => $default_homepage, - ), - ) + $debug_info[] = array( + 'profile_noindex' => array( + 'label' => __( 'Avoid indexing profile by search engines', 'ultimate-member' ), + 'value' => $profile_noindex, + ), + 'default_homepage' => array( + 'label' => __( 'Can view default homepage?', 'ultimate-member' ), + 'value' => $default_homepage, + ), ); if ( isset( $rolemeta['_um_default_homepage'] ) && 0 === absint( $rolemeta['_um_default_homepage'] ) ) { - $info[ 'ultimate-member-' . $key ]['fields'] = array_merge( - $info[ 'ultimate-member-' . $key ]['fields'], - array( - 'um-redirect_homepage' => array( - 'label' => __( 'Custom Homepage Redirect', 'ultimate-member' ), - 'value' => $rolemeta['_um_redirect_homepage'], - ), - ) + $debug_info[] = array( + 'redirect_homepage' => array( + 'label' => __( 'Custom Homepage Redirect', 'ultimate-member' ), + 'value' => $rolemeta['_um_redirect_homepage'], + ), ); } @@ -1604,14 +1828,11 @@ class Site_Health { ); if ( array_key_exists( '_um_status', $rolemeta ) && isset( $status_options[ $rolemeta['_um_status'] ] ) ) { - $info[ 'ultimate-member-' . $key ]['fields'] = array_merge( - $info[ 'ultimate-member-' . $key ]['fields'], - array( - 'um-status' => array( - 'label' => __( 'Registration Status', 'ultimate-member' ), - 'value' => $status_options[ $rolemeta['_um_status'] ], - ), - ) + $debug_info[] = array( + 'status' => array( + 'label' => __( 'Registration Status', 'ultimate-member' ), + 'value' => $status_options[ $rolemeta['_um_status'] ], + ), ); } @@ -1622,141 +1843,103 @@ class Site_Health { ); if ( isset( $auto_approve_act[ $rolemeta['_um_auto_approve_act'] ] ) ) { - $info[ 'ultimate-member-' . $key ]['fields'] = array_merge( - $info[ 'ultimate-member-' . $key ]['fields'], - array( - 'um-auto_approve_act' => array( - 'label' => __( 'Custom Homepage Redirect', 'ultimate-member' ), - 'value' => $auto_approve_act[ $rolemeta['_um_auto_approve_act'] ], - ), - ) + $debug_info[] = array( + 'auto_approve_act' => array( + 'label' => __( 'Auto-approve action', 'ultimate-member' ), + 'value' => $auto_approve_act[ $rolemeta['_um_auto_approve_act'] ], + ), ); } if ( 'redirect_url' === $rolemeta['_um_auto_approve_act'] && array_key_exists( '_um_auto_approve_url', $rolemeta ) ) { - $info[ 'ultimate-member-' . $key ]['fields'] = array_merge( - $info[ 'ultimate-member-' . $key ]['fields'], - array( - 'um-auto_approve_url' => array( - 'label' => __( 'Set Custom Redirect URL', 'ultimate-member' ), - 'value' => $rolemeta['_um_auto_approve_url'], - ), - ) + $debug_info[] = array( + 'auto_approve_url' => array( + 'label' => __( 'Set Custom Redirect URL', 'ultimate-member' ), + 'value' => $rolemeta['_um_auto_approve_url'], + ), ); } - } - - if ( array_key_exists( '_um_status', $rolemeta ) && 'checkmail' === $rolemeta['_um_status'] ) { + } elseif ( array_key_exists( '_um_status', $rolemeta ) && 'checkmail' === $rolemeta['_um_status'] ) { $checkmail_action = array( 'show_message' => __( 'Show custom message', 'ultimate-member' ), 'redirect_url' => __( 'Redirect to URL', 'ultimate-member' ), ); if ( array_key_exists( '_um_login_email_activate', $rolemeta ) ) { - $info[ 'ultimate-member-' . $key ]['fields'] = array_merge( - $info[ 'ultimate-member-' . $key ]['fields'], - array( - 'um-login_email_activate' => array( - 'label' => __( 'Login user after validating the activation link?', 'ultimate-member' ), - 'value' => $rolemeta['_um_login_email_activate'] ? $labels['yes'] : $labels['no'], - ), - ) + $debug_info[] = array( + 'login_email_activate' => array( + 'label' => __( 'Login user after validating the activation link?', 'ultimate-member' ), + 'value' => $rolemeta['_um_login_email_activate'] ? $labels['yes'] : $labels['no'], + ), ); } if ( isset( $checkmail_action[ $rolemeta['_um_checkmail_action'] ] ) ) { - $info[ 'ultimate-member-' . $key ]['fields'] = array_merge( - $info[ 'ultimate-member-' . $key ]['fields'], - array( - 'um-checkmail_action' => array( - 'label' => __( 'Action to be taken after registration', 'ultimate-member' ), - 'value' => $checkmail_action[ $rolemeta['_um_checkmail_action'] ], - ), - ) + $debug_info[] = array( + 'checkmail_action' => array( + 'label' => __( 'Action to be taken after registration', 'ultimate-member' ), + 'value' => $checkmail_action[ $rolemeta['_um_checkmail_action'] ], + ), ); } if ( 'show_message' === $rolemeta['_um_checkmail_action'] ) { if ( array_key_exists( '_um_checkmail_message', $rolemeta ) ) { - $info[ 'ultimate-member-' . $key ]['fields'] = array_merge( - $info[ 'ultimate-member-' . $key ]['fields'], - array( - 'um-checkmail_message' => array( - 'label' => __( 'Personalize the custom message', 'ultimate-member' ), - 'value' => stripslashes( $rolemeta['_um_checkmail_message'] ), - ), - ) - ); - } - } else { - if ( array_key_exists( '_um_checkmail_url', $rolemeta ) ) { - $info[ 'ultimate-member-' . $key ]['fields'] = array_merge( - $info[ 'ultimate-member-' . $key ]['fields'], - array( - 'um-checkmail_url' => array( - 'label' => __( 'Set Custom Redirect URL', 'ultimate-member' ), - 'value' => $rolemeta['_um_checkmail_url'], - ), - ) + $debug_info[] = array( + 'checkmail_message' => array( + 'label' => __( 'Personalize the custom message', 'ultimate-member' ), + 'value' => stripslashes( $rolemeta['_um_checkmail_message'] ), + ), ); } + } elseif ( array_key_exists( '_um_checkmail_url', $rolemeta ) ) { + $debug_info[] = array( + 'checkmail_url' => array( + 'label' => __( 'Set Custom Redirect URL', 'ultimate-member' ), + 'value' => $rolemeta['_um_checkmail_url'], + ), + ); } if ( array_key_exists( '_um_url_email_activate', $rolemeta ) ) { - $info[ 'ultimate-member-' . $key ]['fields'] = array_merge( - $info[ 'ultimate-member-' . $key ]['fields'], - array( - 'um-url_email_activate' => array( - 'label' => __( 'URL redirect after email activation', 'ultimate-member' ), - 'value' => $rolemeta['_um_url_email_activate'], - ), - ) + $debug_info[] = array( + 'url_email_activate' => array( + 'label' => __( 'URL redirect after email activation', 'ultimate-member' ), + 'value' => $rolemeta['_um_url_email_activate'], + ), ); } - } - - if ( array_key_exists( '_um_status', $rolemeta ) && 'pending' === $rolemeta['_um_status'] ) { + } elseif ( array_key_exists( '_um_status', $rolemeta ) && 'pending' === $rolemeta['_um_status'] ) { $pending_action = array( 'show_message' => __( 'Show custom message', 'ultimate-member' ), 'redirect_url' => __( 'Redirect to URL', 'ultimate-member' ), ); if ( array_key_exists( '_um_pending_action', $rolemeta ) ) { - $info[ 'ultimate-member-' . $key ]['fields'] = array_merge( - $info[ 'ultimate-member-' . $key ]['fields'], - array( - 'um-pending_action' => array( - 'label' => __( 'Action to be taken after registration', 'ultimate-member' ), - 'value' => $pending_action[ $rolemeta['_um_pending_action'] ], - ), - ) + $debug_info[] = array( + 'pending_action' => array( + 'label' => __( 'Action to be taken after registration', 'ultimate-member' ), + 'value' => $pending_action[ $rolemeta['_um_pending_action'] ], + ), ); } if ( 'show_message' === $rolemeta['_um_pending_action'] ) { if ( array_key_exists( '_um_pending_message', $rolemeta ) ) { - $info[ 'ultimate-member-' . $key ]['fields'] = array_merge( - $info[ 'ultimate-member-' . $key ]['fields'], - array( - 'um-pending_message' => array( - 'label' => __( 'Personalize the custom message', 'ultimate-member' ), - 'value' => stripslashes( $rolemeta['_um_pending_message'] ), - ), - ) - ); - } - } else { - if ( array_key_exists( '_um_pending_url', $rolemeta ) ) { - $info[ 'ultimate-member-' . $key ]['fields'] = array_merge( - $info[ 'ultimate-member-' . $key ]['fields'], - array( - 'um-pending_url' => array( - 'label' => __( 'Set Custom Redirect URL', 'ultimate-member' ), - 'value' => $rolemeta['_um_pending_url'], - ), - ) + $debug_info[] = array( + 'pending_message' => array( + 'label' => __( 'Personalize the custom message', 'ultimate-member' ), + 'value' => stripslashes( $rolemeta['_um_pending_message'] ), + ), ); } + } elseif ( array_key_exists( '_um_pending_url', $rolemeta ) ) { + $debug_info[] = array( + 'pending_url' => array( + 'label' => __( 'Set Custom Redirect URL', 'ultimate-member' ), + 'value' => $rolemeta['_um_pending_url'], + ), + ); } } @@ -1768,25 +1951,19 @@ class Site_Health { ); if ( array_key_exists( '_um_after_login', $rolemeta ) && isset( $after_login_options[ $rolemeta['_um_after_login'] ] ) ) { - $info[ 'ultimate-member-' . $key ]['fields'] = array_merge( - $info[ 'ultimate-member-' . $key ]['fields'], - array( - 'um-after_login' => array( - 'label' => __( 'Action to be taken after login', 'ultimate-member' ), - 'value' => $after_login_options[ $rolemeta['_um_after_login'] ], - ), - ) + $debug_info[] = array( + 'after_login' => array( + 'label' => __( 'Action to be taken after login', 'ultimate-member' ), + 'value' => $after_login_options[ $rolemeta['_um_after_login'] ], + ), ); if ( 'redirect_url' === $rolemeta['_um_after_login'] && array_key_exists( '_um_login_redirect_url', $rolemeta ) ) { - $info[ 'ultimate-member-' . $key ]['fields'] = array_merge( - $info[ 'ultimate-member-' . $key ]['fields'], - array( - 'um-login_redirect_url' => array( - 'label' => __( 'Set Custom Redirect URL', 'ultimate-member' ), - 'value' => $rolemeta['_um_login_redirect_url'], - ), - ) + $debug_info[] = array( + 'login_redirect_url' => array( + 'label' => __( 'Set Custom Redirect URL', 'ultimate-member' ), + 'value' => $rolemeta['_um_login_redirect_url'], + ), ); } } @@ -1799,25 +1976,19 @@ class Site_Health { $rolemeta['_um_after_logout'] = 'redirect_home'; } if ( array_key_exists( '_um_after_logout', $rolemeta ) && isset( $redirect_options[ $rolemeta['_um_after_logout'] ] ) ) { - $info[ 'ultimate-member-' . $key ]['fields'] = array_merge( - $info[ 'ultimate-member-' . $key ]['fields'], - array( - 'um-after_logout' => array( - 'label' => __( 'Action to be taken after logout', 'ultimate-member' ), - 'value' => $redirect_options[ $rolemeta['_um_after_logout'] ], - ), - ) + $debug_info[] = array( + 'after_logout' => array( + 'label' => __( 'Action to be taken after logout', 'ultimate-member' ), + 'value' => $redirect_options[ $rolemeta['_um_after_logout'] ], + ), ); if ( 'redirect_url' === $rolemeta['_um_after_logout'] && array_key_exists( '_um_logout_redirect_url', $rolemeta ) ) { - $info[ 'ultimate-member-' . $key ]['fields'] = array_merge( - $info[ 'ultimate-member-' . $key ]['fields'], - array( - 'um-logout_redirect_url' => array( - 'label' => __( 'Set Custom Redirect URL', 'ultimate-member' ), - 'value' => $rolemeta['_um_logout_redirect_url'], - ), - ) + $debug_info[] = array( + 'logout_redirect_url' => array( + 'label' => __( 'Set Custom Redirect URL', 'ultimate-member' ), + 'value' => $rolemeta['_um_logout_redirect_url'], + ), ); } } @@ -1826,144 +1997,203 @@ class Site_Health { $rolemeta['_um_after_delete'] = 'redirect_home'; } if ( array_key_exists( '_um_after_delete', $rolemeta ) && isset( $redirect_options[ $rolemeta['_um_after_delete'] ] ) ) { - $info[ 'ultimate-member-' . $key ]['fields'] = array_merge( - $info[ 'ultimate-member-' . $key ]['fields'], - array( - 'um-after_delete' => array( - 'label' => __( 'Action to be taken after account is deleted', 'ultimate-member' ), - 'value' => $redirect_options[ $rolemeta['_um_after_delete'] ], - ), - ) + $debug_info[] = array( + 'after_delete' => array( + 'label' => __( 'Action to be taken after account is deleted', 'ultimate-member' ), + 'value' => $redirect_options[ $rolemeta['_um_after_delete'] ], + ), ); if ( 'redirect_url' === $rolemeta['_um_after_delete'] && array_key_exists( '_um_delete_redirect_url', $rolemeta ) ) { - $info[ 'ultimate-member-' . $key ]['fields'] = array_merge( - $info[ 'ultimate-member-' . $key ]['fields'], - array( - 'um-delete_redirect_url' => array( - 'label' => __( 'Set Custom Redirect URL', 'ultimate-member' ), - 'value' => $rolemeta['_um_delete_redirect_url'], - ), - ) + $debug_info[] = array( + 'delete_redirect_url' => array( + 'label' => __( 'Set Custom Redirect URL', 'ultimate-member' ), + 'value' => $rolemeta['_um_delete_redirect_url'], + ), ); } } if ( ! empty( $rolemeta['wp_capabilities'] ) ) { - $info[ 'ultimate-member-' . $key ]['fields'] = array_merge( - $info[ 'ultimate-member-' . $key ]['fields'], - array( - 'um-wp_capabilities' => array( - 'label' => __( 'WP Capabilities', 'ultimate-member' ), - 'value' => $rolemeta['wp_capabilities'], - ), - ) + $debug_info[] = array( + 'wp_capabilities' => array( + 'label' => __( 'WP Capabilities', 'ultimate-member' ), + 'value' => $rolemeta['wp_capabilities'], + ), ); } - $info = apply_filters( 'um_debug_information_user_role', $info, $key ); + /** + * Filters user role settings for Site Health. + * + * @since 2.10.5 + * @hook um_debug_information_user_role + * + * @param {array} $debug_info User Role settings for Site Health. + * @param {array} $rolemeta User Role metadata. + * @param {string} $slug User Role slug. + * + * @return {array} User Role settings for Site Health. + * + * @example Extend User Role settings for Site Health. + * function um_debug_information_user_role( $debug_info, $rolemeta, $slug ) { + * // your code here + * return $debug_info; + * } + * add_filter( 'um_debug_information_user_role', 'um_debug_information_user_role', 10, 3 ); + */ + $debug_info = apply_filters( 'um_debug_information_user_role', $debug_info, $rolemeta, $slug ); + + $debug_info = array_merge( ...$debug_info ); + + $info[ 'ultimate-member-role-' . $slug ] = array( + 'label' => ' - ' . $role . __( ' role settings', 'ultimate-member' ), + 'description' => __( 'This debug information about user role.', 'ultimate-member' ), + 'fields' => $debug_info, + ); } - // Forms settings - if ( ! empty( $this->get_forms() ) ) { - $info['ultimate-member-forms'] = array( - 'label' => __( 'Ultimate Member Forms', 'ultimate-member' ), - 'description' => __( 'This debug information for your Ultimate Member forms.', 'ultimate-member' ), - 'fields' => array( - 'um-forms' => array( - 'label' => __( 'UM Forms', 'ultimate-member' ), - 'value' => $this->get_forms(), - ), + return $info; + } + + /** + * Retrieve debug information about Ultimate Member forms. + * + * @param array $info Information array containing debug information. + * + * @return array Information about Ultimate Member forms including form IDs, titles, settings, and labels. + */ + public function forms_debug_information( $info ) { + $all_forms = get_posts( + array( + 'post_type' => 'um_form', + 'posts_per_page' => -1, + 'fields' => 'ids', + ) + ); + + $forms_formatted = array(); + if ( ! empty( $all_forms ) ) { + foreach ( $all_forms as $form_id ) { + $forms_formatted[ 'ID#' . $form_id ] = get_the_title( $form_id ); + } + } + + $info['ultimate-member-forms'] = array( + 'label' => __( 'Ultimate Member Forms', 'ultimate-member' ), + 'description' => __( 'This debug information for your Ultimate Member forms.', 'ultimate-member' ), + 'fields' => array( + 'forms' => array( + 'label' => __( 'UM Forms', 'ultimate-member' ), + 'value' => ! empty( $forms_formatted ) ? $forms_formatted : __( 'No Ultimate Member Forms', 'ultimate-member' ), ), + ), + ); + + if ( ! empty( $all_forms ) ) { + $labels = self::get_labels(); + + $icons_display_options = array( + 'field' => __( 'Show inside text field', 'ultimate-member' ), + 'label' => __( 'Show with label', 'ultimate-member' ), + 'off' => __( 'Turn off', 'ultimate-member' ), ); - foreach ( $this->get_forms() as $key => $form ) { - if ( strpos( $key, 'ID#' ) === 0 ) { - $key = substr( $key, 3 ); - } - - $info[ 'ultimate-member-' . $key ] = array( - 'label' => ' - ' . $form . __( ' form settings', 'ultimate-member' ), - 'description' => __( 'This debug information for your Ultimate Member form.', 'ultimate-member' ), - 'fields' => array( - 'um-form-shortcode' => array( + foreach ( $all_forms as $form_id ) { + $form_mode = get_post_meta( $form_id, '_um_mode', true ); + $debug_info = array( + array( + 'form-shortcode' => array( 'label' => __( 'Shortcode', 'ultimate-member' ), - 'value' => '[ultimatemember form_id="' . $key . '"]', + 'value' => '[ultimatemember form_id="' . $form_id . '"]', ), - 'um-mode' => array( + 'mode' => array( 'label' => __( 'Type', 'ultimate-member' ), - 'value' => get_post_meta( $key, '_um_mode', true ), + 'value' => $form_mode, ), ), ); - if ( 'register' === get_post_meta( $key, '_um_mode', true ) ) { - $info[ 'ultimate-member-' . $key ]['fields'] = array_merge( - $info[ 'ultimate-member-' . $key ]['fields'], - array( - 'um-register_role' => array( - 'label' => __( 'User registration role', 'ultimate-member' ), - 'value' => 0 === absint( get_post_meta( $key, '_um_register_role', true ) ) ? $labels['default'] : get_post_meta( $key, '_um_register_role', true ), - ), - 'um-register_template' => array( - 'label' => __( 'Template', 'ultimate-member' ), - 'value' => 0 === absint( get_post_meta( $key, '_um_register_template', true ) ) ? $labels['default'] : get_post_meta( $key, '_um_register_template', true ), - ), - 'um-register_primary_btn_word' => array( - 'label' => __( 'Primary Button Text', 'ultimate-member' ), - 'value' => ! get_post_meta( $key, '_um_register_primary_btn_word', true ) ? $labels['default'] : get_post_meta( $key, '_um_register_primary_btn_word', true ), - ), - 'um-register_use_gdpr' => array( - 'label' => __( 'Enable privacy policy agreement', 'ultimate-member' ), - 'value' => get_post_meta( $key, '_um_register_use_gdpr', true ) ? $labels['yes'] : $labels['no'], - ), - ) + if ( 'register' === $form_mode ) { + $debug_info[] = array( + 'use_custom_settings' => array( + 'label' => __( 'Apply custom settings to this form', 'ultimate-member' ), + 'value' => get_post_meta( $form_id, '_um_register_use_custom_settings', true ) ? $labels['yes'] : $labels['no'], + ), ); - if ( 1 === absint( get_post_meta( $key, '_um_register_use_gdpr', true ) ) ) { - $gdpr_content_id = get_post_meta( $key, '_um_register_use_gdpr_content_id', true ); - - $info[ 'ultimate-member-' . $key ]['fields'] = array_merge( - $info[ 'ultimate-member-' . $key ]['fields'], - array( - 'um-register_use_gdpr_content_id' => array( - 'label' => __( 'Privacy policy content', 'ultimate-member' ), - 'value' => $gdpr_content_id ? get_the_title( $gdpr_content_id ) . '(' . $gdpr_content_id . ')' . get_the_permalink( $gdpr_content_id ) : '', - ), - 'um-register_use_gdpr_toggle_show' => array( - 'label' => __( 'Toggle Show text', 'ultimate-member' ), - 'value' => get_post_meta( $key, '_um_register_use_gdpr_toggle_show', true ), - ), - 'um-register_use_gdpr_toggle_hide' => array( - 'label' => __( 'Toggle Hide text', 'ultimate-member' ), - 'value' => get_post_meta( $key, '_um_register_use_gdpr_toggle_hide', true ), - ), - 'um-register_use_gdpr_agreement' => array( - 'label' => __( 'Checkbox agreement description', 'ultimate-member' ), - 'value' => get_post_meta( $key, '_um_register_use_gdpr_agreement', true ), - ), - 'um-register_use_gdpr_error_text' => array( - 'label' => __( 'Error Text', 'ultimate-member' ), - 'value' => get_post_meta( $key, '_um_register_use_gdpr_error_text', true ), - ), - ) + if ( get_post_meta( $form_id, '_um_register_use_custom_settings', true ) ) { + $debug_info[] = array( + 'role' => array( + 'label' => __( 'User registration role', 'ultimate-member' ), + 'value' => 0 === absint( get_post_meta( $form_id, '_um_register_role', true ) ) ? $labels['default'] : get_post_meta( $form_id, '_um_register_role', true ), + ), + 'template' => array( + 'label' => __( 'Template', 'ultimate-member' ), + 'value' => 0 === absint( get_post_meta( $form_id, '_um_register_template', true ) ) ? $labels['default'] : get_post_meta( $form_id, '_um_register_template', true ), + ), + 'max_width' => array( + 'label' => __( 'Max. Width (px)', 'ultimate-member' ), + 'value' => get_post_meta( $form_id, '_um_register_max_width', true ), + ), + 'icons' => array( + 'label' => __( 'Field Icons', 'ultimate-member' ), + 'value' => $icons_display_options[ get_post_meta( $form_id, '_um_register_icons', true ) ], + ), + 'primary_btn_word' => array( + 'label' => __( 'Primary Button Text', 'ultimate-member' ), + 'value' => ! get_post_meta( $form_id, '_um_register_primary_btn_word', true ) ? $labels['default'] : get_post_meta( $form_id, '_um_register_primary_btn_word', true ), + ), + 'secondary_btn' => array( + 'label' => __( 'Show Secondary Button', 'ultimate-member' ), + 'value' => get_post_meta( $form_id, '_um_register_secondary_btn', true ) ? $labels['yes'] : $labels['no'], + ), ); - } - $info = apply_filters( 'um_debug_information_register_form', $info, $key ); - - $fields = get_post_meta( $key, '_um_custom_fields', true ); - if ( ! empty( $fields ) && is_array( $fields ) ) { - foreach ( $fields as $field_key => $field ) { - $field_info = $this->get_field_data( $info, $key, $field_key, $field ); - - $info[ 'ultimate-member-' . $key ]['fields'] = array_merge( - $info[ 'ultimate-member-' . $key ]['fields'], - $field_info + if ( get_post_meta( $form_id, '_um_register_secondary_btn', true ) ) { + $debug_info[] = array( + 'secondary_btn_word' => array( + 'label' => __( 'Secondary Button Text', 'ultimate-member' ), + 'value' => get_post_meta( $form_id, '_um_register_secondary_btn_word', true ), + ), ); } } - } elseif ( 'login' === get_post_meta( $key, '_um_mode', true ) ) { + + $debug_info[] = array( + 'use_gdpr' => array( + 'label' => __( 'Enable privacy policy agreement', 'ultimate-member' ), + 'value' => get_post_meta( $form_id, '_um_register_use_gdpr', true ) ? $labels['yes'] : $labels['no'], + ), + ); + + if ( get_post_meta( $form_id, '_um_register_use_gdpr', true ) ) { + $gdpr_content_id = get_post_meta( $form_id, '_um_register_use_gdpr_content_id', true ); + + $debug_info[] = array( + 'use_gdpr_content_id' => array( + 'label' => __( 'Privacy policy content', 'ultimate-member' ), + 'value' => $gdpr_content_id ? get_the_title( $gdpr_content_id ) . ' (ID#' . $gdpr_content_id . ') ' . get_the_permalink( $gdpr_content_id ) : '', + ), + 'use_gdpr_toggle_show' => array( + 'label' => __( 'Toggle Show text', 'ultimate-member' ), + 'value' => get_post_meta( $form_id, '_um_register_use_gdpr_toggle_show', true ), + ), + 'use_gdpr_toggle_hide' => array( + 'label' => __( 'Toggle Hide text', 'ultimate-member' ), + 'value' => get_post_meta( $form_id, '_um_register_use_gdpr_toggle_hide', true ), + ), + 'use_gdpr_agreement' => array( + 'label' => __( 'Checkbox agreement description', 'ultimate-member' ), + 'value' => get_post_meta( $form_id, '_um_register_use_gdpr_agreement', true ), + ), + 'use_gdpr_error_text' => array( + 'label' => __( 'Error Text', 'ultimate-member' ), + 'value' => get_post_meta( $form_id, '_um_register_use_gdpr_error_text', true ), + ), + ); + } + } elseif ( 'login' === $form_mode ) { $login_redirect_options = array( '0' => __( 'Default', 'ultimate-member' ), 'redirect_profile' => __( 'Redirect to profile', 'ultimate-member' ), @@ -1972,234 +2202,302 @@ class Site_Health { 'redirect_admin' => __( 'Redirect to WordPress Admin', 'ultimate-member' ), ); - $login_after_login = get_post_meta( $key, '_um_login_after_login', true ); + $login_after_login = get_post_meta( $form_id, '_um_login_after_login', true ); $login_after_login = '' === $login_after_login ? '0' : $login_after_login; - $info[ 'ultimate-member-' . $key ]['fields'] = array_merge( - $info[ 'ultimate-member-' . $key ]['fields'], - array( - 'um-login_template' => array( + $debug_info[] = array( + 'use_custom_settings' => array( + 'label' => __( 'Apply custom settings to this form', 'ultimate-member' ), + 'value' => get_post_meta( $form_id, '_um_login_use_custom_settings', true ) ? $labels['yes'] : $labels['no'], + ), + ); + + if ( get_post_meta( $form_id, '_um_login_use_custom_settings', true ) ) { + $debug_info[] = array( + 'template' => array( 'label' => __( 'Template', 'ultimate-member' ), - 'value' => 0 === absint( get_post_meta( $key, '_um_login_template', true ) ) ? $labels['default'] : get_post_meta( $key, '_um_login_template', true ), + 'value' => 0 === absint( get_post_meta( $form_id, '_um_login_template', true ) ) ? $labels['default'] : get_post_meta( $form_id, '_um_login_template', true ), ), - 'um-login_primary_btn_word' => array( + 'max_width' => array( + 'label' => __( 'Max. Width (px)', 'ultimate-member' ), + 'value' => get_post_meta( $form_id, '_um_login_max_width', true ), + ), + 'icons' => array( + 'label' => __( 'Field Icons', 'ultimate-member' ), + 'value' => $icons_display_options[ get_post_meta( $form_id, '_um_login_icons', true ) ], + ), + 'primary_btn_word' => array( 'label' => __( 'Primary Button Text', 'ultimate-member' ), - 'value' => ! get_post_meta( $key, '_um_login_primary_btn_word', true ) ? $labels['default'] : get_post_meta( $key, '_um_login_primary_btn_word', true ), + 'value' => ! get_post_meta( $form_id, '_um_login_primary_btn_word', true ) ? $labels['default'] : get_post_meta( $form_id, '_um_login_primary_btn_word', true ), ), - 'um-login_forgot_pass_link' => array( + 'secondary_btn' => array( + 'label' => __( 'Show Secondary Button', 'ultimate-member' ), + 'value' => get_post_meta( $form_id, '_um_login_secondary_btn', true ) ? $labels['yes'] : $labels['no'], + ), + ); + + if ( get_post_meta( $form_id, '_um_login_secondary_btn', true ) ) { + $debug_info[] = array( + 'secondary_btn_word' => array( + 'label' => __( 'Secondary Button Text', 'ultimate-member' ), + 'value' => get_post_meta( $form_id, '_um_login_secondary_btn_word', true ), + ), + ); + } + + $debug_info[] = array( + 'forgot_pass_link' => array( 'label' => __( 'Show Forgot Password Link?', 'ultimate-member' ), - 'value' => get_post_meta( $key, '_um_login_forgot_pass_link', true ) ? $labels['yes'] : $labels['no'], + 'value' => get_post_meta( $form_id, '_um_login_forgot_pass_link', true ) ? $labels['yes'] : $labels['no'], ), - 'um-login_show_rememberme' => array( + 'show_rememberme' => array( 'label' => __( 'Show "Remember Me"?', 'ultimate-member' ), - 'value' => get_post_meta( $key, '_um_login_show_rememberme', true ) ? $labels['yes'] : $labels['no'], + 'value' => get_post_meta( $form_id, '_um_login_show_rememberme', true ) ? $labels['yes'] : $labels['no'], ), - 'um-login_after_login' => array( - 'label' => __( 'Redirection after Login', 'ultimate-member' ), - 'value' => $login_redirect_options[ $login_after_login ], - ), - ) - ); - - if ( 'redirect_url' === get_post_meta( $key, '_um_login_after_login', true ) ) { - $info[ 'ultimate-member-' . $key ]['fields'] = array_merge( - $info[ 'ultimate-member-' . $key ]['fields'], - array( - 'um-login_redirect_url' => array( - 'label' => __( 'Set Custom Redirect URL', 'ultimate-member' ), - 'value' => get_post_meta( $key, '_um_login_redirect_url', true ), - ), - ) ); } - $info = apply_filters( 'um_debug_information_login_form', $info, $key ); + $debug_info[] = array( + 'after_login' => array( + 'label' => __( 'Redirection after Login', 'ultimate-member' ), + 'value' => $login_redirect_options[ $login_after_login ], + ), + ); - $fields = get_post_meta( $key, '_um_custom_fields', true ); - if ( ! empty( $fields ) && is_array( $fields ) ) { - foreach ( $fields as $field_key => $field ) { - $field_info = $this->get_field_data( $info, $key, $field_key, $field ); - - $info[ 'ultimate-member-' . $key ]['fields'] = array_merge( - $info[ 'ultimate-member-' . $key ]['fields'], - $field_info - ); - } + if ( 'redirect_url' === get_post_meta( $form_id, '_um_login_after_login', true ) ) { + $debug_info[] = array( + 'redirect_url' => array( + 'label' => __( 'Set Custom Redirect URL', 'ultimate-member' ), + 'value' => get_post_meta( $form_id, '_um_login_redirect_url', true ), + ), + ); } - } elseif ( 'profile' === get_post_meta( $key, '_um_mode', true ) ) { - $info[ 'ultimate-member-' . $key ]['fields'] = array_merge( - $info[ 'ultimate-member-' . $key ]['fields'], - array( - 'um-profile_role' => array( + } elseif ( 'profile' === $form_mode ) { + $debug_info[] = array( + 'use_custom_settings' => array( + 'label' => __( 'Apply custom settings to this form', 'ultimate-member' ), + 'value' => get_post_meta( $form_id, '_um_profile_use_custom_settings', true ) ? $labels['yes'] : $labels['no'], + ), + ); + + if ( get_post_meta( $form_id, '_um_profile_use_custom_settings', true ) ) { + $debug_info[] = array( + 'role' => array( 'label' => __( 'Make this profile form role-specific', 'ultimate-member' ), - 'value' => ! empty( get_post_meta( $key, '_um_profile_role', true ) ) ? get_post_meta( $key, '_um_profile_role', true ) : $labels['all'], + 'value' => ! empty( get_post_meta( $form_id, '_um_profile_role', true ) ) ? get_post_meta( $form_id, '_um_profile_role', true ) : $labels['all'], ), - 'um-profile_template' => array( + 'template' => array( 'label' => __( 'Template', 'ultimate-member' ), - 'value' => 0 === absint( get_post_meta( $key, '_um_profile_template', true ) ) ? $labels['default'] : get_post_meta( $key, '_um_profile_template', true ), + 'value' => 0 === absint( get_post_meta( $form_id, '_um_profile_template', true ) ) ? $labels['default'] : get_post_meta( $form_id, '_um_profile_template', true ), ), - 'um-profile_primary_btn_word' => array( + 'max_width' => array( + 'label' => __( 'Max. Width (px)', 'ultimate-member' ), + 'value' => get_post_meta( $form_id, '_um_profile_max_width', true ), + ), + 'area_max_width' => array( + 'label' => __( 'Profile Area Max. Width (px)', 'ultimate-member' ), + 'value' => get_post_meta( $form_id, '_um_profile_area_max_width', true ), + ), + 'icons' => array( + 'label' => __( 'Field Icons', 'ultimate-member' ), + 'value' => $icons_display_options[ get_post_meta( $form_id, '_um_profile_icons', true ) ], + ), + 'primary_btn_word' => array( 'label' => __( 'Primary Button Text', 'ultimate-member' ), - 'value' => ! get_post_meta( $key, '_um_profile_primary_btn_word', true ) ? $labels['default'] : get_post_meta( $key, '_um_profile_primary_btn_word', true ), + 'value' => ! get_post_meta( $form_id, '_um_profile_primary_btn_word', true ) ? $labels['default'] : get_post_meta( $form_id, '_um_profile_primary_btn_word', true ), ), - 'um-profile_cover_enabled' => array( - 'label' => __( 'Enable Cover Photos', 'ultimate-member' ), - 'value' => get_post_meta( $key, '_um_profile_cover_enabled', true ) ? $labels['yes'] : $labels['no'], + 'secondary_btn' => array( + 'label' => __( 'Show Secondary Button', 'ultimate-member' ), + 'value' => get_post_meta( $form_id, '_um_profile_secondary_btn', true ) ? $labels['yes'] : $labels['no'], ), - 'um-profile_disable_photo_upload' => array( - 'label' => __( 'Disable Profile Photo Upload', 'ultimate-member' ), - 'value' => get_post_meta( $key, '_um_profile_disable_photo_upload', true ) ? $labels['yes'] : $labels['no'], - ), - ) - ); + ); - if ( 0 === absint( get_post_meta( $key, '_um_profile_disable_photo_upload', true ) ) ) { - $info[ 'ultimate-member-' . $key ]['fields'] = array_merge( - $info[ 'ultimate-member-' . $key ]['fields'], - array( - 'um-profile_photo_required' => array( - 'label' => __( 'Make Profile Photo Required', 'ultimate-member' ), - 'value' => get_post_meta( $key, '_um_profile_photo_required', true ) ? $labels['yes'] : $labels['no'], + if ( get_post_meta( $form_id, '_um_profile_secondary_btn', true ) ) { + $debug_info[] = array( + 'secondary_btn_word' => array( + 'label' => __( 'Secondary Button Text', 'ultimate-member' ), + 'value' => get_post_meta( $form_id, '_um_profile_secondary_btn_word', true ), ), - ) + ); + } + + $debug_info[] = array( + 'cover_enabled' => array( + 'label' => __( 'Enable Cover Photos', 'ultimate-member' ), + 'value' => get_post_meta( $form_id, '_um_profile_cover_enabled', true ) ? $labels['yes'] : $labels['no'], + ), + ); + + if ( get_post_meta( $form_id, '_um_profile_cover_enabled', true ) ) { + $debug_info[] = array( + 'coversize' => array( + 'label' => __( 'Cover Photo Size', 'ultimate-member' ), + 'value' => get_post_meta( $form_id, '_um_profile_coversize', true ), + ), + 'cover_ratio' => array( + 'label' => __( 'Cover photo ratio', 'ultimate-member' ), + 'value' => get_post_meta( $form_id, '_um_profile_cover_ratio', true ), + ), + ); + } + + $debug_info[] = array( + 'disable_photo_upload' => array( + 'label' => __( 'Disable Profile Photo Upload', 'ultimate-member' ), + 'value' => get_post_meta( $form_id, '_um_profile_disable_photo_upload', true ) ? $labels['yes'] : $labels['no'], + ), + ); + + if ( 0 === absint( get_post_meta( $form_id, '_um_profile_disable_photo_upload', true ) ) ) { + $debug_info[] = array( + 'photosize' => array( + 'label' => __( 'Profile Photo Size', 'ultimate-member' ), + 'value' => get_post_meta( $form_id, '_um_profile_photosize', true ), + ), + 'photo_required' => array( + 'label' => __( 'Make Profile Photo Required', 'ultimate-member' ), + 'value' => get_post_meta( $form_id, '_um_profile_photo_required', true ) ? $labels['yes'] : $labels['no'], + ), + ); + } + + $debug_info[] = array( + 'show_name' => array( + 'label' => __( 'Show display name in profile header?', 'ultimate-member' ), + 'value' => get_post_meta( $form_id, '_um_profile_show_name', true ) ? $labels['yes'] : $labels['no'], + ), + 'show_social_links' => array( + 'label' => __( 'Show social links in profile header?', 'ultimate-member' ), + 'value' => get_post_meta( $form_id, '_um_profile_show_social_links', true ) ? $labels['yes'] : $labels['no'], + ), + 'show_bio' => array( + 'label' => __( 'Show user description in profile header?', 'ultimate-member' ), + 'value' => get_post_meta( $form_id, '_um_profile_show_bio', true ) ? $labels['yes'] : $labels['no'], + ), ); } - $info[ 'ultimate-member-' . $key ]['fields'] = array_merge( - $info[ 'ultimate-member-' . $key ]['fields'], - array( - 'um-profile_show_name' => array( - 'label' => __( 'Show display name in profile header?', 'ultimate-member' ), - 'value' => get_post_meta( $key, '_um_profile_show_name', true ) ? $labels['yes'] : $labels['no'], - ), - 'um-profile_show_social_links' => array( - 'label' => __( 'Show social links in profile header?', 'ultimate-member' ), - 'value' => get_post_meta( $key, '_um_profile_show_social_links', true ) ? $labels['yes'] : $labels['no'], - ), - 'um-profile_show_bio' => array( - 'label' => __( 'Show user description in profile header?', 'ultimate-member' ), - 'value' => get_post_meta( $key, '_um_profile_show_bio', true ) ? $labels['yes'] : $labels['no'], - ), - ) - ); - - $fields = get_post_meta( $key, '_um_custom_fields', true ); - if ( ! empty( $fields ) && is_array( $fields ) ) { - foreach ( $fields as $field_key => $field ) { - $field_info = $this->get_field_data( $info, $key, $field_key, $field ); - - $info[ 'ultimate-member-' . $key ]['fields'] = array_merge( - $info[ 'ultimate-member-' . $key ]['fields'], - $field_info - ); - } - } - - $profile_metafields = get_post_meta( $key, '_um_profile_metafields', true ); + $profile_metafields = get_post_meta( $form_id, '_um_profile_metafields', true ); if ( ! empty( $profile_metafields ) && is_array( $profile_metafields ) ) { - foreach ( $profile_metafields as $k => $field ) { - $info[ 'ultimate-member-' . $key ]['fields'] = array_merge( - $info[ 'ultimate-member-' . $key ]['fields'], - array( - 'um-profile_metafields-' . $k => array( - 'label' => __( 'Field to show in user meta', 'ultimate-member' ), - 'value' => $field, - ), - ) - ); - } + $debug_info[] = array( + 'metafields-' . $form_id => array( + 'label' => __( 'Field(s) to show in user meta', 'ultimate-member' ), + 'value' => implode( ', ', $profile_metafields ), + ), + ); } } + + $fields = get_post_meta( $form_id, '_um_custom_fields', true ); + if ( ! empty( $fields ) && is_array( $fields ) ) { + foreach ( $fields as $field_key => $field ) { + $debug_info[] = $this->get_field_data( $field_key, $field ); + } + } + + /** + * Filters form settings for Site Health. + * + * @since 2.10.5 + * @hook um_debug_information_{$form_mode}_form + * + * @param {array} $info Registration form settings for Site Health. + * @param {string} $form_id Registration form ID. + * + * @return {array} Registration form settings for Site Health. + * + * @example Extend Registration form settings for Site Health. + * function um_debug_information_user_role( $info, $form_id ) { + * // your code here + * return $info; + * } + * add_filter( 'um_debug_information_register_form', 'um_debug_information_register_form', 10, 2 ); + * @example Extend Login form settings for Site Health. + * function um_debug_information_login_form( $info, $form_id ) { + * // your code here + * return $info; + * } + * add_filter( 'um_debug_information_login_form', 'um_debug_information_login_form', 10, 2 ); + */ + $debug_info = apply_filters( "um_debug_information_{$form_mode}_form", $debug_info, $form_id ); + + $debug_info = array_merge( ...$debug_info ); + + $info[ 'ultimate-member-form-' . $form_id ] = array( + // translators: %s is the form title. + 'label' => sprintf( __( ' - Form "%s" settings', 'ultimate-member' ), get_the_title( $form_id ) ), + 'description' => __( 'This debug information for your Ultimate Member form.', 'ultimate-member' ), + 'fields' => $debug_info, + ); } } - // Members directory - $options = array( - 'country' => __( 'Country', 'ultimate-member' ), - 'gender' => __( 'Gender', 'ultimate-member' ), - 'languages' => __( 'Languages', 'ultimate-member' ), - 'role' => __( 'Roles', 'ultimate-member' ), - 'birth_date' => __( 'Age', 'ultimate-member' ), - 'last_login' => __( 'Last Login', 'ultimate-member' ), - 'user_registered' => __( 'User Registered', 'ultimate-member' ), - 'first_name' => __( 'First Name', 'ultimate-member' ), - 'last_name' => __( 'Last Name', 'ultimate-member' ), - 'nickname' => __( 'Nickname', 'ultimate-member' ), - 'secondary_user_email' => __( 'Secondary Email Address', 'ultimate-member' ), - 'description' => __( 'Biography', 'ultimate-member' ), - 'phone_number' => __( 'Phone Number', 'ultimate-member' ), - 'mobile_number' => __( 'Mobile Number', 'ultimate-member' ), - 'role_select' => __( 'Roles (Dropdown)', 'ultimate-member' ), - 'role_radio' => __( 'Roles (Radio)', 'ultimate-member' ), - 'whatsapp' => __( 'WhatsApp number', 'ultimate-member' ), - 'facebook' => __( 'Facebook', 'ultimate-member' ), - 'twitter' => __( 'X (formerly Twitter)', 'ultimate-member' ), - 'viber' => __( 'Viber number', 'ultimate-member' ), - 'skype' => __( 'Skype ID', 'ultimate-member' ), - 'telegram' => __( 'Telegram', 'ultimate-member' ), - 'discord' => __( 'Discord', 'ultimate-member' ), - 'youtube' => __( 'Youtube', 'ultimate-member' ), - 'soundcloud' => __( 'SoundCloud', 'ultimate-member' ), - 'user_registered_desc' => __( 'New users first', 'ultimate-member' ), - 'user_registered_asc' => __( 'Old users first', 'ultimate-member' ), - 'username' => __( 'Username', 'ultimate-member' ), - 'display_name' => __( 'Display name', 'ultimate-member' ), - 'last_first_name' => __( 'Last & First name', 'ultimate-member' ), - 'random' => __( 'Random', 'ultimate-member' ), - 'other' => __( 'Other (Custom Field)', 'ultimate-member' ), + return $info; + } + + /** + * Get information about member directories for site health check. + * + * @param array $info Additional information for site health check. + * + * @return array Information about Ultimate Member directories including labels, fields, and debug details. + */ + public function member_directories_debug_information( $info ) { + $all_member_directories = get_posts( + array( + 'post_type' => 'um_directory', + 'posts_per_page' => -1, + 'fields' => 'ids', + ) ); + $formatted_directories = array(); + foreach ( $all_member_directories as $directory_id ) { + $formatted_directories[ 'ID#' . $directory_id ] = get_the_title( $directory_id ); + } + $info['ultimate-member-directories'] = array( 'label' => __( 'Ultimate Member Directories', 'ultimate-member' ), 'description' => __( 'This debug information about Ultimate Member directories.', 'ultimate-member' ), 'fields' => array( - 'um-directory' => array( + 'directory' => array( 'label' => __( 'Member directories', 'ultimate-member' ), - 'value' => ! empty( $this->get_member_directories() ) ? $this->get_member_directories() : $labels['no-dir'], + 'value' => ! empty( $formatted_directories ) ? $formatted_directories : __( 'No member directories', 'ultimate-member' ), ), ), ); - if ( ! empty( $this->get_member_directories() ) ) { - foreach ( $this->get_member_directories() as $key => $directory ) { - if ( 0 === strpos( $key, 'ID#' ) ) { - $key = substr( $key, 3 ); - } + if ( ! empty( $all_member_directories ) ) { + $labels = self::get_labels(); + $options = array_unique( array_merge( UM()->member_directory()->filter_fields, UM()->member_directory()->default_sorting, UM()->member_directory()->sort_fields, UM()->member_directory()->searching_fields ) ); - $_um_view_types_value = get_post_meta( $key, '_um_view_types', true ); + foreach ( $all_member_directories as $directory_id ) { + $_um_view_types_value = get_post_meta( $directory_id, '_um_view_types', true ); $_um_view_types_value = empty( $_um_view_types_value ) ? array( 'grid', 'list' ) : $_um_view_types_value; $_um_view_types_value = is_string( $_um_view_types_value ) ? array( $_um_view_types_value ) : $_um_view_types_value; - $info[ 'ultimate-member-directory-' . $key ] = array( - 'label' => ' - ' . $directory . __( ' directory settings', 'ultimate-member' ), - 'description' => __( 'This debug information for your Ultimate Member directory.', 'ultimate-member' ), - 'fields' => array( - 'um-directory-shortcode' => array( + $debug_info = array( + array( + 'shortcode' => array( 'label' => __( 'Shortcode', 'ultimate-member' ), - 'value' => '[ultimatemember_directory id="' . $key . '"]', + 'value' => '[ultimatemember_directory id="' . $directory_id . '"]', ), - 'um-directory_template' => array( + 'template' => array( 'label' => __( 'Template', 'ultimate-member' ), - 'value' => get_post_meta( $key, '_um_directory_template', true ) ? get_post_meta( $key, '_um_directory_template', true ) : $labels['default'], + 'value' => get_post_meta( $directory_id, '_um_directory_template', true ) ? get_post_meta( $directory_id, '_um_directory_template', true ) : $labels['default'], ), - 'um-directory-view_types' => array( + 'view_types' => array( 'label' => __( 'View types', 'ultimate-member' ), 'value' => implode( ', ', $_um_view_types_value ), ), - 'um-directory-default_view' => array( + 'default_view' => array( 'label' => __( 'Default view type', 'ultimate-member' ), - 'value' => get_post_meta( $key, '_um_default_view', true ), + 'value' => get_post_meta( $directory_id, '_um_default_view', true ), ), ), ); - if ( isset( $options[ get_post_meta( $key, '_um_sortby', true ) ] ) ) { - $sortby_label = $options[ get_post_meta( $key, '_um_sortby', true ) ]; - } else { - $sortby_label = get_post_meta( $key, '_um_sortby', true ); - } - - $directory_roles_meta = get_post_meta( $key, '_um_roles', true ); + $directory_roles_meta = get_post_meta( $directory_id, '_um_roles', true ); $directory_roles = array(); if ( ! empty( $directory_roles_meta ) ) { if ( is_string( $directory_roles_meta ) ) { @@ -2209,7 +2507,7 @@ class Site_Health { } } - $directory_show_these_users_meta = get_post_meta( $key, '_um_show_these_users', true ); + $directory_show_these_users_meta = get_post_meta( $directory_id, '_um_show_these_users', true ); $show_these_users = array(); if ( ! empty( $directory_show_these_users_meta ) ) { if ( is_string( $directory_show_these_users_meta ) ) { @@ -2219,7 +2517,7 @@ class Site_Health { } } - $directory_exclude_these_users_meta = get_post_meta( $key, '_um_exclude_these_users', true ); + $directory_exclude_these_users_meta = get_post_meta( $directory_id, '_um_exclude_these_users', true ); $exclude_these_users = array(); if ( ! empty( $directory_exclude_these_users_meta ) ) { if ( is_string( $directory_exclude_these_users_meta ) ) { @@ -2229,186 +2527,123 @@ class Site_Health { } } - $info[ 'ultimate-member-directory-' . $key ]['fields'] = array_merge( - $info[ 'ultimate-member-directory-' . $key ]['fields'], - array( - 'um-directory-roles' => array( - 'label' => __( 'User Roles to display', 'ultimate-member' ), - 'value' => ! empty( $directory_roles ) ? implode( ', ', $directory_roles ) : $labels['all'], - ), - 'um-directory-has_profile_photo' => array( - 'label' => __( 'Only show members who have uploaded a profile photo', 'ultimate-member' ), - 'value' => get_post_meta( $key, '_um_has_profile_photo', true ) ? $labels['yes'] : $labels['no'], - ), - 'um-directory-has_cover_photo' => array( - 'label' => __( 'Only show members who have uploaded a profile photo', 'ultimate-member' ), - 'value' => get_post_meta( $key, '_um_has_cover_photo', true ) ? $labels['yes'] : $labels['no'], - ), - 'um-directory-show_these_users' => array( - 'label' => __( 'Only show specific users (Enter one username per line)', 'ultimate-member' ), - 'value' => ! empty( $show_these_users ) ? implode( ', ', $show_these_users ) : '', - ), - 'um-directory-exclude_these_users' => array( - 'label' => __( 'Exclude specific users (Enter one username per line)', 'ultimate-member' ), - 'value' => ! empty( $exclude_these_users ) ? implode( ', ', $exclude_these_users ) : '', - ), - ) + $debug_info[] = array( + 'roles' => array( + 'label' => __( 'User Roles to display', 'ultimate-member' ), + 'value' => ! empty( $directory_roles ) ? implode( ', ', $directory_roles ) : $labels['all'], + ), + 'has_profile_photo' => array( + 'label' => __( 'Only show members who have uploaded a profile photo', 'ultimate-member' ), + 'value' => get_post_meta( $directory_id, '_um_has_profile_photo', true ) ? $labels['yes'] : $labels['no'], + ), + 'has_cover_photo' => array( + 'label' => __( 'Only show members who have uploaded a cover photo', 'ultimate-member' ), + 'value' => get_post_meta( $directory_id, '_um_has_cover_photo', true ) ? $labels['yes'] : $labels['no'], + ), + 'show_these_users' => array( + 'label' => __( 'Only show specific users', 'ultimate-member' ), + 'value' => ! empty( $show_these_users ) ? implode( ', ', $show_these_users ) : $labels['empty'], + ), + 'exclude_these_users' => array( + 'label' => __( 'Exclude specific users', 'ultimate-member' ), + 'value' => ! empty( $exclude_these_users ) ? implode( ', ', $exclude_these_users ) : $labels['empty'], + ), ); - $info = apply_filters( 'um_debug_member_directory_general_extend', $info, $key ); + /** + * Filters general member directory settings for Site Health. + * + * @since 2.10.5 + * @hook um_debug_member_directory_general_extend + * + * @param {array} $info Member directory settings for Site Health. + * @param {string} $directory_id Member directory ID. + * + * @return {array} Member directory settings for Site Health. + * + * @example Extend Member directory settings for Site Health. + * function um_debug_member_directory_general_extend( $info, $directory_id ) { + * // your code here + * return $info; + * } + * add_filter( 'um_debug_member_directory_general_extend', 'um_debug_member_directory_general_extend', 10, 2 ); + */ + $debug_info = apply_filters( 'um_debug_member_directory_general_extend', $debug_info, $directory_id ); - $info[ 'ultimate-member-directory-' . $key ]['fields'] = array_merge( - $info[ 'ultimate-member-directory-' . $key ]['fields'], - array( - 'um-directory-sortby' => array( - 'label' => __( 'Default sort users by', 'ultimate-member' ), - 'value' => $sortby_label, - ), - ) + if ( isset( $options[ get_post_meta( $directory_id, '_um_sortby', true ) ] ) ) { + $sortby_label = $options[ get_post_meta( $directory_id, '_um_sortby', true ) ]; + } else { + $sortby_label = get_post_meta( $directory_id, '_um_sortby', true ); + } + + $debug_info[] = array( + 'sortby' => array( + 'label' => __( 'Default sort users by', 'ultimate-member' ), + 'value' => $sortby_label, + ), ); - if ( 'other' === get_post_meta( $key, '_um_sortby', true ) ) { - $info[ 'ultimate-member-directory-' . $key ]['fields'] = array_merge( - $info[ 'ultimate-member-directory-' . $key ]['fields'], - array( - 'um-directory-enable_sorting' => array( - 'label' => __( 'Enable custom sorting', 'ultimate-member' ), - 'value' => get_post_meta( $key, '_um_enable_sorting', true ) ? $labels['yes'] : $labels['no'], - ), - 'um-directory-sortby_custom' => array( - 'label' => __( 'Custom sorting meta key', 'ultimate-member' ), - 'value' => get_post_meta( $key, '_um_sortby_custom', true ), - ), - 'um-directory-sortby_custom_label' => array( - 'label' => __( 'Label of custom sort', 'ultimate-member' ), - 'value' => get_post_meta( $key, '_um_sortby_custom_label', true ), - ), - ) + if ( 'other' === get_post_meta( $directory_id, '_um_sortby', true ) ) { + $debug_info[] = array( + 'sortby_custom' => array( + 'label' => __( 'Meta key', 'ultimate-member' ), + 'value' => get_post_meta( $directory_id, '_um_sortby_custom', true ), + ), + 'sortby_custom_type' => array( + 'label' => __( 'Data type', 'ultimate-member' ), + 'value' => UM()->member_directory()->sort_data_types[ get_post_meta( $directory_id, '_um_sortby_custom_type', true ) ], + ), + 'sortby_custom_order' => array( + 'label' => __( 'Order', 'ultimate-member' ), + 'value' => 'ASC' === get_post_meta( $directory_id, '_um_sortby_custom_order', true ) ? __( 'Ascending', 'ultimate-member' ) : __( 'Descending', 'ultimate-member' ), + ), + 'sortby_custom_label' => array( + 'label' => __( 'Label of custom sort', 'ultimate-member' ), + 'value' => get_post_meta( $directory_id, '_um_sortby_custom_label', true ), + ), ); } - if ( 1 === absint( get_post_meta( $key, '_um_enable_sorting', true ) ) ) { - $sorting_fields = get_post_meta( $key, '_um_sorting_fields', true ); + $debug_info[] = array( + 'enable_sorting' => array( + 'label' => __( 'Enable custom sorting', 'ultimate-member' ), + 'value' => get_post_meta( $directory_id, '_um_enable_sorting', true ) ? $labels['yes'] : $labels['no'], + ), + ); + + if ( 1 === absint( get_post_meta( $directory_id, '_um_enable_sorting', true ) ) ) { + $sorting_fields = get_post_meta( $directory_id, '_um_sorting_fields', true ); if ( ! empty( $sorting_fields ) ) { foreach ( $sorting_fields as $k => $field ) { if ( is_array( $field ) ) { - $info[ 'ultimate-member-directory-' . $key ]['fields'] = array_merge( - $info[ 'ultimate-member-directory-' . $key ]['fields'], - array( - 'um-directory-sorting_fields-' . $k => array( - 'label' => __( 'Field(s) to enable in sorting', 'ultimate-member' ), - 'value' => __( 'Label: ', 'ultimate-member' ) . array_values( $field )[0] . ' | ' . __( 'Meta key: ', 'ultimate-member' ) . stripslashes( array_keys( $field )[0] ), - ), - ) + $debug_info[] = array( + 'sorting_fields-' . $k => array( + 'label' => __( 'Field(s) to enable in sorting', 'ultimate-member' ), + 'value' => $field, + ), ); } else { $sortby_label = isset( $options[ $field ] ) ? $options[ $field ] : $field; - $info[ 'ultimate-member-directory-' . $key ]['fields'] = array_merge( - $info[ 'ultimate-member-directory-' . $key ]['fields'], - array( - 'um-directory-sorting_fields-' . $k => array( - 'label' => __( 'Field to enable in sorting', 'ultimate-member' ), - 'value' => $sortby_label, - ), - ) + $debug_info[] = array( + 'sorting_fields-' . $k => array( + 'label' => __( 'Field(s) to enable in sorting', 'ultimate-member' ), + 'value' => $sortby_label, + ), ); } } } } - $info[ 'ultimate-member-directory-' . $key ]['fields'] = array_merge( - $info[ 'ultimate-member-directory-' . $key ]['fields'], - array( - 'um-directory-profile_photo' => array( - 'label' => __( 'Enable Profile Photo', 'ultimate-member' ), - 'value' => get_post_meta( $key, '_um_profile_photo', true ) ? $labels['yes'] : $labels['no'], - ), - 'um-directory-cover_photos' => array( - 'label' => __( 'Enable Cover Photo', 'ultimate-member' ), - 'value' => get_post_meta( $key, '_um_cover_photos', true ) ? $labels['yes'] : $labels['no'], - ), - 'um-directory-show_name' => array( - 'label' => __( 'Show display name', 'ultimate-member' ), - 'value' => get_post_meta( $key, '_um_show_name', true ) ? $labels['yes'] : $labels['no'], - ), - ) + $debug_info[] = array( + 'search' => array( + 'label' => __( 'Enable Search feature', 'ultimate-member' ), + 'value' => get_post_meta( $directory_id, '_um_search', true ) ? $labels['yes'] : $labels['no'], + ), ); - $info = apply_filters( 'um_debug_member_directory_profile_extend', $info, $key ); - - $info[ 'ultimate-member-directory-' . $key ]['fields'] = array_merge( - $info[ 'ultimate-member-directory-' . $key ]['fields'], - array( - 'um-directory-show_tagline' => array( - 'label' => __( 'Show tagline below profile name', 'ultimate-member' ), - 'value' => get_post_meta( $key, '_um_show_tagline', true ) ? $labels['yes'] : $labels['no'], - ), - ) - ); - - if ( 1 === absint( get_post_meta( $key, '_um_show_tagline', true ) ) ) { - $tagline_fields = get_post_meta( $key, '_um_tagline_fields', true ); - if ( ! empty( $tagline_fields ) && is_array( $tagline_fields ) ) { - foreach ( $tagline_fields as $k => $field ) { - $label = isset( $options[ $field ] ) ? $options[ $field ] : $field; - $info[ 'ultimate-member-directory-' . $key ]['fields'] = array_merge( - $info[ 'ultimate-member-directory-' . $key ]['fields'], - array( - 'um-directory-tagline_fields-' . $k => array( - 'label' => __( 'Field to display in tagline', 'ultimate-member' ), - 'value' => $label, - ), - ) - ); - } - } - } - - $info[ 'ultimate-member-directory-' . $key ]['fields'] = array_merge( - $info[ 'ultimate-member-directory-' . $key ]['fields'], - array( - 'um-directory-show_userinfo' => array( - 'label' => __( 'Show extra user information below tagline?', 'ultimate-member' ), - 'value' => get_post_meta( $key, '_um_show_userinfo', true ) ? $labels['yes'] : $labels['no'], - ), - ) - ); - - if ( 1 === absint( get_post_meta( $key, '_um_show_userinfo', true ) ) ) { - $reveal_fields = get_post_meta( $key, '_um_reveal_fields', true ); - if ( ! empty( $reveal_fields ) && is_array( $reveal_fields ) ) { - foreach ( $reveal_fields as $k => $field ) { - $label = isset( $options[ $field ] ) ? $options[ $field ] : $field; - $info[ 'ultimate-member-directory-' . $key ]['fields'] = array_merge( - $info[ 'ultimate-member-directory-' . $key ]['fields'], - array( - 'um-directory-reveal_fields-' . $k => array( - 'label' => __( 'Field to display in extra user information section', 'ultimate-member' ), - 'value' => $label, - ), - ) - ); - } - } - } - - $info[ 'ultimate-member-directory-' . $key ]['fields'] = array_merge( - $info[ 'ultimate-member-directory-' . $key ]['fields'], - array( - 'um-directory-show_social' => array( - 'label' => __( 'Show social connect icons in extra user information section', 'ultimate-member' ), - 'value' => get_post_meta( $key, '_um_show_social', true ) ? $labels['yes'] : $labels['no'], - ), - 'um-directory-search' => array( - 'label' => __( 'Enable Search feature', 'ultimate-member' ), - 'value' => get_post_meta( $key, '_um_search', true ) ? $labels['yes'] : $labels['no'], - ), - ) - ); - - if ( 1 === absint( get_post_meta( $key, '_um_search', true ) ) ) { - $directory_roles_can_search_meta = get_post_meta( $key, '_um_roles_can_search', true ); + if ( 1 === absint( get_post_meta( $directory_id, '_um_search', true ) ) ) { + $directory_roles_can_search_meta = get_post_meta( $directory_id, '_um_roles_can_search', true ); $roles_can_search = array(); if ( ! empty( $directory_roles_can_search_meta ) ) { if ( is_string( $directory_roles_can_search_meta ) ) { @@ -2418,29 +2653,41 @@ class Site_Health { } } - $info[ 'ultimate-member-directory-' . $key ]['fields'] = array_merge( - $info[ 'ultimate-member-directory-' . $key ]['fields'], - array( - 'um-directory-roles_can_search' => array( - 'label' => __( 'User Roles that can use search', 'ultimate-member' ), - 'value' => ! empty( $roles_can_search ) ? implode( ', ', $roles_can_search ) : $labels['all'], - ), - ) + $debug_info[] = array( + 'roles_can_search' => array( + 'label' => __( 'User Roles that can use search', 'ultimate-member' ), + 'value' => ! empty( $roles_can_search ) ? implode( ', ', $roles_can_search ) : $labels['all'], + ), ); + + if ( ! empty( get_post_meta( $directory_id, '_um_search_exclude_fields', true ) ) ) { + $debug_info[] = array( + 'search_exclude_fields' => array( + 'label' => __( 'Exclude fields from search', 'ultimate-member' ), + 'value' => get_post_meta( $directory_id, '_um_search_exclude_fields', true ), + ), + ); + } + + if ( ! empty( get_post_meta( $directory_id, '_um_search_include_fields', true ) ) ) { + $debug_info[] = array( + 'search_include_fields' => array( + 'label' => __( 'Fields to search by', 'ultimate-member' ), + 'value' => get_post_meta( $directory_id, '_um_search_include_fields', true ), + ), + ); + } } - $info[ 'ultimate-member-directory-' . $key ]['fields'] = array_merge( - $info[ 'ultimate-member-directory-' . $key ]['fields'], - array( - 'um-directory-filters' => array( - 'label' => __( 'Enable Filters feature', 'ultimate-member' ), - 'value' => get_post_meta( $key, '_um_filters', true ) ? $labels['yes'] : $labels['no'], - ), - ) + $debug_info[] = array( + 'filters' => array( + 'label' => __( 'Enable Filters feature', 'ultimate-member' ), + 'value' => get_post_meta( $directory_id, '_um_filters', true ) ? $labels['yes'] : $labels['no'], + ), ); - if ( 1 === absint( get_post_meta( $key, '_um_filters', true ) ) ) { - $directory_roles_can_filter_meta = get_post_meta( $key, '_um_roles_can_filter', true ); + if ( 1 === absint( get_post_meta( $directory_id, '_um_filters', true ) ) ) { + $directory_roles_can_filter_meta = get_post_meta( $directory_id, '_um_roles_can_filter', true ); $roles_can_filter = array(); if ( ! empty( $directory_roles_can_filter_meta ) ) { if ( is_string( $directory_roles_can_filter_meta ) ) { @@ -2450,124 +2697,224 @@ class Site_Health { } } - $info[ 'ultimate-member-directory-' . $key ]['fields'] = array_merge( - $info[ 'ultimate-member-directory-' . $key ]['fields'], - array( - 'um-directory-roles_can_filter' => array( - 'label' => __( 'User Roles that can use filters', 'ultimate-member' ), - 'value' => ! empty( $roles_can_filter ) ? implode( ', ', $roles_can_filter ) : $labels['all'], - ), - ) - ); - - $search_fields = get_post_meta( $key, '_um_search_fields', true ); - if ( ! empty( $search_fields ) && is_array( $search_fields ) ) { - foreach ( $search_fields as $k => $field ) { - $label = isset( $options[ $field ] ) ? $options[ $field ] : $field; - $info[ 'ultimate-member-directory-' . $key ]['fields'] = array_merge( - $info[ 'ultimate-member-directory-' . $key ]['fields'], - array( - 'um-directory-search_fields-' . $k => array( - 'label' => __( 'Filter meta to enable', 'ultimate-member' ), - 'value' => $label, - ), - ) - ); - } - } - } - - $info[ 'ultimate-member-directory-' . $key ]['fields'] = array_merge( - $info[ 'ultimate-member-directory-' . $key ]['fields'], - array( - 'um-directory-filters_expanded' => array( - 'label' => __( 'Expand the filter bar by default', 'ultimate-member' ), - 'value' => get_post_meta( $key, '_um_filters_expanded', true ) ? $labels['yes'] : $labels['no'], + $debug_info[] = array( + 'roles_can_filter' => array( + 'label' => __( 'User Roles that can use filters', 'ultimate-member' ), + 'value' => ! empty( $roles_can_filter ) ? implode( ', ', $roles_can_filter ) : $labels['all'], ), - ) - ); - - if ( 1 === absint( get_post_meta( $key, '_um_filters_expanded', true ) ) ) { - $info[ 'ultimate-member-directory-' . $key ]['fields'] = array_merge( - $info[ 'ultimate-member-directory-' . $key ]['fields'], - array( - 'um-directory-filters_is_collapsible' => array( - 'label' => __( 'Can filter bar be collapsed', 'ultimate-member' ), - 'value' => get_post_meta( $key, '_um_filters_is_collapsible', true ) ? $labels['yes'] : $labels['no'], - ), - ) ); - } - $search_filters = get_post_meta( $key, '_um_search_filters', true ); - if ( ! empty( $search_filters ) && is_array( $search_filters ) ) { - foreach ( $search_filters as $k => $field ) { - $label = isset( $options[ $k ] ) ? $options[ $k ] : $k; - $value = $field; - if ( is_array( $field ) ) { - $value = __( 'From ', 'ultimate-member' ) . $field[0] . __( ' to ', 'ultimate-member' ) . $field[1]; + $search_fields = get_post_meta( $directory_id, '_um_search_fields', true ); + if ( ! empty( $search_fields ) && is_array( $search_fields ) ) { + $field_labels = array(); + foreach ( $search_fields as $field ) { + $field_label = isset( $options[ $field ] ) ? $options[ $field ] : $field; + $field_labels[] = $field_label; } - $info[ 'ultimate-member-directory-' . $key ]['fields'] = array_merge( - $info[ 'ultimate-member-directory-' . $key ]['fields'], - array( - 'um-directory-search_filters-' . $k => array( - 'label' => __( 'Admin filtering', 'ultimate-member' ), - 'value' => $label . ' - ' . $value, - ), - ) + $debug_info[] = array( + 'search_fields-' . $directory_id => array( + 'label' => __( 'Filter meta to enable', 'ultimate-member' ), + 'value' => $field_labels, + ), + ); + } + + $debug_info[] = array( + 'filters_expanded' => array( + 'label' => __( 'Expand the filter bar by default', 'ultimate-member' ), + 'value' => get_post_meta( $directory_id, '_um_filters_expanded', true ) ? $labels['yes'] : $labels['no'], + ), + ); + + if ( 1 === absint( get_post_meta( $directory_id, '_um_filters_expanded', true ) ) ) { + $debug_info[] = array( + 'filters_is_collapsible' => array( + 'label' => __( 'Can filter bar be collapsed', 'ultimate-member' ), + 'value' => get_post_meta( $directory_id, '_um_filters_is_collapsible', true ) ? $labels['yes'] : $labels['no'], + ), ); } } - $info[ 'ultimate-member-directory-' . $key ]['fields'] = array_merge( - $info[ 'ultimate-member-directory-' . $key ]['fields'], - array( - 'um-directory-must_search' => array( - 'label' => __( 'Show results only after search/filtration', 'ultimate-member' ), - 'value' => get_post_meta( $key, '_um_must_search', true ) ? $labels['yes'] : $labels['no'], + $search_filters = get_post_meta( $directory_id, '_um_search_filters', true ); + if ( ! empty( $search_filters ) && is_array( $search_filters ) ) { + $field_labels = array(); + foreach ( $search_filters as $k => $field ) { + $field_label = isset( $options[ $k ] ) ? $options[ $k ] : $k; + $value = $field; + if ( is_array( $field ) ) { + if ( array_key_exists( $k, UM()->member_directory()->filter_types ) && in_array( UM()->member_directory()->filter_types[ $k ], array( 'datepicker', 'timepicker', 'slider' ), true ) ) { + // translators: %1$s is the "From" value, %2$s is the "To" value. + $value = sprintf( __( 'From %1$s; To %2$s', 'ultimate-member' ), $field[0], $field[1] ); + } else { + $value = implode( ', ', $field ); + } + } + $field_labels[] = $field_label . ' - ' . $value; + } + $debug_info[] = array( + 'search_filters-' . $directory_id => array( + 'label' => __( 'Admin filtering', 'ultimate-member' ), + 'value' => $field_labels, ), - 'um-directory-max_users' => array( - 'label' => __( 'Maximum number of profiles', 'ultimate-member' ), - 'value' => get_post_meta( $key, '_um_max_users', true ), - ), - 'um-directory-profiles_per_page' => array( - 'label' => __( 'Number of profiles per page', 'ultimate-member' ), - 'value' => get_post_meta( $key, '_um_profiles_per_page', true ), - ), - 'um-directory-profiles_per_page_mobile' => array( - 'label' => __( 'Maximum number of profiles', 'ultimate-member' ), - 'value' => get_post_meta( $key, '_um_profiles_per_page_mobile', true ), - ), - 'um-directory-directory_header' => array( - 'label' => __( 'Results Text', 'ultimate-member' ), - 'value' => get_post_meta( $key, '_um_directory_header', true ), - ), - 'um-directory-directory_header_single' => array( - 'label' => __( 'Single Result Text', 'ultimate-member' ), - 'value' => get_post_meta( $key, '_um_directory_header_single', true ), - ), - 'um-directory-directory_no_users' => array( - 'label' => __( 'Custom text if no users were found', 'ultimate-member' ), - 'value' => get_post_meta( $key, '_um_directory_no_users', true ), - ), - ) + ); + } + + $debug_info[] = array( + 'show_profile_photo' => array( + 'label' => __( 'Enable Profile Photo', 'ultimate-member' ), + 'value' => get_post_meta( $directory_id, '_um_profile_photo', true ) ? $labels['yes'] : $labels['no'], + ), + 'show_cover_photos' => array( + 'label' => __( 'Enable Cover Photo', 'ultimate-member' ), + 'value' => get_post_meta( $directory_id, '_um_cover_photos', true ) ? $labels['yes'] : $labels['no'], + ), + 'show_display_name' => array( + 'label' => __( 'Show display name', 'ultimate-member' ), + 'value' => get_post_meta( $directory_id, '_um_show_name', true ) ? $labels['yes'] : $labels['no'], + ), ); - $info = apply_filters( 'um_debug_member_directory_extend', $info, $key ); + /** + * Filters member directory profile card settings for Site Health. + * + * @since 2.10.5 + * @hook um_debug_member_directory_profile_extend + * + * @param {array} $info Member directory settings for Site Health. + * @param {string} $directory_id Member directory ID. + * + * @return {array} Member directory settings for Site Health. + * + * @example Extend Member directory settings for Site Health. + * function um_debug_member_directory_profile_extend( $info, $directory_id ) { + * // your code here + * return $info; + * } + * add_filter( 'um_debug_member_directory_profile_extend', 'um_debug_member_directory_profile_extend', 10, 2 ); + */ + $debug_info = apply_filters( 'um_debug_member_directory_profile_extend', $debug_info, $directory_id ); + + $debug_info[] = array( + 'show_tagline' => array( + 'label' => __( 'Show tagline below profile name', 'ultimate-member' ), + 'value' => get_post_meta( $directory_id, '_um_show_tagline', true ) ? $labels['yes'] : $labels['no'], + ), + ); + + if ( 1 === absint( get_post_meta( $directory_id, '_um_show_tagline', true ) ) ) { + $tagline_fields = get_post_meta( $directory_id, '_um_tagline_fields', true ); + if ( ! empty( $tagline_fields ) && is_array( $tagline_fields ) ) { + $field_labels = array(); + foreach ( $tagline_fields as $field ) { + $label = isset( $options[ $field ] ) ? $options[ $field ] : $field; + $field_labels[] = $label; + } + + $debug_info[] = array( + 'tagline_fields-' . $directory_id => array( + 'label' => __( 'Field to display in tagline', 'ultimate-member' ), + 'value' => $field_labels, + ), + ); + } + } + + $debug_info[] = array( + 'show_userinfo' => array( + 'label' => __( 'Show extra user information below tagline?', 'ultimate-member' ), + 'value' => get_post_meta( $directory_id, '_um_show_userinfo', true ) ? $labels['yes'] : $labels['no'], + ), + ); + + if ( 1 === absint( get_post_meta( $directory_id, '_um_show_userinfo', true ) ) ) { + $reveal_fields = get_post_meta( $directory_id, '_um_reveal_fields', true ); + if ( ! empty( $reveal_fields ) && is_array( $reveal_fields ) ) { + $field_labels = array(); + foreach ( $reveal_fields as $field ) { + $label = isset( $options[ $field ] ) ? $options[ $field ] : $field; + $field_labels[] = $label; + } + + $debug_info[] = array( + 'reveal_fields-' . $directory_id => array( + 'label' => __( 'Field to display in extra user information section', 'ultimate-member' ), + 'value' => $field_labels, + ), + ); + } + } + + $debug_info[] = array( + 'show_social' => array( + 'label' => __( 'Show social connect icons in extra user information section', 'ultimate-member' ), + 'value' => get_post_meta( $directory_id, '_um_show_social', true ) ? $labels['yes'] : $labels['no'], + ), + 'userinfo_animate' => array( + 'label' => __( 'Hide extra user information to the reveal section', 'ultimate-member' ), + 'value' => get_post_meta( $directory_id, '_um_userinfo_animate', true ) ? $labels['yes'] : $labels['no'], + ), + 'must_search' => array( + 'label' => __( 'Show results only after search/filtration', 'ultimate-member' ), + 'value' => get_post_meta( $directory_id, '_um_must_search', true ) ? $labels['yes'] : $labels['no'], + ), + 'max_users' => array( + 'label' => __( 'Maximum number of profiles', 'ultimate-member' ), + 'value' => get_post_meta( $directory_id, '_um_max_users', true ), + ), + 'profiles_per_page' => array( + 'label' => __( 'Number of profiles per page', 'ultimate-member' ), + 'value' => get_post_meta( $directory_id, '_um_profiles_per_page', true ), + ), + 'profiles_per_page_mobile' => array( + 'label' => __( 'Maximum number of profiles', 'ultimate-member' ), + 'value' => get_post_meta( $directory_id, '_um_profiles_per_page_mobile', true ), + ), + 'header' => array( + 'label' => __( 'Results Text', 'ultimate-member' ), + 'value' => get_post_meta( $directory_id, '_um_directory_header', true ), + ), + 'header_single' => array( + 'label' => __( 'Single Result Text', 'ultimate-member' ), + 'value' => get_post_meta( $directory_id, '_um_directory_header_single', true ), + ), + 'no_users_text' => array( + 'label' => __( 'Custom text if no users were found', 'ultimate-member' ), + 'value' => get_post_meta( $directory_id, '_um_directory_no_users', true ), + ), + ); + + /** + * Filters member directory settings for Site Health. + * + * @since 2.10.5 + * @hook um_debug_member_directory_extend + * + * @param {array} $info Member directory settings for Site Health. + * @param {string} $directory_id Member directory ID. + * + * @return {array} Member directory settings for Site Health. + * + * @example Extend Member directory settings for Site Health. + * function um_debug_member_directory_extend( $info, $directory_id ) { + * // your code here + * return $info; + * } + * add_filter( 'um_debug_member_directory_extend', 'um_debug_member_directory_extend', 10, 2 ); + */ + $debug_info = apply_filters( 'um_debug_member_directory_extend', $debug_info, $directory_id ); + + $debug_info = array_merge( ...$debug_info ); + + $info[ 'ultimate-member-directory-' . $directory_id ] = array( + // translators: %s is the member directory title. + 'label' => sprintf( __( ' - Member directory "%s" settings', 'ultimate-member' ), get_the_title( $directory_id ) ), + 'description' => __( 'This debug information for your Ultimate Member directory.', 'ultimate-member' ), + 'fields' => $debug_info, + ); } } - /** - * Filters the site health information. - * - * @hook um_site_health_extend - * - * @since 2.10.3 - * - * @param {array} $info The site health info to be filtered. - * - * @return {array} The filtered site health info. - */ - return apply_filters( 'um_site_health_extend', $info ); + return $info; } } diff --git a/includes/admin/core/class-admin-settings.php b/includes/admin/core/class-admin-settings.php index bdef709a..9821763c 100644 --- a/includes/admin/core/class-admin-settings.php +++ b/includes/admin/core/class-admin-settings.php @@ -1403,6 +1403,7 @@ if ( ! class_exists( 'um\admin\core\Admin_Settings' ) ) { 'args' => array( 'textarea_rows' => 6, ), + 'conditional' => array( 'account_tab_delete', '=', '1' ), ), array( 'id' => 'delete_account_no_pass_required_text', @@ -1412,6 +1413,7 @@ if ( ! class_exists( 'um\admin\core\Admin_Settings' ) ) { 'args' => array( 'textarea_rows' => 6, ), + 'conditional' => array( 'account_tab_delete', '=', '1' ), ), ), ), diff --git a/includes/core/class-profile.php b/includes/core/class-profile.php index ad5d9d64..044f4294 100644 --- a/includes/core/class-profile.php +++ b/includes/core/class-profile.php @@ -103,7 +103,24 @@ if ( ! class_exists( 'um\core\Profile' ) ) { * @return array */ public function tabs_privacy() { - $privacy = apply_filters( + /** + * Filters a privacy list extend. + * + * @since 2.7.0 + * @hook um_profile_tabs_privacy_list + * + * @param {array} $privacy_option Add options for profile tabs' privacy. + * + * @return {array} Options for profile tabs' privacy. + * + * @example Add options for profile tabs' privacy. + * function um_profile_menu_link_attrs( $privacy_option ) { + * // your code here + * return $privacy_option; + * } + * add_filter( 'um_profile_tabs_privacy_list', 'um_profile_tabs_privacy_list', 10, 1 ); + */ + return apply_filters( 'um_profile_tabs_privacy_list', array( 0 => __( 'Anyone', 'ultimate-member' ), @@ -114,53 +131,46 @@ if ( ! class_exists( 'um\core\Profile' ) ) { 5 => __( 'Owner and specific roles', 'ultimate-member' ), ) ); - - return $privacy; } - /** * All tab data * * @return array */ - function tabs() { - - /** - * UM hook - * - * @type filter - * @title um_profile_tabs - * @description Extend user profile tabs - * @input_vars - * [{"var":"$tabs","type":"array","desc":"Profile tabs"}] - * @change_log - * ["Since: 2.0"] - * @usage - * - * @example - * - */ - $tabs = apply_filters( 'um_profile_tabs', array( - 'main' => array( + public function tabs() { + $tabs = array( + 'main' => array( 'name' => __( 'About', 'ultimate-member' ), - 'icon' => 'um-faicon-user' + 'icon' => 'um-faicon-user', ), - 'posts' => array( + 'posts' => array( 'name' => __( 'Posts', 'ultimate-member' ), - 'icon' => 'um-faicon-pencil' + 'icon' => 'um-faicon-pencil', ), 'comments' => array( 'name' => __( 'Comments', 'ultimate-member' ), - 'icon' => 'um-faicon-comment' - ) - ) ); + 'icon' => 'um-faicon-comment', + ), + ); + /** + * Filters user profile tabs + * + * @since 1.3.x + * @hook um_profile_tabs + * + * @param {array} $tabs tabs list. + * + * @return {array} tabs list. + * + * @example Add user profile tabs. + * function um_profile_tabs( $tabs ) { + * // your code here + * return $tabs; + * } + * add_filter( 'um_profile_tabs', 'um_profile_tabs' ); + */ + $tabs = apply_filters( 'um_profile_tabs', $tabs ); // disable private tabs if ( ! is_admin() ) {