73 lines
		
	
	
		
			2.1 KiB
		
	
	
	
		
			PHP
		
	
	
		
			Executable File
		
	
	
	
	
			
		
		
	
	
			73 lines
		
	
	
		
			2.1 KiB
		
	
	
	
		
			PHP
		
	
	
		
			Executable File
		
	
	
	
	
| <?php
 | |
| /**
 | |
|  * Kadence\Entry_Title\Component class
 | |
|  *
 | |
|  * @package kadence
 | |
|  */
 | |
| 
 | |
| namespace Kadence\Entry_Title;
 | |
| 
 | |
| use Kadence\Component_Interface;
 | |
| use Kadence\Templating_Component_Interface;
 | |
| use function add_action;
 | |
| use function apply_filters;
 | |
| use function Kadence\kadence;
 | |
| use function get_template_part;
 | |
| 
 | |
| /**
 | |
|  * Class for adding custom title area support.
 | |
|  *
 | |
|  * Exposes template tags:
 | |
|  * * `kadence()->render_title()`
 | |
|  */
 | |
| class Component implements Component_Interface, Templating_Component_Interface {
 | |
| 
 | |
| 	/**
 | |
| 	 * Gets the unique identifier for the theme component.
 | |
| 	 *
 | |
| 	 * @return string Component slug.
 | |
| 	 */
 | |
| 	public function get_slug() : string {
 | |
| 		return 'entry_title';
 | |
| 	}
 | |
| 
 | |
| 	/**
 | |
| 	 * Adds the action and filter hooks to integrate with WordPress.
 | |
| 	 */
 | |
| 	public function initialize() {
 | |
| 		//add_filter( 'kadence_title_elements_default', array( $this, 'maybe_add_defaults' ), 10, 2 );
 | |
| 	}
 | |
| 	/**
 | |
| 	 * Gets template tags to expose as methods on the Template_Tags class instance, accessible through `kadence()`.
 | |
| 	 *
 | |
| 	 * @return array Associative array of $method_name => $callback_info pairs. Each $callback_info must either be
 | |
| 	 *               a callable or an array with key 'callable'. This approach is used to reserve the possibility of
 | |
| 	 *               adding support for further arguments in the future.
 | |
| 	 */
 | |
| 	public function template_tags() : array {
 | |
| 		return array(
 | |
| 			'render_title' => array( $this, 'render_title' ),
 | |
| 		);
 | |
| 	}
 | |
| 
 | |
| 	/**
 | |
| 	 * Adds support to render header columns.
 | |
| 	 *
 | |
| 	 * @param string $post_type the name of the row.
 | |
| 	 * @param string $area the name of the area.
 | |
| 	 */
 | |
| 	public function render_title( $post_type = 'post', $area = 'normal' ) {
 | |
| 		$elements = kadence()->option( $post_type . '_title_elements' );
 | |
| 		if ( isset( $elements ) && is_array( $elements ) && ! empty( $elements ) ) {
 | |
| 			foreach ( $elements as $item ) {
 | |
| 				if ( kadence()->sub_option( $post_type . '_title_element_' . $item, 'enabled' ) ) {
 | |
| 					$template = apply_filters( 'kadence_title_elements_template_path', 'template-parts/title/' . $item, $item, $area );
 | |
| 					get_template_part( $template );
 | |
| 				}
 | |
| 			}
 | |
| 		} else {
 | |
| 			get_template_part( 'template-parts/title/title' );
 | |
| 		}
 | |
| 	}
 | |
| }
 |