1114 lines
32 KiB
PHP
Raw Permalink Normal View History

2024-05-20 15:37:46 +03:00
<?php
/**
* Filter to add plugins to the TOC list.
*
* @link https://rankmath.com/kb/filters-hooks-api-developer/#add-toc-plugin
*
* @since 2.0
*
* @param array TOC plugins.
*/
add_filter(
'rank_math/researches/toc_plugins',
function( $toc_plugins ) {
$toc_plugins[ EZ_TOC_BASE_NAME ] = 'Easy Table of Contents';
return $toc_plugins;
}
);
/**
* Filter to remove Connections Business Directory related shortcodes from being processed as eligible TOC items.
*
* @since 2.0
*/
add_filter(
'ez_toc_strip_shortcodes_tagnames',
function( $tags_to_remove ) {
$shortcodes = array (
'basic-user-avatars',
'CARFORM',
'connections_form',
'cn_multi_category_search',
'cn_widget',
'cn_carousel',
'connections_categories',
'connections_link_view',
'connections_link_edit',
'connections_login',
'siteshot',
'connections',
'upcoming_list',
'cn-mapblock',
'connections_vcard',
'connections_qtip',
'cn_thumb',
'cn_thumbr',
);
$tags_to_remove = array_merge( $tags_to_remove, $shortcodes );
return $tags_to_remove;
}
);
/**
* Filter to remove Striking theme related shortcodes from being processed as eligible TOC items.
*
* @since 2.0
*/
add_filter(
'ez_toc_strip_shortcodes_tagnames',
function( $tags_to_remove ) {
$shortcodes = array (
'iconbox',
'toggle',
);
$tags_to_remove = array_merge( $tags_to_remove, $shortcodes );
return $tags_to_remove;
}
);
/**
* Remove the JetPack share buttons node from the post content before extracting headings.
*
* @since 2.0
*/
add_filter(
'ez_toc_exclude_by_selector',
function( $selectors ) {
$selectors['jetpack-sharedaddy'] = '.sharedaddy';
$selectors['jetpack-relatedposts'] = '.jp-relatedposts';
return $selectors;
}
);
/**
* Remove the Elegant Themes Bloom plugin node from the post content before extracting headings.
*
* @since 2.0
*/
add_filter(
'ez_toc_exclude_by_selector',
function( $selectors ) {
$selectors['elegant-themes-bloom'] = '.et_bloom_below_post';
return $selectors;
}
);
/**
* Do not allow `the_content` TOC callback to run when editing a page in Visual Composer.
*
* @link https://wordpress.org/support/topic/correct-method-to-determine-if-using-frontend-editor/#post-12404679
*
* @since 2.0
*/
add_filter(
'ez_toc_maybe_apply_the_content_filter',
function( $apply ) {
if ( function_exists( 'vchelper' ) ) {
if ( vchelper( 'Frontend' )->isPageEditable() ) {
$apply = false;
}
}
return $apply;
}
);
/**
* Do not allow `the_content` TOC callback to run when editing a page in WPBakery Page Builder.
*
* @link https://wordpress.org/support/topic/correct-method-to-determine-if-using-frontend-editor/#post-12404679
*
* @since 2.0
*/
add_filter(
'ez_toc_maybe_apply_the_content_filter',
function( $apply ) {
if ( function_exists( 'vc_is_page_editable' ) ) {
if ( vc_is_page_editable() ) {
$apply = false;
}
}
return $apply;
}
);
/**
* Filter to remove WPBakery Page Builder related shortcodes from being processed as eligible TOC items.
*
* @since 2.0
*/
add_filter(
'ez_toc_strip_shortcodes_tagnames',
function( $tags_to_remove ) {
$shortcodes = array (
'vc_tta_section',
);
$tags_to_remove = array_merge( $tags_to_remove, $shortcodes );
return $tags_to_remove;
}
);
/**
* Exclude the TOC shortcodes from being processed in the admin in the Divi Theme by Elegant Themes.
*
* @since 2.0
*/
add_action(
'et_pb_admin_excluded_shortcodes',
function( $shortcodes ) {
$shortcodes[] = 'ez-toc';
$shortcodes[] = apply_filters( 'ez_toc_shortcode', 'toc' );
return $shortcodes;
}
);
/**
* Callback the for `et_builder_render_layout` filter.
*
* Attaches the ezTOC `the_content` filter callback to the Divi layout content filter so the in page anchors will be
* added the post content.
*
* NOTE: Set priority 12 to run after Divi runs the `do_shortcode` filter on its layout content.
*
* @link https://wordpress.org/support/topic/anchor-links-not-being-added-with-divi/
*
* @since 2.0
*/
add_filter(
'et_builder_render_layout',
array( 'ezTOC', 'the_content' ),
12,
1
);
/**
* Add support for the Uncode Theme.
*
* @link http://www.undsgn.com/
*
* @since 2.0.11
*/
add_action(
'after_setup_theme',
function() {
if ( function_exists( 'uncode_setup' ) ) {
add_filter(
'uncode_single_content_final_output',
array( 'ezTOC', 'the_content' ),
10,
1
);
}
},
11
);
/**
* Remove the Starbox plugin node from the post content before extracting headings.
* @link https://wordpress.org/plugins/starbox/
* @since 2.0
*/
add_filter(
'ez_toc_exclude_by_selector',
function( $selectors ) {
$selectors['starbox'] = '.abh_box';
return $selectors;
}
);
/**
* Remove the WordPress Related Posts plugin node from the post content before extracting headings.
* @link
* @since 2.0
*/
add_filter(
'ez_toc_exclude_by_selector',
function( $selectors ) {
$selectors['wordpress-23-related-posts-plugin'] = '.wp_rp_content';
return $selectors;
}
);
/**
* Remove the Atomic Blocks plugin node from the post content before extracting headings.
* @link
* @since 2.0
*/
add_filter(
'ez_toc_exclude_by_selector',
function( $selectors ) {
$selectors['atomic-blocks-cta'] = '.ab-block-cta';
$selectors['atomic-blocks-testimonial'] = '.ab-block-testimonial';
return $selectors;
}
);
/**
* Remove the Ultimate Addons for VC Composer node from the post content before extracting headings.
* @link
* @since 2.0
*/
add_filter(
'ez_toc_exclude_by_selector',
function( $selectors ) {
$selectors['ultimate-addons-for-vc-composer'] = '.ult_tabs';
return $selectors;
}
);
/**
* Remove the WP Product Review node from the post content before extracting headings.
* @link
* @since 2.0
*/
add_filter(
'ez_toc_exclude_by_selector',
function( $selectors ) {
$selectors['wp-product-review'] = '.wppr-review-container';
return $selectors;
}
);
/**
* Remove the Contextual Related Posts node from the post content before extracting headings.
*
* @link https://wordpress.org/plugins/contextual-related-posts/
* @since 2.0.9
*/
add_filter(
'ez_toc_exclude_by_selector',
function( $selectors ) {
$selectors['contextual-related-posts'] = '.crp_related';
return $selectors;
}
);
class ezTOC_Elementor {
/**
* Whether the excerpt is being called.
*
* Used to determine whether the call to `the_content()` came from `get_the_excerpt()`.
*
* @since 2.0.2
*
* @var bool Whether the excerpt is being used. Default is false.
*/
private $_is_excerpt = false;
/**
* ezTOC_Elementor constructor.
*
* @since 2.0.2
*/
public function __construct() {
// Hack to avoid enqueue post CSS while it's a `the_excerpt` call.
add_filter( 'get_the_excerpt', array( $this, 'start_excerpt_flag' ), 1 );
add_filter( 'get_the_excerpt', array( $this, 'end_excerpt_flag' ), 20 );
add_filter( 'ez_toc_maybe_apply_the_content_filter', array( $this, 'maybe_apply_the_content_filter' ) );
add_filter(
'ez_toc_strip_shortcodes_tagnames',
function( $tags_to_remove ) {
$shortcodes = array (
'elementor-template',
);
$tags_to_remove = array_merge( $tags_to_remove, $shortcodes );
return $tags_to_remove;
}
);
}
/**
* Callback for the `elementor/init` action.
*
* Add the compatibility filters for Elementor.
*
* @since 2.0.2
*/
public static function start() {
new self();
}
/**
* Callback for the `get_the_excerpt` filter.
*
* Start excerpt flag.
*
* Flags when `the_excerpt` is called. Used to avoid enqueueing CSS in the excerpt.
*
* @since 2.0.2
*
* @param string $excerpt The post excerpt.
*
* @return string The post excerpt.
*/
public function start_excerpt_flag( $excerpt ) {
$this->_is_excerpt = true;
return $excerpt;
}
/**
* Callback for the `get_the_excerpt` filter.
*
* End excerpt flag.
*
* Flags when `the_excerpt` call ended.
*
* @since 2.0.2
*
* @param string $excerpt The post excerpt.
*
* @return string The post excerpt.
*/
public function end_excerpt_flag( $excerpt ) {
$this->_is_excerpt = false;
return $excerpt;
}
/**
* Callback for the `ez_toc_maybe_apply_the_content_filter` filter.
*
* If doing Elementor excerpt, which calls `the_content` filter, do not apply the ezTOC `the_content` filter.
*
* @since 2.0.2
*
* @param bool $apply
*
* @return bool mixed
*/
public function maybe_apply_the_content_filter( $apply ) {
if ( $this->_is_excerpt ) {
$apply = false;
}
return $apply;
}
}
add_action( 'elementor/init', array( 'ezTOC_Elementor', 'start' ) );
/**
* Do not allow `the_content` TOC callback to run when on WooCommerce pages.
*
* @link https://docs.woocommerce.com/document/conditional-tags/
* @link https://wordpress.stackexchange.com/a/246525/59053
*
* @since 2.0.11
*/
add_filter(
'ez_toc_maybe_apply_the_content_filter',
function( $apply ) {
$active_plugins = apply_filters( 'active_plugins', get_option( 'active_plugins' ) );
// Just in case an array is not returned.
if ( ! is_array( $active_plugins ) ) {
$active_plugins = array();
}
$string = implode( '|', $active_plugins );
if ( class_exists( 'WooCommerce' ) && FALSE !== stripos( $string, 'woocommerce.php' ) ) {
/** @noinspection PhpUndefinedFunctionInspection */
if ( is_shop() ||
is_product_tag() ||
is_cart() ||
is_checkout() ||
is_account_page() ||
is_wc_endpoint_url()
) {
$apply = false;
}
}
return $apply;
}
);
/**
* Beaver Builder Plugin Customization
* for remove excluding heading contents
* @since 2.0.34
*/
add_filter(
'fl_builder_layout_data',
'ez_toc_flbuilder_layout_data',
12,
1
);
function ez_toc_flbuilder_layout_data( $data ) {
if( has_action( 'the_content' ) ) {
if(!empty($data)){
foreach( $data as $nodeKey => $node ){
$data[$nodeKey] = $node;
}
}
}
return $data;
}
/**
* Thrive Theme Builder Compatibility
* add inline custom CSS to remove double line
* on links of our Easy TOC container
* @since 2.0.38
*/
if ( 'Thrive Theme Builder' == apply_filters( 'current_theme', get_option( 'current_theme' ) ) ) {
add_action( 'wp_head', 'ezTocEnqueueScriptsforThriveThemeBuilder' );
if( ! function_exists( 'ezTocEnqueueScriptsforThriveThemeBuilder' ) ) {
function ezTocEnqueueScriptsforThriveThemeBuilder() {
echo <<<INLINECSSAVADA
<style>#ez-toc-container a:hover{text-decoration: none;}</style>
INLINECSSAVADA;
}
}
}
/**
* Kalium - Medical Theme Compatibility
* remove duplicate eztoc containers
* in faq sections
* @since 2.0.38
*/
if ( in_array( 'js_composer/js_composer.php', apply_filters( 'active_plugins', get_option( 'active_plugins' ) ) ) && ( 'Kalium - Medical Theme' == apply_filters( 'current_theme', get_option( 'current_theme' ) ) || 'Kalium' == apply_filters( 'current_theme', get_option( 'current_theme' ) ) ) ) {
add_shortcode( 'vc_toggle', 'eztoc_vc_toggle_modified' );
function eztoc_vc_toggle_modified( $atts, $content, $tag ) {
if ( 'vc_toggle' == $tag ) {
/**
* Shortcode attributes
* @var $atts
* @var $title
* @var $el_class
* @var $style
* @var $color
* @var $size
* @var $open
* @var $css_animation
* @var $el_id
* @var $content - shortcode content
* @var $css
* Shortcode class
* @var WPBakeryShortCode_Vc_Toggle $this_WPBakeryShortCode_Vc_Toggle
*/
$title = $el_class = $style = $color = $size = $open = $css_animation = $css = $el_id = '';
$inverted = false;
$atts = vc_map_get_attributes('vc_toggle', $atts);
extract($atts);
// checking is color inverted
$style = str_replace('_outline', '', $style, $inverted);
/**
* @since 4.4
*/
$elementClass = array(
'base' => apply_filters(VC_SHORTCODE_CUSTOM_CSS_FILTER_TAG, 'vc_toggle', 'vc_toggle', $atts),
// TODO: check this code, don't know how to get base class names from params
'style' => 'vc_toggle_' . $style,
'color' => ( $color ) ? 'vc_toggle_color_' . $color : '',
'inverted' => ( $inverted ) ? 'vc_toggle_color_inverted' : '',
'size' => ( $size ) ? 'vc_toggle_size_' . $size : '',
'open' => ( 'true' === $open ) ? 'vc_toggle_active' : '',
'extra' => $atts['css'],
'css_animation' => '',
// TODO: remove getCssAnimation as function in helpers
);
$class_to_filter = trim(implode(' ', $elementClass));
$class_to_filter .= vc_shortcode_custom_css_class($css, ' ');
$css_class = apply_filters(VC_SHORTCODE_CUSTOM_CSS_FILTER_TAG, $class_to_filter, 'vc_toggle', $atts);
$heading_output = apply_filters('wpb_toggle_heading', $atts['title'], array(
'title' => $title,
'open' => $open,
));
$output = '<div ' . ( isset( $el_id ) && ! empty( $el_id ) ? 'id="' . esc_attr( $el_id ) . '"' : '' ) . ' class="' . esc_attr( $css_class ) . '"><div class="vc_toggle_title">' . $heading_output . '<i class="vc_toggle_icon"></i></div><div class="vc_toggle_content">' . wpb_js_remove_wpautop( $content, true ) . '</div></div>';
return $output;
}
}
}
/**
* Foodie Pro Theme Compatibility
* for working sticky toggle
* in right way
* @since 2.0.39
*/
if ( 'Foodie Pro' == apply_filters( 'current_theme', get_option( 'current_theme' ) ) ) {
add_action( 'wp_head', 'ezTocEnqueueScriptsforFoodieProTheme' );
if( ! function_exists( 'ezTocEnqueueScriptsforFoodieProTheme' ) ) {
function ezTocEnqueueScriptsforFoodieProTheme() {
echo <<<INLINECSSFOODPRO
<style>@media only screen and (max-width: 940px){ .ez-toc-sticky #ez-toc-sticky-container .menu-toggle,#ez-toc-container .menu-toggle, #ez-toc-widget-container .menu-toggle{display:none} .ez-toc-sticky #ez-toc-sticky-container nav,#ez-toc-container nav, #ez-toc-widget-container nav {display:block} }</style>
INLINECSSFOODPRO;
}
}
}
/**
* Poka Theme Compatibility
* remove duplicate eztoc containers
* in header & footer sections
* @since 2.0.46
*/
if ( 'PokaTheme' == apply_filters( 'current_theme', get_option( 'current_theme' ) ) ) {
add_action( 'poka_before_main', 'ez_toc_poka_before_main', 4, 0 );
function ez_toc_poka_before_main() {
remove_action('poka_before_main', 'poka_before_content', 5, 0);
remove_filter( 'the_content', array( 'ezTOC', 'the_content' ), 100 );
add_action( 'poka_before_main', 'poka_before_content', 5, 0 );
}
add_action( 'poka_before_main', 'ez_toc_poka_before_main_after', 6, 0 );
function ez_toc_poka_before_main_after() {
add_filter( 'the_content', array( 'ezTOC', 'the_content' ), 100 );
}
add_action( 'poka_after_main', 'ez_toc_poka_after_main', 3, 0 );
function ez_toc_poka_after_main() {
remove_action( 'poka_after_main', 'poka_banner_footer', 4, 0 );
remove_filter( 'the_content', array( 'ezTOC', 'the_content' ), 100 );
add_action( 'poka_after_main', 'poka_banner_footer', 4, 0 );
}
add_action( 'poka_after_main', 'ez_toc_poka_after_main_after', 5, 0 );
function ez_toc_poka_after_main_after() {
add_filter( 'the_content', array( 'ezTOC', 'the_content' ), 100 );
}
}
if ( 'MAKE9 Divi zh-tw Child' == apply_filters( 'current_theme', get_option( 'current_theme' ) ) ) {
add_filter('ez_toc_regex_filteration', 'ez_toc_regex_filteration_for_divi_chinese');
function ez_toc_regex_filteration_for_divi_chinese( $regEx ) {
$regEx = '/(<h([1-6]{1})(?:(?!\bclass="et_pb_slide_title")[^>])*>)(.*)<\/h\2>/msuU';
return $regEx;
}
}
if ( in_array( 'lasso/affiliate-plugin.php', apply_filters( 'active_plugins', get_option( 'active_plugins' ) ) ) ) {
add_filter('ez_toc_regex_filteration', 'ez_toc_regex_filteration_for_lasso_products');
function ez_toc_regex_filteration_for_lasso_products( $regEx ) {
$regEx = '/(<(?:h|H){1}([1-6]{1})[^>]*>)(.*)<\/(?:h|H){1}\2>/msuU';
return $regEx;
}
}
/**
* Avada Theme with Fusion Core/Builder Plugin Compatibility
* remove duplicate eztoc containers
* in footer sections
* @since 2.0.49
*/
if ( ('Avada Child' == apply_filters( 'current_theme', get_option( 'current_theme' ) ) || 'Avada' == apply_filters( 'current_theme', get_option( 'current_theme' ) )) && in_array( 'fusion-builder/fusion-builder.php', apply_filters( 'active_plugins', get_option( 'active_plugins' ) ) ) ) {
add_action( 'awb_remove_third_party_the_content_changes', 'ez_toc_remove_the_footer_content', 1 );
function ez_toc_remove_the_footer_content() {
remove_filter( 'the_content', array( 'ezTOC', 'the_content' ), 100 );
}
add_action( 'awb_readd_third_party_the_content_changes', 'ez_toc_remove_the_footer_content_after', 1 );
function ez_toc_remove_the_footer_content_after() {
add_filter( 'the_content', array( 'ezTOC', 'the_content' ), 100 );
}
}
/**
* Grow, Social Pro by Mediavine plugin compatibility
* Anchors were not being generated for special char like inverted comma.
* @since 2.0.52
*/
add_filter('ez_toc_extract_headings_content', 'ez_toc_social_pro_by_mediavine_com',10,1);
function ez_toc_social_pro_by_mediavine_com($content){
if(class_exists( '\Mediavine\Grow\Shortcodes' ) && ezTOC_Option::get('mediavine-create') == 1){
$settings = Mediavine\Grow\Settings::get_setting( 'dpsp_pinterest_share_images_setting', [] );
if ( !empty( $settings['share_image_page_builder_compatibility'] ) || ! empty( $settings['share_image_lazy_load_compatibility'] ) ) {
$content = mb_convert_encoding( html_entity_decode($content), 'HTML-ENTITIES', 'UTF-8' );
}
}
return $content;
}
/**
* Parse Gutenberg reusable block
* @since 2.0.53
*/
add_filter('ez_toc_modify_process_page_content', 'ez_toc_parse_gutenberg_reusable_block',10,1);
function ez_toc_parse_gutenberg_reusable_block($content){
if(function_exists('do_blocks')){
if(has_block('easytoc/toc')){
$content = str_replace( '<!-- wp:easytoc/toc /-->', 'eztoctempblock', $content );
$content = do_blocks($content);
$content = str_replace( 'eztoctempblock', '<!-- wp:easytoc/toc /-->', $content );
}else{
$content = do_blocks($content);
}
}
return $content;
}
/**
* Create by Mediavine plugin compatibility
* shortcode were not being parse for custom post type mv_create added by this plugin inside post content
* @since 2.0.52
*/
add_filter('ez_toc_modify_process_page_content', 'ez_toc_parse_mv_create_shortcode',10,1);
function ez_toc_parse_mv_create_shortcode($content){
if ( in_array( 'mediavine-create/mediavine-create.php', apply_filters( 'active_plugins', get_option( 'active_plugins' ) ) ) && ezTOC_Option::get('mediavine-create') == 1) {
if ( has_shortcode( $content, 'mv_create' )) {
$content = do_shortcode($content);
}
}
return $content;
}
/**
* Remove the Create by Mediavine node from the post content before extracting headings.
*
* @link https://wordpress.org/plugins/mediavine-create/
* @since 2.0.8
* Modifyed in 2.0.52
*/
add_filter(
'ez_toc_exclude_by_selector',
function( $selectors ) {
if(ezTOC_Option::get('mediavine-create') != 1){
$selectors['mediavine-create'] = '.mv-create-card';
}
return $selectors;
}
);
/**
* UpSolution Core compatibility
* @link https://help.us-themes.com/impreza/us-core/
* @since 2.0.54
*/
add_filter('ez_toc_sidebar_has_toc_filter', 'ez_toc_sidebar_has_toc_status_us_core', 10,1);
function ez_toc_sidebar_has_toc_status_us_core($status){
if(function_exists('us_get_page_area_id')){
$content_template_id = us_get_page_area_id( 'content' );
$content_template = get_post( (int) $content_template_id );
if(isset($content_template->post_content)){
if ( has_shortcode( $content_template->post_content, 'toc' ) || has_shortcode( $content_template->post_content, 'ez-toc' ) ) {
$status = true;
}
}
}
return $status;
}
/**
* Custom Field Suite plugin sidebar compatibility
*
* @link https://wordpress.org/plugins/custom-field-suite/
* @since 2.0.52
*
*/
add_filter('ez_toc_sidebar_has_toc_filter', 'ez_toc_sidebar_has_toc_status_cfs', 10,1);
function ez_toc_sidebar_has_toc_status_cfs($status){
global $post;
if(function_exists('CFS')){
$fields = CFS()->get(false, $post->ID);
if(isset($fields['use_ez_toc']) && $fields['use_ez_toc'] == true){
$status = true;
}
}
return $status;
}
/**
* If Chamomile theme is active then remove hamburger div from content
* @since 2.0.53
* */
if('Chamomile' == apply_filters( 'current_theme', get_option( 'current_theme' ) )){
add_action('wp_footer', 'ez_toc_add_custom_script');
function ez_toc_add_custom_script()
{
?>
<script>
jQuery(document).ready(function($){
$('#ez-toc-container').find('.hamburger').remove();
});
</script>
<?php
}
}
/**
* Block Editor Template
*
* @link https://developer.wordpress.org/block-editor/
* @since 2.0.54
*
*/
if(function_exists('wp_is_block_theme') && wp_is_block_theme()){
add_filter('ez_toc_sidebar_has_toc_filter', 'ez_toc_guttenberg_has_toc', 10,1);
}
function ez_toc_guttenberg_has_toc($status){
$block_post_template = get_block_template(get_stylesheet() . '//' .'single');
$block_page_template = get_block_template(get_stylesheet() . '//' .'page');
if(is_single() && is_object($block_post_template) && (has_shortcode($block_post_template->content,'toc') || has_shortcode($block_post_template->content,'ez-toc')))
{
$status=true;
}
if(is_page() && is_object($block_post_template) && (has_shortcode($block_page_template->content,'toc') || has_shortcode($block_page_template->content,'ez-toc')))
{
$status=true;
}
return $status;
}
if(function_exists('init_goodlayers_core_system') && ezTOC_Option::get('goodlayers-core') == 1){
eztoc_enable_output_buffer_filter();
add_filter('eztoc_wordpress_final_output', 'ez_toc_gdlr_core_the_content', 10, 1);
function ez_toc_gdlr_core_the_content($content){
if(is_admin()){
return $content;
}
$post = ezTOC::get( get_the_ID() );
if($post){
$find = $post->getHeadings();
$replace = $post->getHeadingsWithAnchors();
$toc = $post->getTOC();
if ( !is_array($content ) && !empty( $find ) && !empty( $replace ) && !empty( $content ) ){
$content = str_replace( $find, $replace, $content );
}
if ( strpos('id="ez-toc-container"',$content) === false ){
$content = str_replace( '<div class="traveltour-single-article-content">', '<div class="traveltour-single-article-content">'.$toc, $content );
}
}
return $content;
}
// function to get combined content of goodlayers builder
function ezTOC_gdlr_core()
{
$postID = get_the_ID();
$gdlr_core_builder = get_post_meta( $postID ,'gdlr-core-page-builder' , false );
$gdlr_core_builder = isset($gdlr_core_builder[0])?$gdlr_core_builder[0]:$gdlr_core_builder;
$content="";
if(!empty($gdlr_core_builder) && is_array($gdlr_core_builder))
{
foreach($gdlr_core_builder as $element)
{
if(isset($element['items']))
{
foreach($element['items'] as $inner_element){
if($inner_element['template'] === 'element'){
$content= $content . ez_toc_gdlr_core_fetch_content($inner_element);
}else if(isset($inner_element['items'])){
foreach($inner_element['items'] as $level2_element){
if($level2_element['template'] === 'element'){
$content= $content . ez_toc_gdlr_core_fetch_content($level2_element);
}
}
}
}
}
if(isset($element['template']) && $element['template'] === 'element'){
$content= $content . ez_toc_gdlr_core_fetch_content($element);
}
}
}
return $content;
}
function ez_toc_gdlr_core_fetch_content($element){
if(isset($element['type']) && isset($element['value'])){
$type = $element['type'];
$element_class = 'gdlr_core_pb_element_'.$type;
if(class_exists($element_class)){
return $element_class::get_content($element['value']);
}
}
return '';
}
// Adding Goodlayers Content to create combined toc
add_filter( 'ez_toc_modify_process_page_content', 'ez_toc_gdlr_core_process_page_content', 10, 1 );
function ez_toc_gdlr_core_process_page_content( $content )
{
if (function_exists( 'ezTOC_gdlr_core' ) )
{
$eztoc_gdlr_core_content = ezTOC_gdlr_core();
$content = $content . $eztoc_gdlr_core_content;
}
return $content;
}
}
if(function_exists('rest_get_url_prefix') && ezTOC_Option::get('disable_in_restapi') == 1){
add_filter( 'ez_toc_modify_process_page_content', 'ez_toc_check_for_wp_json_request', 999, 1 );
function ez_toc_check_for_wp_json_request($content){
if ( empty( $_SERVER['REQUEST_URI'] ) ) {
return $content;
}
$rest_prefix = trailingslashit( rest_get_url_prefix() );
if(strpos( $_SERVER['REQUEST_URI'], $rest_prefix ) !== false){
return '';
}
return $content;
}
}
/**
* Molongui Authorship plugin compatibility
* @link https://wordpress.org/plugins/molongui-authorship/
* @since 2.0.56
*/
if( function_exists( 'molongui_authorship_load_plugin_textdomain' ) && ezTOC_Option::get('molongui-authorship') == 1 ){
add_filter( 'ez_toc_modify_process_page_content', 'ez_toc_content_molongui_authorship');
function ez_toc_content_molongui_authorship($content){
if(!empty($content))
{
if(strpos($content, "m-a-box-container") !== false){
libxml_use_internal_errors(true);
$dom = new DOMDocument();
$dom->loadHTML(mb_convert_encoding($content, 'HTML-ENTITIES', 'UTF-8'));
$xpath = new DOMXPath($dom);
if($xpath){
$divs = $xpath->query('//div[@class="m-a-box-container"]');
if($divs){
foreach ($divs as $div) {
$div->parentNode->removeChild($div);
}
}
// Save the modified HTML content
$modifiedHtml = $dom->saveHTML();
// Return the modified HTML content
return $modifiedHtml;
}
}
}
return $content;
}
}
/*
* Compatibility for Walker News Template
* @since 2.0.56
*/
if(function_exists('wp_get_theme')){
$theme_data = wp_get_theme();
if(!empty($theme_data) && $theme_data->get_template()== 'walker-news-template')
{
add_filter( 'ez_toc_sidebar_has_toc_filter', 'ez_toc_walker_news_template_fix');
function ez_toc_walker_news_template_fix($status){
$content = get_the_content();
if(function_exists('do_blocks')){
$content = do_blocks($content);
}
if(has_shortcode($content,'toc') || has_shortcode($content,'ez-toc')){
return true;
}
return $status;
}
}
}
/**
* Mediavine trellis compatibility
* @since 2.0.57
*/
add_filter('eztoc_modify_the_content','eztoc_mediavine_trellis_content_improver');
function eztoc_mediavine_trellis_content_improver($content){
if(class_exists('Mediavine\Trellis\Custom_Content')){
$content = mb_convert_encoding( html_entity_decode($content), 'HTML-ENTITIES', 'UTF-8' );
}
return $content;
}
//Perfmatters Compatibility
add_filter('ez_toc_pro_inline_css','ez_toc_perfmatters_touch_css');
function ez_toc_perfmatters_touch_css($css){
if('css' == ezTOC_Option::get( 'toc_loading' ) && class_exists('Perfmatters\Config') && !empty(Perfmatters\Config::$options['assets']['delay_js']) && !empty(Perfmatters\Config::$options['assets']['fastclick'])) {
$css .= 'label > * { pointer-events:none; }';
}
return $css;
}
/**
* Woodmart + WPbakery Gallery compatibility
* @since 2.0.58
*/
function ez_toc_woodmart_gallery_fix(){
if(function_exists('woodmart_load_classes') && class_exists('Vc_Manager')){
if(!wp_style_is('el-section-title')){
wp_register_style( 'el-section-title', WOODMART_THEME_DIR.'/css/parts/el-section-title.min.css');
wp_enqueue_style( 'el-section-title' );
}
if(!wp_style_is('wd-section-title-style-simple-and-brd')){
wp_register_style( 'wd-section-title-style-simple-and-brd', WOODMART_THEME_DIR.'/css/parts/el-section-title-style-simple-and-brd.min.css');
wp_enqueue_style( 'wd-section-title-style-simple-and-brd' );
}
if(!wp_style_is('wd-owl-carousel')){
wp_register_style( 'wd-owl-carousel', WOODMART_THEME_DIR.'/css/parts/lib-owl-carousel.min.css');
wp_enqueue_style( 'wd-owl-carousel' );
}
if(!wp_style_is('wd-image-gallery')){
wp_register_style( 'wd-image-gallery', WOODMART_THEME_DIR.'/css/parts/el-gallery.min.css');
wp_enqueue_style( 'wd-image-gallery' );
}
if(!wp_style_is('wd-accordion')){
wp_register_style( 'wd-accordion', WOODMART_THEME_DIR.'/css/parts/el-accordion.min.css');
wp_enqueue_style( 'wd-accordion' );
}
if(!wp_style_is('wd-tabs')){
wp_register_style( 'wd-tabs', WOODMART_THEME_DIR.'/css/parts/el-tabs.min.css');
wp_enqueue_style( 'wd-tabs' );
}
if(!wp_style_is('wd-team-member')){
wp_register_style( 'wd-team-member', WOODMART_THEME_DIR.'/css/parts/el-team-member.min.css');
wp_enqueue_style( 'wd-team-member' );
}
}
}
add_action('wp_enqueue_scripts', 'ez_toc_woodmart_gallery_fix');
/**
* Ad inserter plugin compatibility
* url : https://wordpress.org/plugins/ad-inserter/
* When toc shortcode being added inside ad inserter block, it runs infinite loop. Below code is the solution for it.
* @since 2.0.62
* return boolean
*/
add_filter('ez_toc_apply_filter_status_manually', 'ez_toc_adinserter_block_has_toc_shortcode',10,1);
function ez_toc_adinserter_block_has_toc_shortcode($status){
if ( in_array( 'ad-inserter/ad-inserter.php', apply_filters( 'active_plugins', get_option( 'active_plugins' ) ) ) ) {
global $block_object;
for ($block = 0; $block <= 96; $block ++) {
if(isset($block_object [$block])){
$obj = $block_object [$block];
if(is_object($obj) && is_array($obj->wp_options)){
if(has_shortcode( $obj->wp_options['code'] , 'ez-toc' ) || has_shortcode( $obj->wp_options['code'] , 'toc' )){
$status = false;
break;
}
}
}
}
}
return $status;
}
/**
* Current Year, Symbols and IP Shortcode compatibility
* shortcode were not being parse for heading title in elementor
* plugin url : https://wordpress.org/plugins/current-year-shortcode/
* @since 2.0.62
*/
add_filter('ez_toc_table_heading_title_anchor', 'ez_toc_parse_curreny_year_shortcode',10,1);
add_filter('ez_toc_content_heading_title', 'ez_toc_parse_curreny_year_shortcode',10,1);
add_filter('ez_toc_content_heading_title_anchor', 'ez_toc_parse_curreny_year_shortcode',10,1);
function ez_toc_parse_curreny_year_shortcode($content){
if ( in_array( 'current-year-shortcode/year-kgm.php', apply_filters( 'active_plugins', get_option( 'active_plugins' ) ) )) {
$content = do_shortcode($content);
}
return $content;
}