'', /** @type string The type of notice (warning, error, success, info). */ 'type' => 'info', /** @type bool If the notice can be dismissed. */ 'dismissible' => true, /** @type bool If the dismissed state should be persisted to ACF user preferences. */ 'persisted' => false, ); /** * 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' ); $is_persisted = $this->get( 'persisted' ); printf( '
%s
', esc_attr( $notice_type ), $is_dismissible ? 'is-dismissible' : '', $is_persisted ? 'true' : 'false', esc_attr( md5( $notice_text ) ), 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 boolean $dismissable Is this notification dismissible (default true) (since 5.11.0) * @param boolean $persisted Store once a notice has been dismissed per user and prevent showing it again. (since 6.1.0) * @return ACF_Admin_Notice */ function acf_add_admin_notice( $text = '', $type = 'info', $dismissible = true, $persisted = false ) { return acf_new_admin_notice( array( 'text' => $text, 'type' => $type, 'dismissible' => $dismissible, 'persisted' => $persisted, ) ); }