1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
|
<?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; } }
|