PK
Current Path : /proc/self/cwd/wp-content/plugins/woocommerce/src/Admin/Features/Blueprint/ |
Current File : //proc/self/cwd/wp-content/plugins/woocommerce/src/Admin/Features/Blueprint/SettingOptions.php |
<?php declare( strict_types = 1 ); namespace Automattic\WooCommerce\Admin\Features\Blueprint; /** * Handles getting options from WooCommerce settings pages. * * Class SettingOptions */ class SettingOptions { /** * Setting option controller. * * @var \WC_REST_Setting_Options_Controller */ private $setting_option_controller; /** * Ignore setting types. * * @var array */ private $ignore_setting_types = array( 'title', 'sectionend', 'slotfill_placeholder', 'hidden' ); /** * Constructor. */ public function __construct() { $this->setting_option_controller = new \WC_REST_Setting_Options_Controller(); } /** * Get options for a specific settings page. * * @param string $page_id The page ID. * @return array * * @throws \Exception If the settings page is not found. */ public function get_page_options( $page_id ) { $settings = $this->setting_option_controller->get_group_settings( $page_id ); if ( is_wp_error( $settings ) ) { throw new \Exception( esc_html( $settings->get_error_message() ) ); } $page_options = array(); foreach ( $settings as $setting ) { // Skip if the setting type is not valid. if ( in_array( $setting['type'], $this->ignore_setting_types, true ) || ! isset( $setting['id'] ) ) { continue; } $key = is_array( $setting['option_key'] ) ? $setting['option_key'][0] : $setting['option_key']; // Skip if the option key is already in the page options. if ( in_array( $key, $page_options, true ) ) { continue; } $default_value = $setting['default'] ?? null; $page_options[ $key ] = get_option( $key, $default_value ); } return $page_options; } }