PATH:
home
/
niazsaze
/
public_html
/
wp-content
/
plugins
/
woocommerce
/
includes
/
admin
/
settings
<?php declare( strict_types = 1); // @codingStandardsIgnoreLine. /** * WooCommerce Checkout Settings * * @package WooCommerce\Admin */ defined( 'ABSPATH' ) || exit; if ( class_exists( 'WC_Settings_Payment_Gateways_React', false ) ) { return new WC_Settings_Payment_Gateways_React(); } /** * WC_Settings_Payment_Gateways_React. */ class WC_Settings_Payment_Gateways_React extends WC_Settings_Page { /** * Get the whitelist of sections to render using React. * * @return array List of section identifiers. */ private function get_reactify_render_sections() { $sections = array( 'offline', 'woocommerce_payments', 'main', ); /** * Filters the list of payment settings sections to be rendered using React. * * @since 9.3.0 * * @param array $sections List of section identifiers. */ return apply_filters( 'experimental_woocommerce_admin_payment_reactify_render_sections', $sections ); } /** * Constructor. */ public function __construct() { $this->id = 'checkout'; $this->label = _x( 'Payments', 'Settings tab label', 'woocommerce' ); parent::__construct(); } /** * Output the settings. */ public function output() { //phpcs:disable WordPress.Security.NonceVerification.Recommended global $current_section; // Load gateways so we can show any global options they may have. $payment_gateways = WC()->payment_gateways->payment_gateways(); if ( $this->should_render_react_section( $current_section ) ) { $this->render_react_section( $current_section ); } elseif ( $current_section ) { $this->render_classic_gateway_settings_page( $payment_gateways, $current_section ); } else { $this->render_react_section( 'main' ); } parent::output(); //phpcs:enable } /** * Check if the given section should be rendered using React. * * @param string $section The section to check. * @return bool Whether the section should be rendered using React. */ private function should_render_react_section( $section ) { return in_array( $section, $this->get_reactify_render_sections(), true ); } /** * Render the React section. * * @param string $section The section to render. */ private function render_react_section( $section ) { global $hide_save_button; $hide_save_button = true; echo '<div id="experimental_wc_settings_payments_' . esc_attr( $section ) . '"></div>'; } /** * Render the classic gateway settings page. * * @param array $payment_gateways The payment gateways. * @param string $current_section The current section. */ private function render_classic_gateway_settings_page( $payment_gateways, $current_section ) { foreach ( $payment_gateways as $gateway ) { if ( in_array( $current_section, array( $gateway->id, sanitize_title( get_class( $gateway ) ) ), true ) ) { if ( isset( $_GET['toggle_enabled'] ) ) { // phpcs:ignore WordPress.Security.NonceVerification.Recommended $enabled = $gateway->get_option( 'enabled' ); if ( $enabled ) { $gateway->settings['enabled'] = wc_string_to_bool( $enabled ) ? 'no' : 'yes'; } } $this->run_gateway_admin_options( $gateway ); break; } } } /** * Run the 'admin_options' method on a given gateway. * This method exists to easy unit testing. * * @param object $gateway The gateway object to run the method on. */ protected function run_gateway_admin_options( $gateway ) { $gateway->admin_options(); } /** * Don't show any section links. * * @return array */ public function get_sections() { return array(); } /** * Save settings. */ public function save() { global $current_section; $wc_payment_gateways = WC_Payment_Gateways::instance(); $this->save_settings_for_current_section(); if ( ! $current_section ) { // If section is empty, we're on the main settings page. This makes sure 'gateway ordering' is saved. $wc_payment_gateways->process_admin_options(); $wc_payment_gateways->init(); } else { // There is a section - this may be a gateway or custom section. foreach ( $wc_payment_gateways->payment_gateways() as $gateway ) { if ( in_array( $current_section, array( $gateway->id, sanitize_title( get_class( $gateway ) ) ), true ) ) { /** * Fires update actions for payment gateways. * * @since 3.4.0 * * @param int $gateway->id Gateway ID. */ do_action( 'woocommerce_update_options_payment_gateways_' . $gateway->id ); $wc_payment_gateways->init(); } } $this->do_update_options_action(); } } } return new WC_Settings_Payment_Gateways_React();
[-] class-wc-settings-products.php
[edit]
[-] class-wc-settings-payment-gateways.php
[edit]
[-] class-wc-settings-payment-gateways-react.php
[edit]
[-] class-wc-settings-site-visibility.php
[edit]
[-] class-wc-settings-checkout.php
[edit]
[+]
views
[-] class-wc-settings-accounts.php
[edit]
[-] class-wc-settings-general.php
[edit]
[-] class-wc-settings-page.php
[edit]
[-] class-wc-settings-integrations.php
[edit]
[-] class-wc-settings-shipping.php
[edit]
[-] class-wc-settings-emails.php
[edit]
[-] class-wc-settings-tax.php
[edit]
[+]
..
[-] class-wc-settings-advanced.php
[edit]