* // Declare support for all hook types
* add_theme_support( 'kemet_hooks', array( 'all' ) );
*
* // Declare support for certain hook types only
* add_theme_support( 'kemet_hooks', array( 'header', 'content', 'footer' ) );
*
*/
add_theme_support(
'kemet_hooks',
array(
/**
* As a Theme developer, use the 'all' parameter, to declare support for all
* hook types.
* Please make sure you then actually reference all the hooks in this file,
* Plugin developers depend on it!
*/
'all',
/**
* Themes can also choose to only support certain hook types.
* Please make sure you then actually reference all the hooks in this type
* family.
*
* When the 'all' parameter was set, specific hook types do not need to be
* added explicitly.
*/
'html',
'body',
'head',
'header',
'content',
'entry',
'comments',
'sidebars',
'sidebar',
'footer',
/**
* If/when WordPress Core implements similar methodology, Themes and Plugins
* will be able to check whether the version of THA supplied by the theme
* supports Core hooks.
*/
)
);
/**
* Determines, whether the specific hook type is actually supported.
*
* Plugin developers should always check for the support of a specific
* hook type before hooking a callback function to a hook of this type.
*
* Example:
*
* if ( current_theme_supports( 'kemet_hooks', 'header' ) )
* add_action( 'kemet_head_top', 'prefix_header_top' );
*
*
* @param bool $bool true.
* @param array $args The hook type being checked.
* @param array $registered All registered hook types.
*
* @return bool
*/
function kemet_current_theme_supports( $bool, $args, $registered ) {
return in_array( $args[0], $registered[0] ) || in_array( 'all', $registered[0] );
}
add_filter( 'current_theme_supports-kemet_hooks', 'kemet_current_theme_supports', 10, 3 );
/**
* HTML
hooks
*
* $kemet_supports[] = 'head';
*/
function kemet_html_before() {
do_action( 'kemet_html_before' );
}
/**
* Head top
*/
function kemet_head_top() {
do_action( 'kemet_head_top' );
}
/**
* Head Bottom
*/
function kemet_head_bottom() {
do_action( 'kemet_head_bottom' );
}
/**
* Site Header
*/
function kemet_header() {
do_action( 'kemet_header' );
}
/**
* After Header
*/
function kemet_after_header_block() {
do_action( 'kemet_after_header_block' );
}
/**
* Before Header
*/
function kemet_before_header_block() {
do_action( 'kemet_before_header_block' );
}
/**
* Sitehead Top
*/
function kemet_sitehead_top() {
do_action( 'kemet_sitehead_top' );
}
/**
* Sitehead
*/
function kemet_sitehead() {
do_action( 'kemet_sitehead' );
}
/**
* Sitehead Bottom
*/
function kemet_sitehead_bottom() {
do_action( 'kemet_sitehead_bottom' );
}
/**
* Main Header bar top
*/
function kemet_main_header_bar_top() {
do_action( 'kemet_main_header_bar_top' );
}
/**
* Main Header bar bottom
*/
function kemet_main_header_bar_bottom() {
do_action( 'kemet_main_header_bar_bottom' );
}
/**
* Main Header Content
*/
function kemet_sitehead_content() {
do_action( 'kemet_sitehead_content' );
}
/**
* Main toggle button before
*/
function kemet_sitehead_toggle_buttons_before() {
do_action( 'kemet_sitehead_toggle_buttons_before' );
}
/**
* Main toggle buttons
*/
function kemet_sitehead_toggle_buttons() {
do_action( 'kemet_sitehead_toggle_buttons' );
}
/**
* Main toggle button after
*/
function kemet_sitehead_toggle_buttons_after() {
do_action( 'kemet_sitehead_toggle_buttons_after' );
}
/**
* Content before
*/
function kemet_content_before() {
do_action( 'kemet_content_before' );
}
/**
* Content after
*/
function kemet_content_after() {
do_action( 'kemet_content_after' );
}
/**
* Content top
*/
function kemet_content_top() {
do_action( 'kemet_content_top' );
}
/**
* Content bottom
*/
function kemet_content_bottom() {
do_action( 'kemet_content_bottom' );
}
/**
* Content while before
*/
function kemet_content_while_before() {
do_action( 'kemet_content_while_before' );
}
/**
* Content loop
*/
function kemet_content_loop() {
do_action( 'kemet_content_loop' );
}
/**
* Conten Page Loop.
*
* Called from page.php
*/
function kemet_content_page_loop() {
do_action( 'kemet_content_page_loop' );
}
/**
* Content while after
*/
function kemet_content_while_after() {
do_action( 'kemet_content_while_after' );
}
/**
* Semantic hooks
*
* $kemet_supports[] = 'entry';
*/
function kemet_entry_before() {
do_action( 'kemet_entry_before' );
}
/**
* Entry after
*/
function kemet_entry_after() {
do_action( 'kemet_entry_after' );
}
/**
* Entry content before
*/
function kemet_entry_content_before() {
do_action( 'kemet_entry_content_before' );
}
/**
* Entry content after
*/
function kemet_entry_content_after() {
do_action( 'kemet_entry_content_after' );
}
/**
* Primary Content Top
*/
function kemet_primary_content_top() {
do_action( 'kemet_primary_content_top' );
}
/**
* Primary Content Bottom
*/
function kemet_primary_content_bottom() {
do_action( 'kemet_primary_content_bottom' );
}
/**
* Entry Top
*/
function kemet_entry_top() {
do_action( 'kemet_entry_top' );
}
/**
* Entry bottom
*/
function kemet_entry_bottom() {
do_action( 'kemet_entry_bottom' );
}
/**
* Single Post Header Before
*/
function kemet_single_header_before() {
do_action( 'kemet_single_header_before' );
}
/**
* Single Post Header After
*/
function kemet_single_header_after() {
do_action( 'kemet_single_header_after' );
}
/**
* Single Post Header Top
*/
function kemet_single_header_top() {
do_action( 'kemet_single_header_top' );
}
/**
* Single Post Header Bottom
*/
function kemet_single_header_bottom() {
do_action( 'kemet_single_header_bottom' );
}
/**
* Entry content blog
*/
function kemet_entry_content_blog() {
do_action( 'kemet_entry_content_blog' );
}
/**
* Blog featured post section
*/
function kemet_blog_post_featured_format() {
do_action( 'kemet_blog_post_featured_format' );
}
/**
* Semantic hooks
*
* $kemet_supports[] = 'sidebar';
*/
function kemet_sidebars_before() {
do_action( 'kemet_sidebars_before' );
}
/**
* Sidebars after
*/
function kemet_sidebars_after() {
do_action( 'kemet_sidebars_after' );
}
/**
* Semantic