OwlCyberSecurity - MANAGER
Edit File: class-eztoc-widget.php
<?php // Exit if accessed directly if ( ! defined( 'ABSPATH' ) ) exit; if ( ! class_exists( 'ezTOC_Widget' ) ) { /** * Class ezTOC_Widget */ class ezTOC_Widget extends WP_Widget { private $allowed_tags = ['h2', 'h3', 'h4', 'h5', 'h6','span','div','p']; /** * Setup and register the table of contents widget. * * @access public * @since 1.0 */ public function __construct() { $options = array( 'classname' => 'ez-toc', 'description' => esc_html__( 'Display the table of contents.', 'easy-table-of-contents' ) ); parent::__construct( 'ezw_tco', esc_html__( 'Table of Contents', 'easy-table-of-contents' ), $options ); add_action( 'admin_enqueue_scripts', array( $this, 'enqueueScripts' ) ); add_action( 'admin_footer-widgets.php', array( $this, 'printScripts' ), 9999 ); } /** * Callback which registers the widget with the Widget API. * * @access public * @since 1.0 * @static * * @return void */ public static function register() { register_widget( __CLASS__ ); } /** * Callback to enqueue scripts on the Widgets admin page. * * @access private * @since 1.0 * * @param string $hook_suffix */ public function enqueueScripts( $hook_suffix ) { if ( 'widgets.php' !== $hook_suffix ) { return; } wp_enqueue_style( 'wp-color-picker' ); wp_enqueue_script( 'wp-color-picker' ); wp_enqueue_script( 'underscore' ); } /** * Callback to print the scripts to the Widgets admin page footer. * * @access private * @since 1.0 */ public function printScripts() { ?> <script> ( function( $ ){ function initColorPicker( widget ) { widget.find( '.color-picker' ).wpColorPicker( { change: _.throttle( function() { // For Customizer $(this).trigger( 'change' ); }, 3000 ) }); } function onFormUpdate( event, widget ) { initColorPicker( widget ); } $( document ).on( 'widget-added widget-updated', onFormUpdate ); $( document ).ready( function() { $( '#widgets-right .widget:has(.color-picker)' ).each( function () { initColorPicker( $( this ) ); } ); } ); }( jQuery ) ); </script> <?php } /** * Display the post content. Optionally allows post ID to be passed * * @link http://stephenharris.info/get-post-content-by-id/ * @link http://wordpress.stackexchange.com/a/143316 * * @access public * @since 1.0 * * @param int $post_id Optional. Post ID. * * @return string */ public function the_content( $post_id = 0 ) { global $post; $post = get_post( $post_id ); setup_postdata( $post ); ob_start(); the_content(); $content = ob_get_clean(); wp_reset_postdata(); return $content; } /** * Renders the widgets. * * @access private * @since 1.0 * * @param array $args * @param array $instance */ public function widget( $args, $instance ) { if ( is_404() || is_archive() || is_search() || ( ! is_front_page() && is_home() ) ) return; $post = ezTOC::get( get_the_ID() ); if( function_exists( 'post_password_required' ) ) { if( post_password_required() ) return; } /** * @link https://wordpress.org/support/topic/fatal-error-when-trying-to-access-widget-area/ */ if ( ! $post instanceof ezTOC_Post ) return; if ( $post->hasTOCItems() ) { /** * @var string $before_widget * @var string $after_widget * @var string $before_title * @var string $after_title */ extract( $args ); $class = array( 'ez-toc-v' . str_replace( '.', '_', ezTOC::VERSION ), 'ez-toc-widget', ); $instance_title = ''; if(isset($instance['title'])){ $instance_title = $instance['title']; } $title = apply_filters( 'widget_title', $instance_title, $instance, $this->id_base ); if ( false !== strpos( $title, '%PAGE_TITLE%' ) || false !== strpos( $title, '%PAGE_NAME%' ) ) { $title = str_replace( '%PAGE_TITLE%', get_the_title(), $title ); } if ( ezTOC_Option::get( 'show_hierarchy' ) ) { $class[] = 'counter-hierarchy'; } else { $class[] = 'counter-flat'; } if( ezTOC_Option::get( 'heading-text-direction', 'ltr' ) == 'ltr' ) { $class[] = 'ez-toc-widget-container'; } if( ezTOC_Option::get( 'heading-text-direction', 'ltr' ) == 'rtl' ) { $class[] = 'ez-toc-widget-container-rtl'; } if ( isset($instance['affix']) ) { $class[] = 'ez-toc-affix'; } $class[] = 'ez-toc-widget-direction'; $custom_classes = ezTOC_Option::get( 'css_container_class', '' ); if ( 0 < strlen( $custom_classes ) ) { $custom_classes = explode( ' ', $custom_classes ); $custom_classes = apply_filters( 'ez_toc_container_class', $custom_classes, $this ); if ( is_array( $custom_classes ) ) { $class = array_merge( $class, $custom_classes ); } } $class = array_filter( $class ); $class = array_map( 'trim', $class ); $class = array_map( 'sanitize_html_class', $class ); //phpcs:ignore WordPress.Security.EscapeOutput.OutputNotEscaped -- Reason : Already escaped echo $before_widget; do_action( 'ez_toc_before_widget_container'); echo '<div id="ez-toc-widget-container" class="ez-toc-widget-container ' . esc_attr(implode( ' ', $class )) . '">' . PHP_EOL; do_action( 'ez_toc_before_widget' ); /** * @todo Instead of inline style, use the shadow DOM. * @link https://css-tricks.com/playing-shadow-dom/ * * @todo Consider not outputting the style if CSS is disabled. * @link https://wordpress.org/support/topic/inline-styling-triggers-html-validation-error/ */ if(isset($instance[ 'sidebar_title_size' ]) && isset($instance[ 'sidebar_title_size_unit' ])){ $title_font_size = $instance[ 'sidebar_title_size' ].$instance[ 'sidebar_title_size_unit' ]; }else{ $title_font_size = '120%'; } if ( 0 < strlen( $title ) ) { ?> <?php if( isset($instance[ 'heading_label_tag' ]) && $instance[ 'heading_label_tag' ] != 'default' && in_array($instance[ 'heading_label_tag' ], $this->allowed_tags)){ echo '<'.esc_attr($instance[ 'heading_label_tag' ]).' class="widget-title">'; }else{ echo $before_title; //phpcs:ignore WordPress.Security.EscapeOutput.OutputNotEscaped -- Already escaped in the core } ?> <span class="ez-toc-title-container"> <style> #<?php echo esc_attr($this->id) ?> .ez-toc-title{ font-size: <?php echo esc_attr ( $title_font_size ); ?>; <?php if( isset($instance[ 'sidebar_title_weight' ]) ){ ?> font-weight: <?php echo esc_attr ( $instance[ 'sidebar_title_weight' ] ); } ?>; <?php if( isset($instance[ 'sidebar_title_color' ]) ){ ?> color: <?php echo esc_attr ( $instance[ 'sidebar_title_color' ] ); }?>; } #<?php echo esc_attr($this->id) ?> .ez-toc-widget-container ul.ez-toc-list li a{ <?php if( isset($instance[ 'sidebar_text_size' ]) && isset($instance[ 'sidebar_text_size_unit' ]) ){ ?> font-size: <?php echo esc_attr ( $instance[ 'sidebar_text_size' ].$instance[ 'sidebar_text_size_unit' ] ); } ?>; <?php if( isset($instance[ 'sidebar_text_weight' ]) ){ ?> font-weight: <?php echo esc_attr ( $instance[ 'sidebar_text_weight' ] ); } ?>; <?php if( isset($instance[ 'sidebar_text_color' ]) ){ ?> color: <?php echo esc_attr ( $instance[ 'sidebar_text_color' ] ); } ?>; } #<?php echo esc_attr($this->id) ?> .ez-toc-widget-container ul.ez-toc-list li.active{ background-color: <?php echo esc_attr( $instance['highlight_color'] ); ?>; } </style> <?php $headerTextToggleClass = ''; $headerTextToggleStyle = ''; if ( ezTOC_Option::get( 'visibility_on_header_text' ) ) { $headerTextToggleClass = 'ez-toc-toggle'; $headerTextToggleStyle = 'style="cursor: pointer"'; } $header_label = '<span class="ez-toc-title ' . $headerTextToggleClass . '" ' .$headerTextToggleStyle . '>' . $title . '</span>'; ?> <span class="ez-toc-title-toggle"> <?php if ( 'css' != ezTOC_Option::get( 'toc_loading' ) ): ?> <?php //phpcs:ignore WordPress.Security.EscapeOutput.OutputNotEscaped -- Reason : Already escaped echo $header_label; if ( ezTOC_Option::get( 'visibility' ) ) { echo '<a href="#" class="ez-toc-pull-right ez-toc-btn ez-toc-btn-xs ez-toc-btn-default ez-toc-toggle" aria-label="'.esc_attr__('Widget Easy TOC toggle icon','easy-table-of-contents').'"><span style="border: 0;padding: 0;margin: 0;position: absolute !important;height: 1px;width: 1px;overflow: hidden;clip: rect(1px 1px 1px 1px);clip: rect(1px, 1px, 1px, 1px);clip-path: inset(50%);white-space: nowrap;">Toggle Table of Content</span>' . ezTOC::get_toc_toggle_icon() . '</a>'; //phpcs:ignore WordPress.Security.EscapeOutput.OutputNotEscaped -- Reason : Already escaped } ?> <?php else: ?> <?php $toggle_view=''; if(ezTOC_Option::get('visibility_hide_by_default')==true){ $toggle_view= "checked"; } if( true == get_post_meta( get_the_ID(), '_ez-toc-visibility_hide_by_default', true ) ) { $toggle_view = "checked"; } $cssIconID = uniqid(); if ( ezTOC_Option::get( 'visibility_on_header_text' ) ) { $htmlCSSIcon = '<label for="ez-toc-cssicon-toggle-item-' . $cssIconID . '" style="cursor:pointer">' . $header_label . '<span class="ez-toc-pull-right ez-toc-btn ez-toc-btn-xs ez-toc-btn-default ez-toc-toggle">' . ezTOC::get_toc_toggle_icon( 'widget-with-visibility_on_header_text' ) . '</span></label>'; } else { //phpcs:ignore WordPress.Security.EscapeOutput.OutputNotEscaped -- Reason : Already escaped echo $header_label; $htmlCSSIcon = '<label for="ez-toc-cssicon-toggle-item-' . $cssIconID . '" class="ez-toc-pull-right ez-toc-btn ez-toc-btn-xs ez-toc-btn-default ez-toc-toggle">' . ezTOC::get_toc_toggle_icon( 'widget-with-visibility_on_header_text' ) . '</span></label>'; } //phpcs:ignore WordPress.Security.EscapeOutput.OutputNotEscaped -- Reason : Already escaped echo $htmlCSSIcon; ?> <?php endif; ?> </span> </span> <?php if( isset($instance[ 'heading_label_tag' ]) && $instance[ 'heading_label_tag' ] != 'default' && in_array($instance[ 'heading_label_tag' ], $this->allowed_tags) ){ echo '</'.esc_attr($instance[ 'heading_label_tag' ]).'>'; }else{ echo $after_title; //phpcs:ignore WordPress.Security.EscapeOutput.OutputNotEscaped -- Already escaped in the core } ?> <?php if ( 'css' == ezTOC_Option::get( 'toc_loading' ) ): ?> <label for="ez-toc-cssicon-toggle-item-count-<?php $cssIconID ?>" class="cssiconcheckbox">1</label><input type="checkbox" id="ez-toc-cssicon-toggle-item-<?php $cssIconID ?>" <?php $toggle_view?> style="display:none" /> <?php endif; ?> <?php } do_action( 'ez_toc_before' ); //phpcs:ignore WordPress.Security.EscapeOutput.OutputNotEscaped -- Reason : Already escaped echo '<nav>'. PHP_EOL . $post->getTOCList() . '</nav>' . PHP_EOL; do_action( 'ez_toc_after' ); do_action( 'ez_toc_after_widget' ); echo '</div>' . PHP_EOL; do_action( 'ez_toc_after_widget_container' ); //phpcs:ignore WordPress.Security.EscapeOutput.OutputNotEscaped -- Reason : Already escaped echo $after_widget; } } /** * Update the widget settings. * * @access private * @since 1.0 * * @param array $new_instance * @param array $old_instance * * @return array */ public function update( $new_instance, $old_instance ) { $instance = $old_instance; $instance['title'] = wp_strip_all_tags( $new_instance['title'] ); $instance['affix'] = array_key_exists( 'affix', $new_instance ) ? $new_instance['affix'] : '0'; $instance['highlight_color'] = wp_strip_all_tags( $new_instance['highlight_color'] ); if ( isset ( $new_instance[ 'eztoc_appearance' ] ) && $new_instance[ 'eztoc_appearance' ] == 'on' ){ $instance[ 'sidebar_title_size' ] = ( int ) wp_strip_all_tags ( $new_instance[ 'sidebar_title_size' ] ); $instance[ 'sidebar_title_size_unit' ] = wp_strip_all_tags ( $new_instance[ 'sidebar_title_size_unit' ] ); $instance[ 'sidebar_title_weight' ] = wp_strip_all_tags ( $new_instance[ 'sidebar_title_weight' ] ); $instance[ 'sidebar_title_color' ] = wp_strip_all_tags ( $new_instance[ 'sidebar_title_color' ] ); $instance[ 'sidebar_text_size' ] = ( int ) wp_strip_all_tags ( $new_instance[ 'sidebar_text_size' ] ); $instance[ 'sidebar_text_size_unit' ] = wp_strip_all_tags ( $new_instance[ 'sidebar_text_size_unit' ] ); $instance[ 'sidebar_text_weight' ] = wp_strip_all_tags ( $new_instance[ 'sidebar_text_weight' ] ); $instance[ 'sidebar_text_color' ] = wp_strip_all_tags ( $new_instance[ 'sidebar_text_color' ] ); $instance[ 'eztoc_appearance' ] = 'on'; $instance['heading_label_tag'] = wp_strip_all_tags( $new_instance['heading_label_tag'] ); }else{ $instance[ 'sidebar_title_size' ] = 120; $instance[ 'sidebar_title_size_unit' ] = '%'; $instance[ 'sidebar_title_weight' ] = '500'; $instance[ 'sidebar_title_color' ] = '#000'; $instance[ 'sidebar_text_size' ] = 120; $instance[ 'sidebar_text_size_unit' ] = '%'; $instance[ 'sidebar_text_weight' ] = '500'; $instance[ 'sidebar_text_color' ] = '#000'; $instance[ 'eztoc_appearance' ] = ''; $instance['heading_label_tag'] = 'default'; } $instance['hide_inline'] = array_key_exists( 'hide_inline', $new_instance ) ? $new_instance['hide_inline'] : '0'; return $instance; } /** * Displays the widget settings on the Widgets admin page. * * @access private * @since 1.0 * * @param array $instance * * @return string|void */ public function form( $instance ) { $defaults = array( 'affix' => '0', 'eztoc_appearance' => '', 'highlight_color' => '#ededed', 'title' => esc_html__('Table of Contents', 'easy-table-of-contents' ), 'sidebar_title_size' => 120, 'sidebar_title_size_unit' => '%', 'sidebar_title_weight' => '500', 'sidebar_title_color' => '#000', 'sidebar_text_size' => 120, 'sidebar_text_size_unit' => '%', 'sidebar_text_weight' => '400', 'sidebar_text_color' => '#000', 'hide_inline' => '0', 'heading_label_tag' => 'default', ); $instance = wp_parse_args( (array) $instance, $defaults ); $highlight_color = esc_attr( $instance[ 'highlight_color' ] ); $title_color = esc_attr( $instance[ 'sidebar_title_color' ] ); $text_color = esc_attr( $instance[ 'sidebar_text_color' ] ); ?> <p> <label for="<?php echo esc_attr($this->get_field_id('title')); ?>"><?php esc_html_e( 'Title', 'easy-table-of-contents' ); ?>:</label> <input type="text" id="<?php echo esc_attr($this->get_field_id('title')); ?>" name="<?php echo esc_attr($this->get_field_name('title')); ?>" value="<?php echo esc_attr($instance['title']); ?>" style="width:100%;"/> </p> <div class="ez-toc-widget-appearance-title"> <input type="checkbox" class="ez_toc_widget_appearance_options" id="<?php echo esc_attr($this->get_field_id('eztoc_appearance')); ?>" name="<?php echo esc_attr($this->get_field_name('eztoc_appearance')); ?>" <?php if( 'on' === $instance[ 'eztoc_appearance' ] ) { ?> checked="checked" <?php } ?>/> <label for="<?php echo esc_attr($this->get_field_id('eztoc_appearance')); ?>"><?php esc_html_e( 'Appearance', 'easy-table-of-contents' ); ?></label> <div id="ez-toc-widget-options-container" class="ez-toc-widget-appearance-options-container"> <p class="ez-toc-widget-form-group"> <label for="<?php echo esc_attr($this->get_field_id('sidebar_title_color')); ?>" style="margin-right: 12px;"><?php esc_html_e( 'Font Title Color:', 'easy-table-of-contents' ); ?></label><br> <input type="text" name="<?php echo esc_attr($this->get_field_name('sidebar_title_color')); ?>" class="color-picker" id="<?php echo esc_attr($this->get_field_id('sidebar_title_color')); ?>" value="<?php echo esc_attr($title_color); ?>" data-default-color="<?php echo esc_attr($defaults[ 'sidebar_title_color' ]); ?>" /> </p> <div class="ez-toc-widget-form-group"> <label for="<?php echo esc_attr($this->get_field_id('sidebar_title_size')); ?>"><?php esc_html_e( 'Title Font Size', 'easy-table-of-contents' ); ?>:</label> <input type="text" id="<?php echo esc_attr($this->get_field_id('sidebar_title_size')); ?>" name="<?php echo esc_attr($this->get_field_name('sidebar_title_size')); ?>" value="<?php echo esc_attr($instance[ 'sidebar_title_size' ]); ?>" style="width: 60px;"/> <select id="<?php echo esc_attr($this->get_field_id('sidebar_title_size_unit')); ?>" name="<?php echo esc_attr($this->get_field_name('sidebar_title_size_unit')); ?>" data-placeholder="" > <option value="%" <?php echo ( '%' == $instance[ 'sidebar_title_size_unit' ] ) ? 'selected' : ''; ?>><?php esc_html_e( '%', 'easy-table-of-contents' ); ?></option> <option value="pt" <?php echo ( 'pt' == $instance[ 'sidebar_title_size_unit' ] ) ? 'selected=' : ''; ?> ><?php esc_html_e( 'pt', 'easy-table-of-contents' ); ?></option> <option value="px" <?php echo ( 'px' == $instance[ 'sidebar_title_size_unit' ] ) ? 'selected=' : ''; ?>><?php esc_html_e( 'px', 'easy-table-of-contents' ); ?></option> <option value="em" <?php echo ( 'em' == $instance[ 'sidebar_title_size_unit' ] ) ? 'selected=' : ''; ?>><?php esc_html_e( 'em', 'easy-table-of-contents' ); ?></option> </select> </div> <div class="ez-toc-widget-form-group"> <label for="<?php echo esc_attr($this->get_field_id('sidebar_title_weight')); ?>"><?php esc_html_e( 'Title Font Weight', 'easy-table-of-contents' ); ?>:</label> <select id="<?php echo esc_attr($this->get_field_id('sidebar_title_weight')); ?>" name="<?php echo esc_attr($this->get_field_name('sidebar_title_weight')); ?>" data-placeholder="" style=" width: 60px; "> <option value="100" <?php echo ( '100' == $instance[ 'sidebar_title_weight' ] ) ? 'selected' : ''; ?>><?php esc_html_e( '100', 'easy-table-of-contents' ); ?></option> <option value="200" <?php echo ( '200' == $instance[ 'sidebar_title_weight' ] ) ? 'selected=' : ''; ?> ><?php esc_html_e( '200', 'easy-table-of-contents' ); ?></option> <option value="300" <?php echo ( '300' == $instance[ 'sidebar_title_weight' ] ) ? 'selected=' : ''; ?>><?php esc_html_e( '300', 'easy-table-of-contents' ); ?></option> <option value="400" <?php echo ( '400' == $instance[ 'sidebar_title_weight' ] ) ? 'selected=' : ''; ?>><?php esc_html_e( '400', 'easy-table-of-contents' ); ?></option> <option value="500" <?php echo ( '500' == $instance[ 'sidebar_title_weight' ] ) ? 'selected=' : ''; ?>><?php esc_html_e( '500', 'easy-table-of-contents' ); ?></option> <option value="600" <?php echo ( '600' == $instance[ 'sidebar_title_weight' ] ) ? 'selected=' : ''; ?>><?php esc_html_e( '600', 'easy-table-of-contents' ); ?></option> <option value="700" <?php echo ( '700' == $instance[ 'sidebar_title_weight' ] ) ? 'selected=' : ''; ?>><?php esc_html_e( '700', 'easy-table-of-contents' ); ?></option> <option value="800" <?php echo ( '800' == $instance[ 'sidebar_title_weight' ] ) ? 'selected=' : ''; ?>><?php esc_html_e( '800', 'easy-table-of-contents' ); ?></option> <option value="900" <?php echo ( '900' == $instance[ 'sidebar_title_weight' ] ) ? 'selected=' : ''; ?>><?php esc_html_e( '900', 'easy-table-of-contents' ); ?></option> </select> </div> <p class="ez-toc-widget-form-group"> <label for="<?php echo esc_attr($this->get_field_id('sidebar_text_color')); ?>" style="margin-right: 12px;"><?php esc_html_e( 'Text Color:', 'easy-table-of-contents' ); ?></label><br> <input type="text" name="<?php echo esc_attr($this->get_field_name('sidebar_text_color')); ?>" class="color-picker" id="<?php echo esc_attr($this->get_field_id('sidebar_text_color')); ?>" value="<?php echo esc_attr($text_color); ?>" data-default-color="<?php echo esc_attr($defaults[ 'sidebar_text_color' ]); ?>" /> </p> <div class="ez-toc-widget-form-group"> <label for="<?php echo esc_attr($this->get_field_id('sidebar_text_size')); ?>"><?php esc_html_e( 'Text Font Size', 'easy-table-of-contents' ); ?>:</label> <input type="text" id="<?php echo esc_attr($this->get_field_id('sidebar_text_size')); ?>" name="<?php echo esc_attr($this->get_field_name('sidebar_text_size')); ?>" value="<?php echo esc_attr($instance[ 'sidebar_text_size' ]); ?>" style="width: 60px;"/> <select id="<?php echo esc_attr($this->get_field_id('sidebar_text_size_unit')); ?>" name="<?php echo esc_attr($this->get_field_name('sidebar_text_size_unit')); ?>" data-placeholder="" > <option value="%" <?php echo ( '%' == $instance[ 'sidebar_text_size_unit' ] ) ? 'selected' : ''; ?>><?php esc_html_e( '%', 'easy-table-of-contents' ); ?></option> <option value="pt" <?php echo ( 'pt' == $instance[ 'sidebar_text_size_unit' ] ) ? 'selected=' : ''; ?> ><?php esc_html_e( 'pt', 'easy-table-of-contents' ); ?></option> <option value="px" <?php echo ( 'px' == $instance[ 'sidebar_text_size_unit' ] ) ? 'selected=' : ''; ?>><?php esc_html_e( 'px', 'easy-table-of-contents' ); ?></option> <option value="em" <?php echo ( 'em' == $instance[ 'sidebar_text_size_unit' ] ) ? 'selected=' : ''; ?>><?php esc_html_e( 'em', 'easy-table-of-contents' ); ?></option> </select> </div> <div class="ez-toc-widget-form-group"> <label for="<?php echo esc_attr($this->get_field_id('sidebar_text_weight')); ?>"><?php esc_html_e( 'Text Font Weight', 'easy-table-of-contents' ); ?>:</label> <select id="<?php echo esc_attr($this->get_field_id('sidebar_text_weight')); ?>" name="<?php echo esc_attr($this->get_field_name('sidebar_text_weight')); ?>" data-placeholder="" style=" width: 60px; "> <option value="100" <?php echo ( '100' == $instance[ 'sidebar_text_weight' ] ) ? 'selected' : ''; ?>><?php esc_html_e( '100', 'easy-table-of-contents' ); ?></option> <option value="200" <?php echo ( '200' == $instance[ 'sidebar_text_weight' ] ) ? 'selected=' : ''; ?> ><?php esc_html_e( '200', 'easy-table-of-contents' ); ?></option> <option value="300" <?php echo ( '300' == $instance[ 'sidebar_text_weight' ] ) ? 'selected=' : ''; ?>><?php esc_html_e( '300', 'easy-table-of-contents' ); ?></option> <option value="400" <?php echo ( '400' == $instance[ 'sidebar_text_weight' ] ) ? 'selected=' : ''; ?>><?php esc_html_e( '400', 'easy-table-of-contents' ); ?></option> <option value="500" <?php echo ( '500' == $instance[ 'sidebar_text_weight' ] ) ? 'selected=' : ''; ?>><?php esc_html_e( '500', 'easy-table-of-contents' ); ?></option> <option value="600" <?php echo ( '600' == $instance[ 'sidebar_text_weight' ] ) ? 'selected=' : ''; ?>><?php esc_html_e( '600', 'easy-table-of-contents' ); ?></option> <option value="700" <?php echo ( '700' == $instance[ 'sidebar_text_weight' ] ) ? 'selected=' : ''; ?>><?php esc_html_e( '700', 'easy-table-of-contents' ); ?></option> <option value="800" <?php echo ( '800' == $instance[ 'sidebar_text_weight' ] ) ? 'selected=' : ''; ?>><?php esc_html_e( '800', 'easy-table-of-contents' ); ?></option> <option value="900" <?php echo ( '900' == $instance[ 'sidebar_text_weight' ] ) ? 'selected=' : ''; ?>><?php esc_html_e( '900', 'easy-table-of-contents' ); ?></option> </select> </div> <p class="ez-toc-widget-form-group"> <label for="<?php echo esc_attr($this->get_field_id('highlight_color')); ?>" style="margin-right: 12px;"><?php esc_html_e( 'Active Section Highlight Color:', 'easy-table-of-contents' ); ?></label><br> <input type="text" name="<?php echo esc_attr($this->get_field_name('highlight_color')); ?>" class="color-picker" id="<?php echo esc_attr($this->get_field_id('highlight_color')); ?>" value="<?php echo esc_attr($highlight_color); ?>" data-default-color="<?php echo esc_attr($defaults['highlight_color']); ?>" /> </p> <div class="ez-toc-widget-form-group"> <label for="<?php echo esc_attr($this -> get_field_id ( 'heading_label_tag' )); ?>"><?php esc_html_e ( 'Heading Label Tag', 'easy-table-of-contents' ); ?>:</label> <select id="<?php echo esc_attr($this -> get_field_id ( 'heading_label_tag' )); ?>" name="<?php echo esc_attr($this -> get_field_name ( 'heading_label_tag' )); ?>" style=" width: 100px; "> <option value="default" <?php echo ( '800' == $instance[ 'heading_label_tag' ] ) ? 'selected=' : ''; ?>><?php esc_html_e ( 'Default', 'easy-table-of-contents' ); ?></option> <option value="h2" <?php echo ( 'h2' == $instance[ 'heading_label_tag' ] ) ? 'selected' : ''; ?>><?php esc_html_e ( 'h2', 'easy-table-of-contents' ); ?></option> <option value="h3" <?php echo ( 'h3' == $instance[ 'heading_label_tag' ] ) ? 'selected=' : ''; ?> ><?php esc_html_e ( 'h3', 'easy-table-of-contents' ); ?></option> <option value="h4" <?php echo ( 'h4' == $instance[ 'heading_label_tag' ] ) ? 'selected=' : ''; ?>><?php esc_html_e ( 'h4', 'easy-table-of-contents' ); ?></option> <option value="h5" <?php echo ( 'h5' == $instance[ 'heading_label_tag' ] ) ? 'selected=' : ''; ?>><?php esc_html_e ( 'h5', 'easy-table-of-contents' ); ?></option> <option value="h6" <?php echo ( 'h6' == $instance[ 'heading_label_tag' ] ) ? 'selected=' : ''; ?>><?php esc_html_e ( 'h6', 'easy-table-of-contents' ); ?></option> <option value="p" <?php echo ( 'p' == $instance[ 'heading_label_tag' ] ) ? 'selected=' : ''; ?>><?php esc_html_e ( 'p', 'easy-table-of-contents' ); ?></option> <option value="span" <?php echo ( 'span' == $instance[ 'heading_label_tag' ] ) ? 'selected=' : ''; ?>><?php esc_html_e ( 'span', 'easy-table-of-contents' ); ?></option> <option value="div" <?php echo ( 'div' == $instance[ 'heading_label_tag' ] ) ? 'selected=' : ''; ?>><?php esc_html_e ( 'div', 'easy-table-of-contents' ); ?></option> </select> </div> </div> </div> <p style="display: <?php echo ezTOC_Option::get( 'widget_affix_selector' ) ? 'block' : 'none'; ?>;"> <input class="checkbox" type="checkbox" <?php checked( $instance['affix'], 1 ); ?> id="<?php echo esc_attr($this->get_field_id('affix')); ?>" name="<?php echo esc_attr($this->get_field_name('affix')); ?>" value="1"/> <label for="<?php echo esc_attr($this->get_field_id('affix')); ?>"> <?php esc_html_e( 'Affix or pin the widget.', 'easy-table-of-contents' ); ?></label> </p> <p class="description" style="display: <?php echo ezTOC_Option::get( 'widget_affix_selector' ) ? 'block' : 'none'; ?>;"> <?php esc_html_e( 'If you choose to affix the widget, do not add any other widgets on the sidebar. Also, make sure you have only one instance Table of Contents widget on the page.', 'easy-table-of-contents' ); ?> </p> <?php } } // end class add_action( 'widgets_init', array( 'ezTOC_Widget', 'register' ) ); }