123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389 |
- <?php
- if ( ! defined( 'ABSPATH' ) ) {
- exit; // Exit if accessed directly
- }
- if ( ! class_exists( 'ACF_Form_User' ) ) :
- class ACF_Form_User {
- /** @var string The current view (new, edit, register) */
- var $view = '';
- /*
- * __construct
- *
- * This function will setup the class functionality
- *
- * @type function
- * @date 5/03/2014
- * @since 5.0.0
- *
- * @param n/a
- * @return n/a
- */
- function __construct() {
- // enqueue
- add_action( 'admin_enqueue_scripts', array( $this, 'admin_enqueue_scripts' ) );
- add_action( 'login_form_register', array( $this, 'login_form_register' ) );
- // render
- add_action( 'show_user_profile', array( $this, 'render_edit' ) );
- add_action( 'edit_user_profile', array( $this, 'render_edit' ) );
- add_action( 'user_new_form', array( $this, 'render_new' ) );
- add_action( 'register_form', array( $this, 'render_register' ) );
- // save
- add_action( 'user_register', array( $this, 'save_user' ) );
- add_action( 'profile_update', array( $this, 'save_user' ) );
- // Perform validation before new user is registered.
- add_filter( 'registration_errors', array( $this, 'filter_registration_errors' ), 10, 3 );
- }
- /**
- * admin_enqueue_scripts
- *
- * Checks current screen and enqueues scripts
- *
- * @date 17/4/18
- * @since 5.6.9
- *
- * @param void
- * @return void
- */
- function admin_enqueue_scripts() {
- // bail early if not valid screen
- if ( ! acf_is_screen( array( 'profile', 'user', 'user-edit' ) ) ) {
- return;
- }
- // enqueue
- acf_enqueue_scripts();
- }
- /**
- * login_form_register
- *
- * Customizes and enqueues scripts
- *
- * @date 17/4/18
- * @since 5.6.9
- *
- * @param void
- * @return void
- */
- function login_form_register() {
- // customize action prefix so that "admin_head" = "login_head"
- acf_enqueue_scripts(
- array(
- 'context' => 'login',
- )
- );
- }
- /*
- * register_user
- *
- * Called during the user register form
- *
- * @type function
- * @date 8/10/13
- * @since 5.0.0
- *
- * @param void
- * @return void
- */
- function render_register() {
- // render
- $this->render(
- array(
- 'user_id' => 0,
- 'view' => 'register',
- 'el' => 'div',
- )
- );
- }
- /*
- * render_edit
- *
- * Called during the user edit form
- *
- * @type function
- * @date 8/10/13
- * @since 5.0.0
- *
- * @param void
- * @return void
- */
- function render_edit( $user ) {
- // add compatibility with front-end user profile edit forms such as bbPress
- if ( ! is_admin() ) {
- acf_enqueue_scripts();
- }
- // render
- $this->render(
- array(
- 'user_id' => $user->ID,
- 'view' => 'edit',
- 'el' => 'tr',
- )
- );
- }
- /*
- * user_new_form
- *
- * description
- *
- * @type function
- * @date 8/10/13
- * @since 5.0.0
- *
- * @param $post_id (int)
- * @return $post_id (int)
- */
- function render_new() {
- // Multisite uses a different 'user-new.php' form. Don't render fields here
- if ( is_multisite() ) {
- return;
- }
- // render
- $this->render(
- array(
- 'user_id' => 0,
- 'view' => 'add',
- 'el' => 'tr',
- )
- );
- }
- /*
- * render
- *
- * This function will render ACF fields for a given $post_id parameter
- *
- * @type function
- * @date 7/10/13
- * @since 5.0.0
- *
- * @param $user_id (int) this can be set to 0 for a new user
- * @param $user_form (string) used for location rule matching. edit | add | register
- * @param $el (string)
- * @return n/a
- */
- function render( $args = array() ) {
- // Allow $_POST data to persist across form submission attempts.
- if ( isset( $_POST['acf'] ) ) { // phpcs:ignore WordPress.Security.NonceVerification.Missing
- add_filter( 'acf/pre_load_value', array( $this, 'filter_pre_load_value' ), 10, 3 );
- }
- // defaults
- $args = wp_parse_args(
- $args,
- array(
- 'user_id' => 0,
- 'view' => 'edit',
- 'el' => 'tr',
- )
- );
- // vars
- $post_id = 'user_' . $args['user_id'];
- // get field groups
- $field_groups = acf_get_field_groups(
- array(
- 'user_id' => $args['user_id'] ? $args['user_id'] : 'new',
- 'user_form' => $args['view'],
- )
- );
- // bail early if no field groups
- if ( empty( $field_groups ) ) {
- return;
- }
- // form data
- acf_form_data(
- array(
- 'screen' => 'user',
- 'post_id' => $post_id,
- 'validation' => ( $args['view'] == 'register' ) ? 0 : 1,
- )
- );
- // elements
- $before = '<table class="form-table"><tbody>';
- $after = '</tbody></table>';
- if ( $args['el'] == 'div' ) {
- $before = '<div class="acf-user-' . $args['view'] . '-fields acf-fields -clear">';
- $after = '</div>';
- }
- // loop
- foreach ( $field_groups as $field_group ) {
- // vars
- $fields = acf_get_fields( $field_group );
- // title
- if ( $field_group['style'] === 'default' ) {
- echo '<h2>' . $field_group['title'] . '</h2>';
- }
- // render
- echo $before;
- acf_render_fields( $fields, $post_id, $args['el'], $field_group['instruction_placement'] );
- echo $after;
- }
- // actions
- add_action( 'acf/input/admin_footer', array( $this, 'admin_footer' ), 10, 1 );
- }
- /*
- * admin_footer
- *
- * description
- *
- * @type function
- * @date 27/03/2015
- * @since 5.1.5
- *
- * @param $post_id (int)
- * @return $post_id (int)
- */
- function admin_footer() {
- // script
- ?>
- <script type="text/javascript">
- (function($) {
-
- // vars
- var view = '<?php echo $this->view; ?>';
-
- // add missing spinners
- var $submit = $('input.button-primary');
- if( !$submit.next('.spinner').length ) {
- $submit.after('<span class="spinner"></span>');
- }
-
- })(jQuery);
- </script>
- <?php
- }
- /*
- * save_user
- *
- * description
- *
- * @type function
- * @date 8/10/13
- * @since 5.0.0
- *
- * @param $post_id (int)
- * @return $post_id (int)
- */
- function save_user( $user_id ) {
- // verify nonce
- if ( ! acf_verify_nonce( 'user' ) ) {
- return $user_id;
- }
- // save
- if ( acf_validate_save_post( true ) ) {
- acf_save_post( "user_$user_id" );
- }
- }
- /**
- * filter_registration_errors
- *
- * Validates $_POST data and appends any errors to prevent new user registration.
- *
- * @date 12/7/19
- * @since 5.8.1
- *
- * @param WP_Error $errors A WP_Error object containing any errors encountered during registration.
- * @param string $sanitized_user_login User's username after it has been sanitized.
- * @param string $user_email User's email.
- * @return WP_Error
- */
- function filter_registration_errors( $errors, $sanitized_user_login, $user_email ) {
- if ( ! acf_validate_save_post() ) {
- $acf_errors = acf_get_validation_errors();
- foreach ( $acf_errors as $acf_error ) {
- $errors->add(
- acf_idify( $acf_error['input'] ),
- acf_esc_html( acf_punctify( sprintf( __( '<strong>Error</strong>: %s', 'acf' ), $acf_error['message'] ) ) )
- );
- }
- }
- return $errors;
- }
- /**
- * filter_pre_load_value
- *
- * Checks if a $_POST value exists for this field to allow persistent values.
- *
- * @date 12/7/19
- * @since 5.8.2
- *
- * @param null $null A null placeholder.
- * @param (int|string) $post_id The post id.
- * @param array $field The field array.
- * @return mixed
- */
- function filter_pre_load_value( $null, $post_id, $field ) {
- $field_key = $field['key'];
- // phpcs:disable WordPress.Security.NonceVerification.Missing -- Verified in save_user().
- if ( isset( $_POST['acf'][ $field_key ] ) ) {
- return $_POST['acf'][ $field_key ]; // phpcs:ignore WordPress.Security.ValidatedSanitizedInput.InputNotSanitized -- Sanitized elsewhere.
- }
- // phpcs:enable WordPress.Security.NonceVerification.Missing
- return $null;
- }
- }
- // instantiate
- acf_new_instance( 'ACF_Form_User' );
- endif; // class_exists check
- ?>
|