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' );
|
|
}
|
|
}
|
|
}
|