File: /var/www/studis.kauko.lt/wp-content/plugins/polylang/include/Options/Business/Browser.php
<?php
/**
* @package Polylang
*/
namespace WP_Syntex\Polylang\Options\Business;
use WP_Error;
use WP_Syntex\Polylang\Options\Primitive\Abstract_Boolean;
use WP_Syntex\Polylang\Options\Options;
defined( 'ABSPATH' ) || exit;
/**
* Class defining the "Detect browser language" boolean option.
* /!\ Sanitization depends on `force_lang`: this option must be set AFTER `force_lang`.
*
* @since 3.7
*/
class Browser extends Abstract_Boolean {
/**
* Returns option key.
*
* @since 3.7
*
* @return string
*
* @phpstan-return 'browser'
*/
public static function key(): string {
return 'browser';
}
/**
* Sanitizes option's value.
* Can populate the `$errors` property with blocking and non-blocking errors: in case of non-blocking errors,
* the value is sanitized and can be stored.
*
* @since 3.7
*
* @param bool $value Value to sanitize.
* @param Options $options All options.
* @return bool|WP_Error The sanitized value. An instance of `WP_Error` in case of blocking error.
*/
protected function sanitize( $value, Options $options ) {
if ( 3 === $options->get( 'force_lang' ) && ! class_exists( 'PLL_Xdata_Domain', true ) ) {
// Cannot share cookies between domains without Polylang Pro.
return false;
}
/** @var bool|WP_Error */
$value = parent::sanitize( $value, $options );
return $value;
}
/**
* Returns the description used in the JSON schema.
*
* @since 3.7
*
* @return string
*/
protected function get_description(): string {
return sprintf(
/* translators: %1$s and %2$s are "true/false" values. */
__( 'Detect preferred browser language on front page: %1$s to detect, %2$s to not detect.', 'polylang' ),
'`true`',
'`false`'
);
}
}