__CLASS__ . '::form', // change it to user_registration_form. 'user_registration_my_account' => __CLASS__ . '::my_account', 'user_registration_login' => __CLASS__ . '::login', 'user_registration_lost_password' => __CLASS__ . '::lost_password', 'user_registration_edit_profile' => __CLASS__ . '::edit_profile', 'user_registration_edit_password' => __CLASS__ . '::edit_password', ); add_filter( 'pre_do_shortcode_tag', array( UR_Shortcode_My_Account::class, 'pre_do_shortcode_tag' ), 10, 4 ); // phpcs:ignore foreach ( $shortcodes as $shortcode => $function ) { /** * Applies filters to customize User Registration shortcode tags. * * The "{$shortcode}_shortcode_tag" filters allow developers to modify default shortcode tags * for User Registration shortcodes like 'user_registration_form', 'user_registration_my_account', etc. */ add_shortcode( apply_filters( "{$shortcode}_shortcode_tag", $shortcode ), $function ); } } /** * Shortcode Wrapper. * * @param string[] $function Callback function. * @param array $atts (default: array()) Extra attributes. * @param array $wrapper Shortcode wrapper. * * @return string */ public static function shortcode_wrapper( $function, $atts = array(), $wrapper = array( 'class' => 'user-registration', 'before' => null, 'after' => null, ) ) { ob_start(); include_once UR_ABSPATH . 'includes/functions-ur-notice.php'; $wrap_before = empty( $wrapper['before'] ) ? '
' . __( 'Only administrators can add new users.', 'user-registration' ) . '
' ); } } else { /** * Applies a filter to customize the capability required for user registration. * * @param string $default_capability Default user capability. */ $current_user_capability = apply_filters( 'ur_registration_user_capability', 'create_users' ); if ( ! current_user_can( $current_user_capability ) ) { global $wp; $user_ID = get_current_user_id(); $user = get_user_by( 'ID', $user_ID ); $current_url = home_url( add_query_arg( array(), $wp->request ) ); $display_name = ! empty( $user->data->display_name ) ? $user->data->display_name : $user->data->user_email; /** * Applies a filter to customize the pre-form message for user registration. * * @param string $default_message Default pre-form message. */ /* translators: 1: Link and username of user 2: Logout url */ return apply_filters( 'ur_register_pre_form_message', '' . sprintf( __( 'You are currently logged in as %1$1s. %2$2s', 'user-registration' ), '' . esc_html( $display_name ) . '', '' . __( 'Logout', 'user-registration' ) . ' »' ) . '
', $user_ID ); } } $atts = shortcode_atts( array( 'id' => '', ), $atts, 'user_registration_form' ); /** * Fires when rendering scripts for the 'user_registration_form' shortcode. * * The 'user_registration_form_shortcode_scripts' action allows developers * to enqueue custom scripts or perform actions related to the 'user_registration_form' shortcode. * * @param array $atts Shortcode attributes passed for customization. */ do_action( 'user_registration_form_shortcode_scripts', $atts ); ob_start(); self::render_form( $atts['id'] ); return ob_get_clean(); } /** * Output for registration form . * * @param int $form_id Form ID. * @since 1.0.1 Recaptcha only */ private static function render_form( $form_id ) { $form_data_array = ( $form_id ) ? UR()->form->get_form( $form_id, array( 'content_only' => true ) ) : array(); $form_json_data = wp_json_encode( $form_data_array ); $values = array( 'form_id' => $form_id, ); /** * Applies a filter to process smart tags in the User Registration content. * * @param string $default_content Default content before processing smart tags. * @param mixed $form_json_data Form JSON data. * @param array $values User input values. */ $content = apply_filters( 'user_registration_process_smart_tags', $form_json_data, $values, array() ); $form_data_array = json_decode( $content ); $form_row_ids = ''; $form_row_data = array(); if ( ! empty( $form_data_array ) ) { $form_row_ids = get_post_meta( $form_id, 'user_registration_form_row_ids', true ); $form_row_data = get_post_meta( $form_id, 'user_registration_form_row_data', true ); } $form_row_ids_array = json_decode( $form_row_ids ); if ( gettype( $form_row_ids_array ) != 'array' ) { $form_row_ids_array = array(); } $is_field_exists = false; $enable_strong_password = ur_string_to_bool( ur_get_single_post_meta( $form_id, 'user_registration_form_setting_enable_strong_password' ) ); $minimum_password_strength = ur_get_single_post_meta( $form_id, 'user_registration_form_setting_minimum_password_strength' ); // Enqueue script. wp_enqueue_script( 'user-registration' ); wp_enqueue_script( 'ur-form-validator' ); wp_enqueue_script( 'ur-common' ); /** * Fires when enqueueing scripts for the User Registration plugin. * * The 'user_registration_enqueue_scripts' action allows developers to enqueue * custom scripts or perform actions related to User Registration, specifically * for a given registration form identified by $form_id. * * @param array $form_data_array Data array for the specific registration form. * @param int $form_id ID of the associated registration form. */ do_action( 'user_registration_enqueue_scripts', $form_data_array, $form_id ); $has_flatpickr = ur_has_flatpickr_field( $form_id ); if ( true === $has_flatpickr ) { wp_enqueue_style( 'flatpickr' ); wp_enqueue_script( 'flatpickr' ); } if ( $enable_strong_password ) { wp_enqueue_script( 'ur-password-strength-meter' ); } $recaptcha_enabled = ur_string_to_bool( ur_get_form_setting_by_key( $form_id, 'user_registration_form_setting_enable_recaptcha_support', false ) ); $recaptcha_node = ur_get_recaptcha_node( 'register', $recaptcha_enabled, $form_id ); /** * Applies a filter before rendering the User Registration registration form template. * * @param array $default_form_data_array Default form data array. * @param int $form_id ID of the registration form. */ $form_data_array = apply_filters( 'user_registration_before_registration_form_template', $form_data_array, $form_id ); /** Allow filter to return early if some condition is not meet. * * @since 4.1.0 */ if ( ! apply_filters( 'user_registration_frontend_before_load', true, $form_data_array, $form_id ) ) { /** * Fires when User Registration frontend form are not loaded. * * @param array $form_data_array Data array for the specific registration form. * @param int $form_id ID of the associated registration form. */ do_action( 'user_registration_frontend_not_loaded', $form_data_array, $form_id ); return; } /** * Applies a filter to customize User Registration parts data. * * The 'user_registration_parts_data' filter allows developers to modify * the parts data before processing it in the User Registration class. * * @param array $default_parts_data Default parts data. * @param int $form_id ID of the registration form. * @param array $form_data_array Form data array. */ self::$parts = apply_filters( 'user_registration_parts_data', self::$parts, $form_id, $form_data_array ); include_once UR_ABSPATH . 'includes/frontend/class-ur-frontend.php'; ur_get_template( 'form-registration.php', array( 'form_data_array' => $form_data_array, 'is_field_exists' => $is_field_exists, 'form_id' => $form_id, 'enable_strong_password' => $enable_strong_password, 'minimum_password_strength' => $minimum_password_strength, 'recaptcha_node' => $recaptcha_node, 'parts' => self::$parts, 'row_ids' => $form_row_ids_array, 'form_row_data' => $form_row_data, 'recaptcha_enabled' => $recaptcha_enabled, ) ); } /** * Check the redirection url is valid url or slug. * * @param string $redirect_url redirection url. */ public static function check_is_valid_redirect_url( $redirect_url ) { if ( filter_var( $redirect_url, FILTER_VALIDATE_URL ) === false ) { $all_page_slug = ur_get_all_page_slugs(); if ( in_array( $redirect_url, $all_page_slug, true ) ) { $redirect_url = site_url( $redirect_url ); } elseif ( '' === $redirect_url ) { $redirect_url; } else { $redirect_url = home_url(); } } return $redirect_url; } }