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.../public_h.../wp-conte.../plugins/wordpres.../src/integrat...
File: feature-flag-integration.php
<?php
[0] Fix | Delete
[1] Fix | Delete
namespace Yoast\WP\SEO\Integrations;
[2] Fix | Delete
[3] Fix | Delete
use WPSEO_Admin_Asset_Manager;
[4] Fix | Delete
use Yoast\WP\SEO\Conditionals\Admin_Conditional;
[5] Fix | Delete
use Yoast\WP\SEO\Conditionals\Feature_Flag_Conditional;
[6] Fix | Delete
[7] Fix | Delete
/**
[8] Fix | Delete
* Gathers all feature flags and surfaces them to the JavaScript side of the plugin.
[9] Fix | Delete
*/
[10] Fix | Delete
class Feature_Flag_Integration implements Integration_Interface {
[11] Fix | Delete
[12] Fix | Delete
/**
[13] Fix | Delete
* The admin asset manager.
[14] Fix | Delete
*
[15] Fix | Delete
* @var WPSEO_Admin_Asset_Manager
[16] Fix | Delete
*/
[17] Fix | Delete
protected $asset_manager;
[18] Fix | Delete
[19] Fix | Delete
/**
[20] Fix | Delete
* All of the feature flag conditionals.
[21] Fix | Delete
*
[22] Fix | Delete
* @var Feature_Flag_Conditional[]
[23] Fix | Delete
*/
[24] Fix | Delete
protected $feature_flags;
[25] Fix | Delete
[26] Fix | Delete
/**
[27] Fix | Delete
* Feature_Flag_Integration constructor.
[28] Fix | Delete
*
[29] Fix | Delete
* @param WPSEO_Admin_Asset_Manager $asset_manager The admin asset manager.
[30] Fix | Delete
* @param Feature_Flag_Conditional ...$feature_flags All of the known feature flag conditionals.
[31] Fix | Delete
*/
[32] Fix | Delete
public function __construct( WPSEO_Admin_Asset_Manager $asset_manager, Feature_Flag_Conditional ...$feature_flags ) {
[33] Fix | Delete
$this->asset_manager = $asset_manager;
[34] Fix | Delete
$this->feature_flags = $feature_flags;
[35] Fix | Delete
}
[36] Fix | Delete
[37] Fix | Delete
/**
[38] Fix | Delete
* Returns the conditionals based on which this loadable should be active.
[39] Fix | Delete
*
[40] Fix | Delete
* @return string[] The conditionals based on which this loadable should be active.
[41] Fix | Delete
*/
[42] Fix | Delete
public static function get_conditionals() {
[43] Fix | Delete
return [ Admin_Conditional::class ];
[44] Fix | Delete
}
[45] Fix | Delete
[46] Fix | Delete
/**
[47] Fix | Delete
* Initializes the integration.
[48] Fix | Delete
*
[49] Fix | Delete
* @return void
[50] Fix | Delete
*/
[51] Fix | Delete
public function register_hooks() {
[52] Fix | Delete
\add_action( 'admin_init', [ $this, 'add_feature_flags' ] );
[53] Fix | Delete
}
[54] Fix | Delete
[55] Fix | Delete
/**
[56] Fix | Delete
* Gathers all the feature flags and injects them into the JavaScript.
[57] Fix | Delete
*
[58] Fix | Delete
* @return void
[59] Fix | Delete
*/
[60] Fix | Delete
public function add_feature_flags() {
[61] Fix | Delete
$enabled_features = $this->get_enabled_features();
[62] Fix | Delete
// Localize under both names for BC.
[63] Fix | Delete
$this->asset_manager->localize_script( 'feature-flag-package', 'wpseoFeatureFlags', $enabled_features );
[64] Fix | Delete
$this->asset_manager->localize_script( 'feature-flag-package', 'wpseoFeaturesL10n', $enabled_features );
[65] Fix | Delete
}
[66] Fix | Delete
[67] Fix | Delete
/**
[68] Fix | Delete
* Returns an array of all enabled feature flags.
[69] Fix | Delete
*
[70] Fix | Delete
* @return string[] The array of enabled features.
[71] Fix | Delete
*/
[72] Fix | Delete
public function get_enabled_features() {
[73] Fix | Delete
$enabled_features = [];
[74] Fix | Delete
foreach ( $this->feature_flags as $feature_flag ) {
[75] Fix | Delete
if ( $feature_flag->is_met() ) {
[76] Fix | Delete
$enabled_features[] = $feature_flag->get_feature_name();
[77] Fix | Delete
}
[78] Fix | Delete
}
[79] Fix | Delete
[80] Fix | Delete
return $this->filter_enabled_features( $enabled_features );
[81] Fix | Delete
}
[82] Fix | Delete
[83] Fix | Delete
/**
[84] Fix | Delete
* Runs the list of enabled feature flags through a filter.
[85] Fix | Delete
*
[86] Fix | Delete
* @param string[] $enabled_features The list of currently enabled feature flags.
[87] Fix | Delete
*
[88] Fix | Delete
* @return string[] The (possibly adapted) list of enabled features.
[89] Fix | Delete
*/
[90] Fix | Delete
protected function filter_enabled_features( $enabled_features ) {
[91] Fix | Delete
/**
[92] Fix | Delete
* Filters the list of currently enabled feature flags.
[93] Fix | Delete
*
[94] Fix | Delete
* @param string[] $enabled_features The current list of enabled feature flags.
[95] Fix | Delete
*/
[96] Fix | Delete
$filtered_enabled_features = \apply_filters( 'wpseo_enable_feature', $enabled_features );
[97] Fix | Delete
[98] Fix | Delete
if ( ! \is_array( $filtered_enabled_features ) ) {
[99] Fix | Delete
$filtered_enabled_features = $enabled_features;
[100] Fix | Delete
}
[101] Fix | Delete
[102] Fix | Delete
return $filtered_enabled_features;
[103] Fix | Delete
}
[104] Fix | Delete
}
[105] Fix | Delete
[106] Fix | Delete
It is recommended that you Edit text format, this type of Fix handles quite a lot in one request
Function