85 lines
		
	
	
		
			1.9 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			85 lines
		
	
	
		
			1.9 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
<?php
 | 
						|
/**
 | 
						|
 * Bootstraps the CMB2 process
 | 
						|
 *
 | 
						|
 * @category  WordPress_Plugin
 | 
						|
 * @package   CMB2
 | 
						|
 * @author    CMB2
 | 
						|
 * @license   GPL-2.0+
 | 
						|
 * @link      https://cmb2.io
 | 
						|
 */
 | 
						|
 | 
						|
/**
 | 
						|
 * Function to encapsulate the CMB2 bootstrap process.
 | 
						|
 *
 | 
						|
 * @since  2.2.0
 | 
						|
 * @return void
 | 
						|
 */
 | 
						|
function cmb2_bootstrap() {
 | 
						|
 | 
						|
	if ( is_admin() ) {
 | 
						|
		/**
 | 
						|
		 * Fires on the admin side when CMB2 is included/loaded.
 | 
						|
		 *
 | 
						|
		 * In most cases, this should be used to add metaboxes. See example-functions.php
 | 
						|
		 */
 | 
						|
		do_action( 'cmb2_admin_init' );
 | 
						|
	}
 | 
						|
 | 
						|
	/**
 | 
						|
	 * Fires when CMB2 is included/loaded
 | 
						|
	 *
 | 
						|
	 * Can be used to add metaboxes if needed on the front-end or WP-API (or the front and backend).
 | 
						|
	 */
 | 
						|
	do_action( 'cmb2_init' );
 | 
						|
 | 
						|
	/**
 | 
						|
	 * For back-compat. Does the dirty-work of instantiating all the
 | 
						|
	 * CMB2 instances for the cmb2_meta_boxes filter
 | 
						|
	 *
 | 
						|
	 * @since  2.0.2
 | 
						|
	 */
 | 
						|
	$cmb_config_arrays = apply_filters( 'cmb2_meta_boxes', array() );
 | 
						|
	foreach ( (array) $cmb_config_arrays as $cmb_config ) {
 | 
						|
		new CMB2( $cmb_config );
 | 
						|
	}
 | 
						|
 | 
						|
	/**
 | 
						|
	 * Fires after all CMB2 instances are created
 | 
						|
	 */
 | 
						|
	do_action( 'cmb2_init_before_hookup' );
 | 
						|
 | 
						|
	/**
 | 
						|
	 * Get all created metaboxes, and instantiate CMB2_Hookup
 | 
						|
	 * on metaboxes which require it.
 | 
						|
	 *
 | 
						|
	 * @since  2.0.2
 | 
						|
	 */
 | 
						|
	foreach ( CMB2_Boxes::get_all() as $cmb ) {
 | 
						|
 | 
						|
		/**
 | 
						|
		 * Initiates the box "hookup" into WordPress.
 | 
						|
		 *
 | 
						|
		 * Unless the 'hookup' box property is `false`, the box will be hooked in as
 | 
						|
		 * a post/user/comment/option/term box.
 | 
						|
		 *
 | 
						|
		 * And if the 'show_in_rest' box property is set, the box will be hooked
 | 
						|
		 * into the CMB2 REST API.
 | 
						|
		 *
 | 
						|
		 * The dynamic portion of the hook name, $cmb->cmb_id, is the box id.
 | 
						|
		 *
 | 
						|
		 * @since 2.2.6
 | 
						|
		 *
 | 
						|
		 * @param array $cmb The CMB2 object to hookup.
 | 
						|
		 */
 | 
						|
		do_action( "cmb2_init_hookup_{$cmb->cmb_id}", $cmb );
 | 
						|
	}
 | 
						|
 | 
						|
	/**
 | 
						|
	 * Fires after CMB2 initiation process has been completed
 | 
						|
	 */
 | 
						|
	do_action( 'cmb2_after_init' );
 | 
						|
}
 | 
						|
 | 
						|
/* End. That's it, folks! */
 |