Edit File by line

Deprecated: str_replace(): Passing null to parameter #2 ($replace) of type array|string is deprecated in /home/sportsfever/public_html/filemanger/function.php on line 93
/home/sportsfe.../httpdocs/clone/wp-conte.../plugins/wordpres.../admin
File: class-yoast-form.php
<?php
[0] Fix | Delete
/**
[1] Fix | Delete
* WPSEO plugin file.
[2] Fix | Delete
*
[3] Fix | Delete
* @package WPSEO\Admin
[4] Fix | Delete
*/
[5] Fix | Delete
[6] Fix | Delete
use Yoast\WP\SEO\Presenters\Admin\Light_Switch_Presenter;
[7] Fix | Delete
use Yoast\WP\SEO\Presenters\Admin\Sidebar_Presenter;
[8] Fix | Delete
[9] Fix | Delete
/**
[10] Fix | Delete
* Admin form class.
[11] Fix | Delete
*
[12] Fix | Delete
* @since 2.0
[13] Fix | Delete
*/
[14] Fix | Delete
class Yoast_Form {
[15] Fix | Delete
[16] Fix | Delete
/**
[17] Fix | Delete
* Instance of this class
[18] Fix | Delete
*
[19] Fix | Delete
* @var Yoast_Form
[20] Fix | Delete
* @since 2.0
[21] Fix | Delete
*/
[22] Fix | Delete
public static $instance;
[23] Fix | Delete
[24] Fix | Delete
/**
[25] Fix | Delete
* The short name of the option to use for the current page.
[26] Fix | Delete
*
[27] Fix | Delete
* @var string
[28] Fix | Delete
* @since 2.0
[29] Fix | Delete
*/
[30] Fix | Delete
public $option_name;
[31] Fix | Delete
[32] Fix | Delete
/**
[33] Fix | Delete
* Option instance.
[34] Fix | Delete
*
[35] Fix | Delete
* @since 8.4
[36] Fix | Delete
* @var WPSEO_Option|null
[37] Fix | Delete
*/
[38] Fix | Delete
protected $option_instance = null;
[39] Fix | Delete
[40] Fix | Delete
/**
[41] Fix | Delete
* Get the singleton instance of this class.
[42] Fix | Delete
*
[43] Fix | Delete
* @since 2.0
[44] Fix | Delete
*
[45] Fix | Delete
* @return Yoast_Form
[46] Fix | Delete
*/
[47] Fix | Delete
public static function get_instance() {
[48] Fix | Delete
if ( ! ( self::$instance instanceof self ) ) {
[49] Fix | Delete
self::$instance = new self();
[50] Fix | Delete
}
[51] Fix | Delete
[52] Fix | Delete
return self::$instance;
[53] Fix | Delete
}
[54] Fix | Delete
[55] Fix | Delete
/**
[56] Fix | Delete
* Generates the header for admin pages.
[57] Fix | Delete
*
[58] Fix | Delete
* @since 2.0
[59] Fix | Delete
*
[60] Fix | Delete
* @param bool $form Whether or not the form start tag should be included.
[61] Fix | Delete
* @param string $option The short name of the option to use for the current page.
[62] Fix | Delete
* @param bool $contains_files Whether the form should allow for file uploads.
[63] Fix | Delete
* @param bool $option_long_name Group name of the option.
[64] Fix | Delete
*
[65] Fix | Delete
* @return void
[66] Fix | Delete
*/
[67] Fix | Delete
public function admin_header( $form = true, $option = 'wpseo', $contains_files = false, $option_long_name = false ) {
[68] Fix | Delete
if ( ! $option_long_name ) {
[69] Fix | Delete
$option_long_name = WPSEO_Options::get_group_name( $option );
[70] Fix | Delete
}
[71] Fix | Delete
?>
[72] Fix | Delete
<div class="wrap yoast wpseo-admin-page <?php echo esc_attr( 'page-' . $option ); ?>">
[73] Fix | Delete
<?php
[74] Fix | Delete
/**
[75] Fix | Delete
* Display the updated/error messages.
[76] Fix | Delete
* Only needed as our settings page is not under options, otherwise it will automatically be included.
[77] Fix | Delete
*
[78] Fix | Delete
* @see settings_errors()
[79] Fix | Delete
*/
[80] Fix | Delete
require_once ABSPATH . 'wp-admin/options-head.php';
[81] Fix | Delete
?>
[82] Fix | Delete
<h1 id="wpseo-title"><?php echo esc_html( get_admin_page_title() ); ?></h1>
[83] Fix | Delete
<div id="yst-settings-header-root"></div>
[84] Fix | Delete
<div class="wpseo_content_wrapper">
[85] Fix | Delete
<div class="wpseo_content_cell" id="wpseo_content_top">
[86] Fix | Delete
<?php
[87] Fix | Delete
if ( $form === true ) {
[88] Fix | Delete
$enctype = ( $contains_files ) ? ' enctype="multipart/form-data"' : '';
[89] Fix | Delete
[90] Fix | Delete
$network_admin = new Yoast_Network_Admin();
[91] Fix | Delete
if ( $network_admin->meets_requirements() ) {
[92] Fix | Delete
$action_url = network_admin_url( 'settings.php' );
[93] Fix | Delete
$hidden_fields_cb = [ $network_admin, 'settings_fields' ];
[94] Fix | Delete
}
[95] Fix | Delete
else {
[96] Fix | Delete
$action_url = admin_url( 'options.php' );
[97] Fix | Delete
$hidden_fields_cb = 'settings_fields';
[98] Fix | Delete
}
[99] Fix | Delete
[100] Fix | Delete
echo '<form action="'
[101] Fix | Delete
. esc_url( $action_url )
[102] Fix | Delete
. '" method="post" id="wpseo-conf"'
[103] Fix | Delete
. $enctype . ' accept-charset="' // phpcs:ignore WordPress.Security.EscapeOutput.OutputNotEscaped -- nothing to escape.
[104] Fix | Delete
. esc_attr( get_bloginfo( 'charset' ) )
[105] Fix | Delete
. '" novalidate="novalidate">';
[106] Fix | Delete
call_user_func( $hidden_fields_cb, $option_long_name );
[107] Fix | Delete
}
[108] Fix | Delete
$this->set_option( $option );
[109] Fix | Delete
}
[110] Fix | Delete
[111] Fix | Delete
/**
[112] Fix | Delete
* Set the option used in output for form elements.
[113] Fix | Delete
*
[114] Fix | Delete
* @since 2.0
[115] Fix | Delete
*
[116] Fix | Delete
* @param string $option_name Option key.
[117] Fix | Delete
*
[118] Fix | Delete
* @return void
[119] Fix | Delete
*/
[120] Fix | Delete
public function set_option( $option_name ) {
[121] Fix | Delete
$this->option_name = $option_name;
[122] Fix | Delete
[123] Fix | Delete
$this->option_instance = WPSEO_Options::get_option_instance( $option_name );
[124] Fix | Delete
if ( ! $this->option_instance ) {
[125] Fix | Delete
$this->option_instance = null;
[126] Fix | Delete
}
[127] Fix | Delete
}
[128] Fix | Delete
[129] Fix | Delete
/**
[130] Fix | Delete
* Generates the footer for admin pages.
[131] Fix | Delete
*
[132] Fix | Delete
* @since 2.0
[133] Fix | Delete
*
[134] Fix | Delete
* @param bool $submit Whether or not a submit button and form end tag should be shown.
[135] Fix | Delete
* @param bool $show_sidebar Whether or not to show the banner sidebar - used by premium plugins to disable it.
[136] Fix | Delete
*
[137] Fix | Delete
* @return void
[138] Fix | Delete
*/
[139] Fix | Delete
public function admin_footer( $submit = true, $show_sidebar = true ) {
[140] Fix | Delete
if ( $submit ) {
[141] Fix | Delete
$settings_changed_listener = new WPSEO_Admin_Settings_Changed_Listener();
[142] Fix | Delete
echo '<div id="wpseo-submit-container">';
[143] Fix | Delete
[144] Fix | Delete
echo '<div id="wpseo-submit-container-float" class="wpseo-admin-submit">';
[145] Fix | Delete
submit_button( __( 'Save changes', 'wordpress-seo' ) );
[146] Fix | Delete
$settings_changed_listener->show_success_message();
[147] Fix | Delete
echo '</div>';
[148] Fix | Delete
[149] Fix | Delete
echo '<div id="wpseo-submit-container-fixed" class="wpseo-admin-submit wpseo-admin-submit-fixed" style="display: none;">';
[150] Fix | Delete
submit_button( __( 'Save changes', 'wordpress-seo' ) );
[151] Fix | Delete
$settings_changed_listener->show_success_message();
[152] Fix | Delete
echo '</div>';
[153] Fix | Delete
[154] Fix | Delete
echo '</div>';
[155] Fix | Delete
[156] Fix | Delete
echo '
[157] Fix | Delete
</form>';
[158] Fix | Delete
}
[159] Fix | Delete
[160] Fix | Delete
/**
[161] Fix | Delete
* Apply general admin_footer hooks.
[162] Fix | Delete
*/
[163] Fix | Delete
do_action( 'wpseo_admin_footer', $this );
[164] Fix | Delete
[165] Fix | Delete
/**
[166] Fix | Delete
* Run possibly set actions to add for example an i18n box.
[167] Fix | Delete
*/
[168] Fix | Delete
do_action( 'wpseo_admin_promo_footer' );
[169] Fix | Delete
[170] Fix | Delete
echo '
[171] Fix | Delete
</div><!-- end of div wpseo_content_top -->';
[172] Fix | Delete
[173] Fix | Delete
if ( $show_sidebar ) {
[174] Fix | Delete
$this->admin_sidebar();
[175] Fix | Delete
}
[176] Fix | Delete
[177] Fix | Delete
echo '</div><!-- end of div wpseo_content_wrapper -->';
[178] Fix | Delete
[179] Fix | Delete
do_action( 'wpseo_admin_below_content', $this );
[180] Fix | Delete
[181] Fix | Delete
echo '
[182] Fix | Delete
</div><!-- end of wrap -->';
[183] Fix | Delete
}
[184] Fix | Delete
[185] Fix | Delete
/**
[186] Fix | Delete
* Generates the sidebar for admin pages.
[187] Fix | Delete
*
[188] Fix | Delete
* @since 2.0
[189] Fix | Delete
*
[190] Fix | Delete
* @return void
[191] Fix | Delete
*/
[192] Fix | Delete
public function admin_sidebar() {
[193] Fix | Delete
// No banners in Premium.
[194] Fix | Delete
$addon_manager = new WPSEO_Addon_Manager();
[195] Fix | Delete
if ( YoastSEO()->helpers->product->is_premium() && $addon_manager->has_valid_subscription( WPSEO_Addon_Manager::PREMIUM_SLUG ) ) {
[196] Fix | Delete
return;
[197] Fix | Delete
}
[198] Fix | Delete
[199] Fix | Delete
$sidebar_presenter = new Sidebar_Presenter();
[200] Fix | Delete
// phpcs:ignore WordPress.Security.EscapeOutput.OutputNotEscaped -- Output escaped in presenter.
[201] Fix | Delete
echo $sidebar_presenter->present();
[202] Fix | Delete
}
[203] Fix | Delete
[204] Fix | Delete
/**
[205] Fix | Delete
* Output a label element.
[206] Fix | Delete
*
[207] Fix | Delete
* @since 2.0
[208] Fix | Delete
*
[209] Fix | Delete
* @param string $text Label text string, which can contain escaped html.
[210] Fix | Delete
* @param array $attr HTML attributes set.
[211] Fix | Delete
*
[212] Fix | Delete
* @return void
[213] Fix | Delete
*/
[214] Fix | Delete
public function label( $text, $attr ) {
[215] Fix | Delete
$defaults = [
[216] Fix | Delete
'class' => 'checkbox',
[217] Fix | Delete
'close' => true,
[218] Fix | Delete
'for' => '',
[219] Fix | Delete
'aria_label' => '',
[220] Fix | Delete
];
[221] Fix | Delete
[222] Fix | Delete
$attr = wp_parse_args( $attr, $defaults );
[223] Fix | Delete
$aria_label = '';
[224] Fix | Delete
if ( $attr['aria_label'] !== '' ) {
[225] Fix | Delete
$aria_label = ' aria-label="' . esc_attr( $attr['aria_label'] ) . '"';
[226] Fix | Delete
}
[227] Fix | Delete
[228] Fix | Delete
// phpcs:ignore WordPress.Security.EscapeOutput.OutputNotEscaped -- output escaped before. Specifically, the $text variable can contain escaped html.
[229] Fix | Delete
echo "<label class='" . esc_attr( $attr['class'] ) . "' for='" . esc_attr( $attr['for'] ) . "'$aria_label>$text";
[230] Fix | Delete
if ( $attr['close'] ) {
[231] Fix | Delete
echo '</label>';
[232] Fix | Delete
}
[233] Fix | Delete
}
[234] Fix | Delete
[235] Fix | Delete
/**
[236] Fix | Delete
* Output a legend element.
[237] Fix | Delete
*
[238] Fix | Delete
* @since 3.4
[239] Fix | Delete
*
[240] Fix | Delete
* @param string $text Legend text string.
[241] Fix | Delete
* @param array $attr HTML attributes set.
[242] Fix | Delete
*
[243] Fix | Delete
* @return void
[244] Fix | Delete
*/
[245] Fix | Delete
public function legend( $text, $attr ) {
[246] Fix | Delete
$defaults = [
[247] Fix | Delete
'id' => '',
[248] Fix | Delete
'class' => '',
[249] Fix | Delete
];
[250] Fix | Delete
$attr = wp_parse_args( $attr, $defaults );
[251] Fix | Delete
[252] Fix | Delete
$id = ( $attr['id'] === '' ) ? '' : ' id="' . esc_attr( $attr['id'] ) . '"';
[253] Fix | Delete
// phpcs:ignore WordPress.Security.EscapeOutput.OutputNotEscaped -- output escaped before.
[254] Fix | Delete
echo '<legend class="' . esc_attr( 'yoast-form-legend ' . $attr['class'] ) . '"' . $id . '>' . $text . '</legend>';
[255] Fix | Delete
}
[256] Fix | Delete
[257] Fix | Delete
/**
[258] Fix | Delete
* Create a Checkbox input field.
[259] Fix | Delete
*
[260] Fix | Delete
* @since 2.0
[261] Fix | Delete
*
[262] Fix | Delete
* @param string $variable The variable within the option to create the checkbox for.
[263] Fix | Delete
* @param string $label The label to show for the variable.
[264] Fix | Delete
* @param bool $label_left Whether the label should be left (true) or right (false).
[265] Fix | Delete
* @param array $attr Extra attributes to add to the checkbox.
[266] Fix | Delete
*
[267] Fix | Delete
* @return void
[268] Fix | Delete
*/
[269] Fix | Delete
public function checkbox( $variable, $label, $label_left = false, $attr = [] ) {
[270] Fix | Delete
$val = $this->get_field_value( $variable, false );
[271] Fix | Delete
[272] Fix | Delete
$defaults = [
[273] Fix | Delete
'disabled' => false,
[274] Fix | Delete
];
[275] Fix | Delete
$attr = wp_parse_args( $attr, $defaults );
[276] Fix | Delete
[277] Fix | Delete
if ( $val === true ) {
[278] Fix | Delete
$val = 'on';
[279] Fix | Delete
}
[280] Fix | Delete
[281] Fix | Delete
$class = '';
[282] Fix | Delete
if ( $label_left !== false ) {
[283] Fix | Delete
$this->label( $label_left, [ 'for' => $variable ] );
[284] Fix | Delete
}
[285] Fix | Delete
else {
[286] Fix | Delete
$class = 'double';
[287] Fix | Delete
}
[288] Fix | Delete
[289] Fix | Delete
$disabled_attribute = $this->get_disabled_attribute( $variable, $attr );
[290] Fix | Delete
[291] Fix | Delete
// phpcs:ignore WordPress.Security.EscapeOutput -- Reason: $disabled_attribute output is hardcoded and all other output is properly escaped.
[292] Fix | Delete
echo '<input class="', esc_attr( 'checkbox ' . $class ), '" type="checkbox" id="', esc_attr( $variable ), '" name="', esc_attr( $this->option_name . '[' . $variable . ']' ), '" value="on"', checked( $val, 'on', false ), $disabled_attribute, '/>';
[293] Fix | Delete
[294] Fix | Delete
if ( ! empty( $label ) ) {
[295] Fix | Delete
$this->label( $label, [ 'for' => $variable ] );
[296] Fix | Delete
}
[297] Fix | Delete
[298] Fix | Delete
echo '<br class="clear" />';
[299] Fix | Delete
}
[300] Fix | Delete
[301] Fix | Delete
/**
[302] Fix | Delete
* Creates a Checkbox input field list.
[303] Fix | Delete
*
[304] Fix | Delete
* @since 12.8
[305] Fix | Delete
*
[306] Fix | Delete
* @param string $variable The variables within the option to create the checkbox list for.
[307] Fix | Delete
* @param string $labels The labels to show for the variable.
[308] Fix | Delete
* @param array $attr Extra attributes to add to the checkbox list.
[309] Fix | Delete
*
[310] Fix | Delete
* @return void
[311] Fix | Delete
*/
[312] Fix | Delete
public function checkbox_list( $variable, $labels, $attr = [] ) {
[313] Fix | Delete
$defaults = [
[314] Fix | Delete
'disabled' => false,
[315] Fix | Delete
];
[316] Fix | Delete
$attr = wp_parse_args( $attr, $defaults );
[317] Fix | Delete
[318] Fix | Delete
$values = $this->get_field_value( $variable, [] );
[319] Fix | Delete
[320] Fix | Delete
foreach ( $labels as $name => $label ) {
[321] Fix | Delete
printf(
[322] Fix | Delete
'<input class="checkbox double" id="%1$s" type="checkbox" name="%2$s" %3$s %5$s value="%4$s"/>',
[323] Fix | Delete
esc_attr( $variable . '-' . $name ),
[324] Fix | Delete
esc_attr( $this->option_name . '[' . $variable . '][' . $name . ']' ),
[325] Fix | Delete
checked( ! empty( $values[ $name ] ), true, false ),
[326] Fix | Delete
esc_attr( $name ),
[327] Fix | Delete
disabled( ( isset( $attr['disabled'] ) && $attr['disabled'] ), true, false )
[328] Fix | Delete
);
[329] Fix | Delete
[330] Fix | Delete
printf(
[331] Fix | Delete
'<label class="checkbox" for="%1$s">%2$s</label>',
[332] Fix | Delete
esc_attr( $variable . '-' . $name ), // #1
[333] Fix | Delete
esc_html( $label )
[334] Fix | Delete
);
[335] Fix | Delete
echo '<br class="clear">';
[336] Fix | Delete
}
[337] Fix | Delete
}
[338] Fix | Delete
[339] Fix | Delete
/**
[340] Fix | Delete
* Create a light switch input field using a single checkbox.
[341] Fix | Delete
*
[342] Fix | Delete
* @since 3.1
[343] Fix | Delete
*
[344] Fix | Delete
* @param string $variable The variable within the option to create the checkbox for.
[345] Fix | Delete
* @param string $label The visual label text for the toggle.
[346] Fix | Delete
* @param array $buttons Array of two visual labels for the buttons (defaults Disabled/Enabled).
[347] Fix | Delete
* @param bool $reverse Reverse order of buttons (default true).
[348] Fix | Delete
* @param string $help Inline Help that will be printed out before the toggle.
[349] Fix | Delete
* @param bool $strong Whether the visual label is displayed in strong text. Default is false.
[350] Fix | Delete
* Starting from Yoast SEO 16.5, the visual label is forced to bold via CSS.
[351] Fix | Delete
* @param array $attr Extra attributes to add to the light switch.
[352] Fix | Delete
*
[353] Fix | Delete
* @return void
[354] Fix | Delete
*/
[355] Fix | Delete
public function light_switch( $variable, $label, $buttons = [], $reverse = true, $help = '', $strong = false, $attr = [] ) {
[356] Fix | Delete
$val = $this->get_field_value( $variable, false );
[357] Fix | Delete
[358] Fix | Delete
$defaults = [
[359] Fix | Delete
'disabled' => false,
[360] Fix | Delete
];
[361] Fix | Delete
$attr = wp_parse_args( $attr, $defaults );
[362] Fix | Delete
[363] Fix | Delete
if ( $val === true ) {
[364] Fix | Delete
$val = 'on';
[365] Fix | Delete
}
[366] Fix | Delete
[367] Fix | Delete
$disabled_attribute = $this->get_disabled_attribute( $variable, $attr );
[368] Fix | Delete
[369] Fix | Delete
$output = new Light_Switch_Presenter(
[370] Fix | Delete
$variable,
[371] Fix | Delete
$label,
[372] Fix | Delete
$buttons,
[373] Fix | Delete
$this->option_name . '[' . $variable . ']',
[374] Fix | Delete
$val,
[375] Fix | Delete
$reverse,
[376] Fix | Delete
$help,
[377] Fix | Delete
$strong,
[378] Fix | Delete
$disabled_attribute
[379] Fix | Delete
);
[380] Fix | Delete
[381] Fix | Delete
// phpcs:ignore WordPress.Security.EscapeOutput -- Reason: All output is properly escaped or hardcoded in the presenter.
[382] Fix | Delete
echo $output;
[383] Fix | Delete
}
[384] Fix | Delete
[385] Fix | Delete
/**
[386] Fix | Delete
* Create a Text input field.
[387] Fix | Delete
*
[388] Fix | Delete
* @since 2.0
[389] Fix | Delete
* @since 2.1 Introduced the `$attr` parameter.
[390] Fix | Delete
*
[391] Fix | Delete
* @param string $variable The variable within the option to create the text input field for.
[392] Fix | Delete
* @param string $label The label to show for the variable.
[393] Fix | Delete
* @param array|string $attr Extra attributes to add to the input field. Can be class, disabled, autocomplete.
[394] Fix | Delete
*
[395] Fix | Delete
* @return void
[396] Fix | Delete
*/
[397] Fix | Delete
public function textinput( $variable, $label, $attr = [] ) {
[398] Fix | Delete
$type = 'text';
[399] Fix | Delete
if ( ! is_array( $attr ) ) {
[400] Fix | Delete
$attr = [
[401] Fix | Delete
'class' => $attr,
[402] Fix | Delete
'disabled' => false,
[403] Fix | Delete
];
[404] Fix | Delete
}
[405] Fix | Delete
[406] Fix | Delete
$defaults = [
[407] Fix | Delete
'placeholder' => '',
[408] Fix | Delete
'class' => '',
[409] Fix | Delete
];
[410] Fix | Delete
$attr = wp_parse_args( $attr, $defaults );
[411] Fix | Delete
$val = $this->get_field_value( $variable, '' );
[412] Fix | Delete
if ( isset( $attr['type'] ) && $attr['type'] === 'url' ) {
[413] Fix | Delete
$val = urldecode( $val );
[414] Fix | Delete
$type = 'url';
[415] Fix | Delete
}
[416] Fix | Delete
$attributes = isset( $attr['autocomplete'] ) ? ' autocomplete="' . esc_attr( $attr['autocomplete'] ) . '"' : '';
[417] Fix | Delete
[418] Fix | Delete
$this->label(
[419] Fix | Delete
$label,
[420] Fix | Delete
[
[421] Fix | Delete
'for' => $variable,
[422] Fix | Delete
'class' => 'textinput',
[423] Fix | Delete
]
[424] Fix | Delete
);
[425] Fix | Delete
[426] Fix | Delete
$aria_attributes = Yoast_Input_Validation::get_the_aria_invalid_attribute( $variable );
[427] Fix | Delete
[428] Fix | Delete
Yoast_Input_Validation::set_error_descriptions();
[429] Fix | Delete
$aria_attributes .= Yoast_Input_Validation::get_the_aria_describedby_attribute( $variable );
[430] Fix | Delete
[431] Fix | Delete
$disabled_attribute = $this->get_disabled_attribute( $variable, $attr );
[432] Fix | Delete
[433] Fix | Delete
// phpcs:ignore WordPress.Security.EscapeOutput -- Reason: $disabled_attribute output is hardcoded and all other output is properly escaped.
[434] Fix | Delete
echo '<input', $attributes, $aria_attributes, ' class="', esc_attr( 'textinput ' . $attr['class'] ), '" placeholder="', esc_attr( $attr['placeholder'] ), '" type="', $type, '" id="', esc_attr( $variable ), '" name="', esc_attr( $this->option_name . '[' . $variable . ']' ), '" value="', esc_attr( $val ), '"', $disabled_attribute, '/>', '<br class="clear" />';
[435] Fix | Delete
// phpcs:ignore WordPress.Security.EscapeOutput.OutputNotEscaped -- Output escaped in getter.
[436] Fix | Delete
echo Yoast_Input_Validation::get_the_error_description( $variable );
[437] Fix | Delete
}
[438] Fix | Delete
[439] Fix | Delete
/**
[440] Fix | Delete
* Create a Number input field.
[441] Fix | Delete
*
[442] Fix | Delete
* @param string $variable The variable within the option to create the text input field for.
[443] Fix | Delete
* @param string $label The label to show for the variable.
[444] Fix | Delete
* @param array|string $attr Extra attributes to add to the input field. Can be class, disabled, autocomplete.
[445] Fix | Delete
*
[446] Fix | Delete
* @return void
[447] Fix | Delete
*/
[448] Fix | Delete
public function number( $variable, $label, $attr = [] ) {
[449] Fix | Delete
$type = 'number';
[450] Fix | Delete
$defaults = [
[451] Fix | Delete
'placeholder' => '',
[452] Fix | Delete
'class' => 'number',
[453] Fix | Delete
'disabled' => false,
[454] Fix | Delete
'min' => 0,
[455] Fix | Delete
'max' => 100,
[456] Fix | Delete
];
[457] Fix | Delete
$attr = wp_parse_args( $attr, $defaults );
[458] Fix | Delete
$val = $this->get_field_value( $variable, 0 );
[459] Fix | Delete
[460] Fix | Delete
$this->label(
[461] Fix | Delete
$label,
[462] Fix | Delete
[
[463] Fix | Delete
'for' => $variable,
[464] Fix | Delete
'class' => 'textinput ' . $attr['class'],
[465] Fix | Delete
]
[466] Fix | Delete
);
[467] Fix | Delete
[468] Fix | Delete
$aria_attributes = Yoast_Input_Validation::get_the_aria_invalid_attribute( $variable );
[469] Fix | Delete
[470] Fix | Delete
Yoast_Input_Validation::set_error_descriptions();
[471] Fix | Delete
$aria_attributes .= Yoast_Input_Validation::get_the_aria_describedby_attribute( $variable );
[472] Fix | Delete
[473] Fix | Delete
$disabled_attribute = $this->get_disabled_attribute( $variable, $attr );
[474] Fix | Delete
[475] Fix | Delete
// phpcs:ignore WordPress.Security.EscapeOutput -- Reason: $disabled_attribute output is hardcoded and all other output is properly escaped.
[476] Fix | Delete
echo '<input' . $aria_attributes . ' class="' . esc_attr( $attr['class'] ) . '" type="' . $type . '" id="', esc_attr( $variable ), '" min="', esc_attr( $attr['min'] ), '" max="', esc_attr( $attr['max'] ), '" name="', esc_attr( $this->option_name . '[' . $variable . ']' ), '" value="', esc_attr( $val ), '"', $disabled_attribute, '/>', '<br class="clear" />';
[477] Fix | Delete
// phpcs:ignore WordPress.Security.EscapeOutput.OutputNotEscaped -- Output escaped in getter.
[478] Fix | Delete
echo Yoast_Input_Validation::get_the_error_description( $variable );
[479] Fix | Delete
}
[480] Fix | Delete
[481] Fix | Delete
/**
[482] Fix | Delete
* Creates a text input field with with the ability to add content after the label.
[483] Fix | Delete
*
[484] Fix | Delete
* @param string $variable The variable within the option to create the text input field for.
[485] Fix | Delete
* @param string $label The label to show for the variable.
[486] Fix | Delete
* @param array $attr Extra attributes to add to the input field.
[487] Fix | Delete
*
[488] Fix | Delete
* @return void
[489] Fix | Delete
*/
[490] Fix | Delete
public function textinput_extra_content( $variable, $label, $attr = [] ) {
[491] Fix | Delete
$type = 'text';
[492] Fix | Delete
[493] Fix | Delete
$defaults = [
[494] Fix | Delete
'class' => 'yoast-field-group__inputfield',
[495] Fix | Delete
'disabled' => false,
[496] Fix | Delete
];
[497] Fix | Delete
[498] Fix | Delete
$attr = wp_parse_args( $attr, $defaults );
[499] Fix | Delete
It is recommended that you Edit text format, this type of Fix handles quite a lot in one request
Function