ACF_Form_User{}ACF 1.0

Хуков нет.

Использование

$ACF_Form_User = new ACF_Form_User();
// use class methods

Методы

  1. public __construct()
  2. public admin_enqueue_scripts()
  3. public admin_footer()
  4. public filter_pre_load_value( $null, $post_id, $field )
  5. public filter_registration_errors( $errors, $sanitized_user_login, $user_email )
  6. public login_form_register()
  7. public render( $args = array() )
  8. public render_edit( $user )
  9. public render_new()
  10. public render_register()
  11. public save_user( $user_id )

Код ACF_Form_User{} ACF 6.0.4

<?php
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;
	}
}