'', /** @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( '
%s
', 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). * @return ACF_Admin_Notice */ function acf_add_admin_notice( $text = '', $type = 'info' ) { return acf_new_admin_notice( array( 'text' => $text, 'type' => $type, ) ); }