Mini Shell

Direktori : /home/brasafestival/www/old/wp-content/plugins/advanced-custom-fields/includes/admin/
Upload File :
Current File : /home/brasafestival/www/old/wp-content/plugins/advanced-custom-fields/includes/admin/admin-notices.php

<?php
/**
 * ACF Admin Notices
 *
 * Functions and classes to manage admin notices.
 *
 * @date    10/1/19
 * @since   5.7.10
 */

// Exit if accessed directly.
if ( ! defined( 'ABSPATH' ) ) {
	exit;
}

// Register notices store.
acf_register_store( 'notices' );

/**
 * ACF_Admin_Notice
 *
 * Class used to create an admin notice.
 *
 * @date    10/1/19
 * @since   5.7.10
 */
if ( ! class_exists( 'ACF_Admin_Notice' ) ) :

	class ACF_Admin_Notice extends ACF_Data {

		/** @var array Storage for data. */
		var $data = array(

			/** @type string Text displayed in notice. */
			'text'        => '',

			/** @type string The type of notice (warning, error, success, info). */
			'type'        => 'info',

			/** @type bool If the notice can be dismissed. */
			'dismissible' => true,
		);

		/**
		 *  render
		 *
		 *  Renders the notice HTML.
		 *
		 *  @date    27/12/18
		 *  @since   5.8.0
		 *
		 *  @param   void
		 *  @return  void
		 */
		function render() {
			$notice_text    = $this->get( 'text' );
			$notice_type    = $this->get( 'type' );
			$is_dismissible = $this->get( 'dismissible' );

			printf(
				'<div class="acf-admin-notice notice notice-%s %s">%s</div>',
				esc_attr( $notice_type ),
				$is_dismissible ? 'is-dismissible' : '',
				acf_esc_html( wpautop( acf_punctify( $notice_text ) ) )
			);
		}
	}

endif; // class_exists check

/**
 *  acf_new_admin_notice
 *
 *  Instantiates and returns a new model.
 *
 *  @date    23/12/18
 *  @since   5.8.0
 *
 *  @param   array $data Optional data to set.
 *  @return  ACF_Admin_Notice
 */
function acf_new_admin_notice( $data = false ) {

	// Create notice.
	$instance = new ACF_Admin_Notice( $data );

	// Register notice.
	acf_get_store( 'notices' )->set( $instance->cid, $instance );

	// Return notice.
	return $instance;
}

/**
 * acf_render_admin_notices
 *
 * Renders all admin notices HTML.
 *
 * @date    10/1/19
 * @since   5.7.10
 *
 * @param   void
 * @return  void
 */
function acf_render_admin_notices() {

	// Get notices.
	$notices = acf_get_store( 'notices' )->get_data();

	// Loop over notices and render.
	if ( $notices ) {
		foreach ( $notices as $notice ) {
			$notice->render();
		}
	}
}

// Render notices during admin action.
add_action( 'admin_notices', 'acf_render_admin_notices', 99 );

/**
 * acf_add_admin_notice
 *
 * Creates and returns a new notice.
 *
 * @date        17/10/13
 * @since       5.0.0
 *
 * @param   string $text The admin notice text.
 * @param   string $class The type of notice (warning, error, success, info).
 * @param   string $dismissable Is this notification dismissible (default true) (since 5.11.0)
 * @return  ACF_Admin_Notice
 */
function acf_add_admin_notice( $text = '', $type = 'info', $dismissible = true ) {
	return acf_new_admin_notice(
		array(
			'text'        => $text,
			'type'        => $type,
			'dismissible' => $dismissible,
		)
	);
}

Zerion Mini Shell 1.0