WC_Settings_General::get_settings_for_default_sectionprotectedWC 1.0

Get settings or the default section.

Метод класса: WC_Settings_General{}

Хуки из метода

Возвращает

Массив.

Использование

// protected - в коде основоного (родительского) или дочернего класса
$result = $this->get_settings_for_default_section();

Код WC_Settings_General::get_settings_for_default_section() WC 10.0.2

protected function get_settings_for_default_section() {

	$currency_code_options = get_woocommerce_currencies();

	foreach ( $currency_code_options as $code => $name ) {
		$currency_code_options[ $code ] = $name . ' (' . get_woocommerce_currency_symbol( $code ) . ') — ' . esc_html( $code );
	}

	$enable_address_autocomplete_setting             = array();
	$address_autocomplete_preferred_provider_setting = array();
	$address_autocomplete_setting_desc_tip           = __( 'Suggest full addresses for customer as they type.', 'woocommerce' );

	if ( Features::is_enabled( 'experimental-blocks' ) ) {
		// This is in a try because getting the class from the container may fail if the class is not available.
		// If it fails, these settings should not be shown as the feature is not available.
		try {
			$address_provider_class         = wc_get_container()->get( AddressProviderController::class );
			$address_autocomplete_providers = $address_provider_class->get_providers();
			$address_autocomplete_available = ! empty( $address_autocomplete_providers );

			if ( ! $address_autocomplete_available ) {
				// translators: %s: WooPayments URL.
				$address_autocomplete_setting_desc_tip .= ' ' . sprintf( __( 'To use this feature, you need to install an address provider such as <a href="%s">WooPayments</a>.', 'woocommerce' ), 'https://woocommerce.com/products/woocommerce-payments/' );
			}

			$enable_address_autocomplete_setting = array(
				'id'       => 'woocommerce_address_autocomplete_enabled',
				'desc'     => __( 'Enable predictive address search', 'woocommerce' ),
				'name'     => __( 'Address autocomplete', 'woocommerce' ),
				'type'     => 'checkbox',
				'disabled' => ! $address_autocomplete_available,
				'desc_tip' => $address_autocomplete_setting_desc_tip,
				'default'  => 'no',
			);

			// If no providers are available, make sure the checkbox is unchecked.
			if ( ! $address_autocomplete_available ) {
				$enable_address_autocomplete_setting['value'] = false;
			}

			if ( count( $address_autocomplete_providers ) > 1 ) {
				$address_provider_options = array();
				foreach ( $address_autocomplete_providers as $address_provider ) {
					$address_provider_options[ $address_provider->id ] = $address_provider->name;
				}
				$address_autocomplete_preferred_provider_setting = array(
					'id'      => 'woocommerce_address_autocomplete_provider',
					'name'    => __( 'Preferred address autocomplete provider', 'woocommerce' ),
					'type'    => 'select',
					'class'   => 'wc-enhanced-select',
					'default' => $address_autocomplete_providers[0]->id ?? '',
					'options' => $address_provider_options,
				);
			}
		} catch ( \Exception $e ) {
			// If the class is not available, we don't want to show the setting.
			wc_get_logger()->log( 'error', 'Error getting address provider class: ' . $e->getMessage() );
			$enable_address_autocomplete_setting             = array();
			$address_autocomplete_preferred_provider_setting = array();
		}
	}

	$settings =
		array(

			array(
				'title' => __( 'Store Address', 'woocommerce' ),
				'type'  => 'title',
				'desc'  => __( 'This is where your business is located. Tax rates and shipping rates will use this address.', 'woocommerce' ),
				'id'    => 'store_address',
			),

			array(
				'title'    => __( 'Address line 1', 'woocommerce' ),
				'desc'     => __( 'The street address for your business location.', 'woocommerce' ),
				'id'       => 'woocommerce_store_address',
				'default'  => '',
				'type'     => 'text',
				'desc_tip' => true,
			),

			array(
				'title'    => __( 'Address line 2', 'woocommerce' ),
				'desc'     => __( 'An additional, optional address line for your business location.', 'woocommerce' ),
				'id'       => 'woocommerce_store_address_2',
				'default'  => '',
				'type'     => 'text',
				'desc_tip' => true,
			),

			array(
				'title'    => __( 'City', 'woocommerce' ),
				'desc'     => __( 'The city in which your business is located.', 'woocommerce' ),
				'id'       => 'woocommerce_store_city',
				'default'  => '',
				'type'     => 'text',
				'desc_tip' => true,
			),

			array(
				'title'    => __( 'Country / State', 'woocommerce' ),
				'desc'     => __( 'The country and state or province, if any, in which your business is located.', 'woocommerce' ),
				'id'       => 'woocommerce_default_country',
				'default'  => 'US:CA',
				'type'     => 'single_select_country',
				'desc_tip' => true,
			),

			array(
				'title'    => __( 'Postcode / ZIP', 'woocommerce' ),
				'desc'     => __( 'The postal code, if any, in which your business is located.', 'woocommerce' ),
				'id'       => 'woocommerce_store_postcode',
				'css'      => 'min-width:50px;',
				'default'  => '',
				'type'     => 'text',
				'desc_tip' => true,
			),

			array(
				'type' => 'sectionend',
				'id'   => 'store_address',
			),

			array(
				'title' => __( 'General options', 'woocommerce' ),
				'type'  => 'title',
				'desc'  => '',
				'id'    => 'general_options',
			),

			array(
				'title'    => __( 'Selling location(s)', 'woocommerce' ),
				'desc'     => __( 'This option lets you limit which countries you are willing to sell to.', 'woocommerce' ),
				'id'       => 'woocommerce_allowed_countries',
				'default'  => 'all',
				'type'     => 'select',
				'class'    => 'wc-enhanced-select',
				'css'      => 'min-width: 350px;',
				'desc_tip' => true,
				'options'  => array(
					'all'        => __( 'Sell to all countries', 'woocommerce' ),
					'all_except' => __( 'Sell to all countries, except for&hellip;', 'woocommerce' ),
					'specific'   => __( 'Sell to specific countries', 'woocommerce' ),
				),
			),

			array(
				'title'   => __( 'Sell to all countries, except for&hellip;', 'woocommerce' ),
				'desc'    => '',
				'id'      => 'woocommerce_all_except_countries',
				'css'     => 'min-width: 350px;',
				'default' => '',
				'type'    => 'multi_select_countries',
			),

			array(
				'title'   => __( 'Sell to specific countries', 'woocommerce' ),
				'desc'    => '',
				'id'      => 'woocommerce_specific_allowed_countries',
				'css'     => 'min-width: 350px;',
				'default' => '',
				'type'    => 'multi_select_countries',
			),

			array(
				'title'    => __( 'Shipping location(s)', 'woocommerce' ),
				'desc'     => __( 'Choose which countries you want to ship to, or choose to ship to all locations you sell to.', 'woocommerce' ),
				'id'       => 'woocommerce_ship_to_countries',
				'default'  => '',
				'type'     => 'select',
				'class'    => 'wc-enhanced-select',
				'desc_tip' => true,
				'options'  => array(
					''         => __( 'Ship to all countries you sell to', 'woocommerce' ),
					'all'      => __( 'Ship to all countries', 'woocommerce' ),
					'specific' => __( 'Ship to specific countries only', 'woocommerce' ),
					'disabled' => __( 'Disable shipping &amp; shipping calculations', 'woocommerce' ),
				),
			),

			array(
				'title'   => __( 'Ship to specific countries', 'woocommerce' ),
				'desc'    => '',
				'id'      => 'woocommerce_specific_ship_to_countries',
				'css'     => '',
				'default' => '',
				'type'    => 'multi_select_countries',
			),

			array(
				'title'    => __( 'Default customer location', 'woocommerce' ),
				'id'       => 'woocommerce_default_customer_address',
				'desc_tip' => __( 'This option determines a customers default location. The MaxMind GeoLite Database will be periodically downloaded to your wp-content directory if using geolocation.', 'woocommerce' ),
				'default'  => 'base',
				'type'     => 'select',
				'class'    => 'wc-enhanced-select',
				'options'  => array(
					''                 => __( 'No location by default', 'woocommerce' ),
					'base'             => __( 'Shop country/region', 'woocommerce' ),
					'geolocation'      => __( 'Geolocate', 'woocommerce' ),
					'geolocation_ajax' => __( 'Geolocate (with page caching support)', 'woocommerce' ),
				),
			),

			$enable_address_autocomplete_setting,

			$address_autocomplete_preferred_provider_setting,

			array(
				'title'    => __( 'Enable taxes', 'woocommerce' ),
				'desc'     => __( 'Enable tax rates and calculations', 'woocommerce' ),
				'id'       => 'woocommerce_calc_taxes',
				'default'  => 'no',
				'type'     => 'checkbox',
				'desc_tip' => __( 'Rates will be configurable and taxes will be calculated during checkout.', 'woocommerce' ),
			),

			array(
				'title'           => __( 'Enable coupons', 'woocommerce' ),
				'desc'            => __( 'Enable the use of coupon codes', 'woocommerce' ),
				'id'              => 'woocommerce_enable_coupons',
				'default'         => 'yes',
				'type'            => 'checkbox',
				'checkboxgroup'   => 'start',
				'show_if_checked' => 'option',
				'desc_tip'        => __( 'Coupons can be applied from the cart and checkout pages.', 'woocommerce' ),
			),

			array(
				'desc'            => __( 'Calculate coupon discounts sequentially', 'woocommerce' ),
				'id'              => 'woocommerce_calc_discounts_sequentially',
				'default'         => 'no',
				'type'            => 'checkbox',
				'desc_tip'        => __( 'When applying multiple coupons, apply the first coupon to the full price and the second coupon to the discounted price and so on.', 'woocommerce' ),
				'show_if_checked' => 'yes',
				'checkboxgroup'   => 'end',
				'autoload'        => false,
			),

			array(
				'type' => 'sectionend',
				'id'   => 'general_options',
			),

			array(
				'title' => __( 'Currency options', 'woocommerce' ),
				'type'  => 'title',
				'desc'  => __( 'The following options affect how prices are displayed on the frontend.', 'woocommerce' ),
				'id'    => 'pricing_options',
			),

			array(
				'title'    => __( 'Currency', 'woocommerce' ),
				'desc'     => __( 'This controls what currency prices are listed at in the catalog and which currency gateways will take payments in.', 'woocommerce' ),
				'id'       => 'woocommerce_currency',
				'default'  => 'USD',
				'type'     => 'select',
				'class'    => 'wc-enhanced-select',
				'desc_tip' => true,
				'options'  => $currency_code_options,
			),

			array(
				'title'    => __( 'Currency position', 'woocommerce' ),
				'desc'     => __( 'This controls the position of the currency symbol.', 'woocommerce' ),
				'id'       => 'woocommerce_currency_pos',
				'class'    => 'wc-enhanced-select',
				'default'  => 'left',
				'type'     => 'select',
				'options'  => array(
					'left'        => __( 'Left', 'woocommerce' ),
					'right'       => __( 'Right', 'woocommerce' ),
					'left_space'  => __( 'Left with space', 'woocommerce' ),
					'right_space' => __( 'Right with space', 'woocommerce' ),
				),
				'desc_tip' => true,
			),

			array(
				'title'    => __( 'Thousand separator', 'woocommerce' ),
				'desc'     => __( 'This sets the thousand separator of displayed prices.', 'woocommerce' ),
				'id'       => 'woocommerce_price_thousand_sep',
				'css'      => 'width:50px;',
				'default'  => ',',
				'type'     => 'text',
				'desc_tip' => true,
			),

			array(
				'title'    => __( 'Decimal separator', 'woocommerce' ),
				'desc'     => __( 'This sets the decimal separator of displayed prices.', 'woocommerce' ),
				'id'       => 'woocommerce_price_decimal_sep',
				'css'      => 'width:50px;',
				'default'  => '.',
				'type'     => 'text',
				'desc_tip' => true,
			),

			array(
				'title'             => __( 'Number of decimals', 'woocommerce' ),
				'desc'              => __( 'This sets the number of decimal points shown in displayed prices.', 'woocommerce' ),
				'id'                => 'woocommerce_price_num_decimals',
				'css'               => 'width:50px;',
				'default'           => '2',
				'desc_tip'          => true,
				'type'              => 'number',
				'custom_attributes' => array(
					'min'  => 0,
					'step' => 1,
				),
			),

			array(
				'type' => 'sectionend',
				'id'   => 'pricing_options',
			),
		);

	// Remove any empty items from settings array.
	// e.g. The preferred autocomplete provider setting would be empty if <=1 providers are registered.
	$settings = array_filter(
		$settings,
		function ( $setting ) {
			return ! empty( $setting );
		}
	);
	return apply_filters( 'woocommerce_general_settings', $settings );
}