119 lines
3.0 KiB
PHP
119 lines
3.0 KiB
PHP
|
<?php
|
||
|
/**
|
||
|
* WPSEO plugin file.
|
||
|
*
|
||
|
* @package WPSEO\Admin
|
||
|
*/
|
||
|
|
||
|
/**
|
||
|
* Generates and displays the React root element for a metabox section.
|
||
|
*/
|
||
|
class WPSEO_Metabox_Section_React implements WPSEO_Metabox_Section {
|
||
|
|
||
|
/**
|
||
|
* Name of the section, used as an identifier in the HTML.
|
||
|
*
|
||
|
* @var string
|
||
|
*/
|
||
|
public $name;
|
||
|
|
||
|
/**
|
||
|
* Content to use before the React root node.
|
||
|
*
|
||
|
* @var string
|
||
|
*/
|
||
|
public $content;
|
||
|
|
||
|
/**
|
||
|
* Content to use to display the button to open this content block.
|
||
|
*
|
||
|
* @var string
|
||
|
*/
|
||
|
private $link_content;
|
||
|
|
||
|
/**
|
||
|
* Class to add to the link.
|
||
|
*
|
||
|
* @var string
|
||
|
*/
|
||
|
private $link_class;
|
||
|
|
||
|
/**
|
||
|
* Aria label to use for the link.
|
||
|
*
|
||
|
* @var string
|
||
|
*/
|
||
|
private $link_aria_label;
|
||
|
|
||
|
/**
|
||
|
* Additional html content to be displayed within the section.
|
||
|
*
|
||
|
* @var string
|
||
|
*/
|
||
|
private $html_after;
|
||
|
|
||
|
/**
|
||
|
* Constructor.
|
||
|
*
|
||
|
* @param string $name The name of the section, used as an identifier in the html.
|
||
|
* Can only contain URL safe characters.
|
||
|
* @param string $link_content The text content of the section link.
|
||
|
* @param string $content Optional. Content to use above the React root element.
|
||
|
* @param array $options Optional link attributes.
|
||
|
*/
|
||
|
public function __construct( $name, $link_content, $content = '', array $options = [] ) {
|
||
|
$this->name = $name;
|
||
|
$this->content = $content;
|
||
|
|
||
|
$default_options = [
|
||
|
'link_class' => '',
|
||
|
'link_aria_label' => '',
|
||
|
'html_after' => '',
|
||
|
];
|
||
|
|
||
|
$options = wp_parse_args( $options, $default_options );
|
||
|
|
||
|
$this->link_content = $link_content;
|
||
|
$this->link_class = $options['link_class'];
|
||
|
$this->link_aria_label = $options['link_aria_label'];
|
||
|
$this->html_after = $options['html_after'];
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Outputs the section link.
|
||
|
*
|
||
|
* @return void
|
||
|
*/
|
||
|
public function display_link() {
|
||
|
printf(
|
||
|
'<li role="presentation"><a role="tab" href="#wpseo-meta-section-%1$s" id="wpseo-meta-tab-%1$s" aria-controls="wpseo-meta-section-%1$s" class="wpseo-meta-section-link %2$s"%3$s>%4$s</a></li>',
|
||
|
esc_attr( $this->name ),
|
||
|
esc_attr( $this->link_class ),
|
||
|
( $this->link_aria_label !== '' ) ? ' aria-label="' . esc_attr( $this->link_aria_label ) . '"' : '',
|
||
|
wp_kses_post( $this->link_content )
|
||
|
);
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Outputs the section content.
|
||
|
*
|
||
|
* @return void
|
||
|
*/
|
||
|
public function display_content() {
|
||
|
add_filter( 'wp_kses_allowed_html', [ 'WPSEO_Utils', 'extend_kses_post_with_forms' ] );
|
||
|
add_filter( 'wp_kses_allowed_html', [ 'WPSEO_Utils', 'extend_kses_post_with_a11y' ] );
|
||
|
|
||
|
printf(
|
||
|
'<div role="tabpanel" id="wpseo-meta-section-%1$s" aria-labelledby="wpseo-meta-tab-%1$s" tabindex="0" class="wpseo-meta-section">',
|
||
|
esc_attr( $this->name )
|
||
|
);
|
||
|
echo wp_kses_post( $this->content );
|
||
|
echo '<div id="wpseo-metabox-root" class="wpseo-metabox-root"></div>';
|
||
|
echo wp_kses_post( $this->html_after );
|
||
|
echo '</div>';
|
||
|
|
||
|
remove_filter( 'wp_kses_allowed_html', [ 'WPSEO_Utils', 'extend_kses_post_with_forms' ] );
|
||
|
remove_filter( 'wp_kses_allowed_html', [ 'WPSEO_Utils', 'extend_kses_post_with_a11y' ] );
|
||
|
}
|
||
|
}
|