File "admin-notices.php"

Full Path: /home/vantageo/public_html/cache/cache/cache/cache/cache/cache/cache/cache/cache/.wp-cli/wp-content/plugins/advanced-custom-fields-pro/includes/admin/admin-notices.php
File size: 2.77 KB
MIME-type: text/x-php
Charset: utf-8

<?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 Optional HTML alternative to text. 
		'html' => '', */
		
		/** @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() {
		
		// Ensure text contains punctuation.
		// todo: Remove this after updating translations.
		$text = $this->get('text');
		if( substr($text, -1) !== '.' && substr($text, -1) !== '>' ) {
			$text .= '.';
		} 
		
		// Print HTML.
		printf('<div class="acf-admin-notice notice notice-%s %s">%s</div>',
			
			// Type class.
			$this->get('type'),
			
			// Dismissible class.
			$this->get('dismissible') ? 'is-dismissible' : '',
			
			// InnerHTML
			$this->has('html') ? $this->get('html') : wpautop($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).
 * @return	ACF_Admin_Notice
 */
function acf_add_admin_notice( $text = '', $type = 'info' ) {
	return acf_new_admin_notice( array( 'text' => $text, 'type' => $type ) );
}