Automattic\WooCommerce\Internal\Admin\WCPayPromotion
Init{} │ WC 1.0
WooPayments Promotion engine.
Хуков нет.
Использование
$Init = new Init();
// use class methods
Методы
- public __construct()
- public add_action( 'admin_enqueue_scripts', array( __CLASS__, 'load_payment_method_promotions' ) )
- public if ( ! is_array( $specs ) || 0 === count( $specs ) )
- public isset( $_GET['page'] )
- ERROR: no method name found on line ``
- ERROR: no method name found on line `* @return array List of gateway classes.`
- ERROR: no method name found on line `// If the React-based Payments settings page is enabled, we don't need the old WooPayments promotion system,`
- ERROR: no method name found on line `*/`
- ERROR: no method name found on line `/* phpcs:disable WordPress.Security.NonceVerification */`
- public add_filter( 'woocommerce_payment_gateways', array( __CLASS__, 'possibly_register_pre_install_wc_pay_promotion_gateway' ) )
- public add_component_settings( $settings )
- ERROR: no method name found on line `// When specs are not empty but have errors, save for 3 hours.`
- ERROR: no method name found on line `* @return array`
- ERROR: no method name found on line `return $wcpay_promotion && 'woocommerce_payments:woopay' === $wcpay_promotion->id;`
- ERROR: no method name found on line `* Checks if promoted gateway can be registered.`
- public static load_payment_method_promotions()
- ERROR: no method name found on line `* For visibility, we want WooPayments to be at the top of the list.`
- ERROR: no method name found on line `*`
- public static can_show_promotion()
- ERROR: no method name found on line ``
- public static delete_specs_transient()
- ERROR: no method name found on line `}`
- ERROR: no method name found on line `$id = WCPaymentGatewayPreInstallWCPayPromotion::GATEWAY_ID;`
- ERROR: no method name found on line `return;`
- public static is_woopay_eligible()
- ERROR: no method name found on line `$specs_to_save = null;`
- ERROR: no method name found on line `* @param array $settings Component settings.`
- public get_user_locale()
- ERROR: no method name found on line `/**`
- ERROR: no method name found on line `* @return array Modified ordering.`
- public static get_promotions()
- ERROR: no method name found on line `return $gateways;`
- ERROR: no method name found on line `* @return array`
- ERROR: no method name found on line ``
- ERROR: no method name found on line `*`
- ERROR: no method name found on line ``
- public static get_cached_or_default_promotions()
- ERROR: no method name found on line ``
- ERROR: no method name found on line ``
- ERROR: no method name found on line `return;`
- ERROR: no method name found on line `// as we will show the WooPayments suggestion with the new system.`
- ERROR: no method name found on line `return $results['suggestions'];`
- ERROR: no method name found on line `* @return boolean If promoted gateway should be registered.`
- ERROR: no method name found on line ``
- ERROR: no method name found on line `// When specs are not empty but have errors, save for 3 hours.`
- ERROR: no method name found on line ``
- public static get_wc_pay_promotion_spec( $fetch_from_remote = true )
- public static get_specs()
- ERROR: no method name found on line ``
- ERROR: no method name found on line `}`
- ERROR: no method name found on line `}`
- ERROR: no method name found on line ``
- ERROR: no method name found on line `*`
- ERROR: no method name found on line `* Possibly registers the pre-install WooPayments promoted gateway.`
- ERROR: no method name found on line `*/`
- ERROR: no method name found on line `* @param array $gateways List of gateway classes.`
- ERROR: no method name found on line ``
- ERROR: no method name found on line `/**`
- public static possibly_register_pre_install_wc_pay_promotion_gateway( $gateways )
- ERROR: no method name found on line ``
- ERROR: no method name found on line ``
- ERROR: no method name found on line ``
- ERROR: no method name found on line ``
- ERROR: no method name found on line `return $gateways;`
- ERROR: no method name found on line ``
- public static set_gateway_top_of_list( $ordering )
- ERROR: no method name found on line ``
- ERROR: no method name found on line `*`
- ERROR: no method name found on line `*`
- ERROR: no method name found on line `* @return array List of promotions.`
Код Init{} Init{}
WC 9.6.0
class Init extends RemoteSpecsEngine {
/**
* Constructor.
*/
public function __construct() {
// If the React-based Payments settings page is enabled, we don't need the old WooPayments promotion system,
// as we will show the WooPayments suggestion with the new system.
if ( Features::is_enabled( 'reactify-classic-payments-settings' ) ) {
return;
}
/* phpcs:disable WordPress.Security.NonceVerification */
$is_payments_setting_page = isset( $_GET['page'] ) && 'wc-settings' === $_GET['page'] && isset( $_GET['tab'] ) && 'checkout' === $_GET['tab'];
$is_wc_admin_page = isset( $_GET['page'] ) && 'wc-admin' === $_GET['page'];
if ( $is_payments_setting_page || $is_wc_admin_page ) {
add_filter( 'woocommerce_admin_shared_settings', array( $this, 'add_component_settings' ) );
}
if ( ! wp_is_json_request() && ! $is_payments_setting_page ) {
return;
}
add_filter( 'woocommerce_payment_gateways', array( __CLASS__, 'possibly_register_pre_install_wc_pay_promotion_gateway' ) );
add_filter( 'option_woocommerce_gateway_order', array( __CLASS__, 'set_gateway_top_of_list' ) );
add_filter( 'default_option_woocommerce_gateway_order', array( __CLASS__, 'set_gateway_top_of_list' ) );
add_action( 'admin_enqueue_scripts', array( __CLASS__, 'load_payment_method_promotions' ) );
add_action( 'update_option_woocommerce_default_country', array( $this, 'delete_specs_transient' ) );
}
/**
* Possibly registers the pre-install WooPayments promoted gateway.
*
* @param array $gateways List of gateway classes.
*
* @return array List of gateway classes.
*/
public static function possibly_register_pre_install_wc_pay_promotion_gateway( $gateways ) {
if ( self::can_show_promotion() && ! WCPaymentGatewayPreInstallWCPayPromotion::is_dismissed() ) {
$gateways[] = 'Automattic\WooCommerce\Internal\Admin\WCPayPromotion\WCPaymentGatewayPreInstallWCPayPromotion';
}
return $gateways;
}
/**
* Checks if promoted gateway can be registered.
*
* @return boolean If promoted gateway should be registered.
*/
public static function can_show_promotion() {
// Don't show if WooPayments is enabled.
if ( class_exists( '\WC_Payments' ) ) {
return false;
}
// Don't show if there is no WooPayments promotion spec.
$wc_pay_spec = self::get_wc_pay_promotion_spec();
if ( ! $wc_pay_spec ) {
return false;
}
return true;
}
/**
* By default, new payment gateways are put at the bottom of the list on the admin "Payments" settings screen.
* For visibility, we want WooPayments to be at the top of the list.
*
* @param array $ordering Existing ordering of the payment gateways.
*
* @return array Modified ordering.
*/
public static function set_gateway_top_of_list( $ordering ) {
$ordering = (array) $ordering;
$id = WCPaymentGatewayPreInstallWCPayPromotion::GATEWAY_ID;
// Only tweak the ordering if the list hasn't been reordered with WooCommerce Payments in it already.
if ( ! isset( $ordering[ $id ] ) || ! is_numeric( $ordering[ $id ] ) ) {
$is_empty = empty( $ordering ) || ( count( $ordering ) === 1 && $ordering[0] === false );
$ordering[ $id ] = $is_empty ? 0 : ( min( $ordering ) - 1 );
}
return $ordering;
}
/**
* Get WooPayments promotion spec.
*
* @param boolean $fetch_from_remote Whether to fetch the spec from remote or not.
*
* @return object|false WooPayments promotion spec or false if there isn't one.
*/
public static function get_wc_pay_promotion_spec( $fetch_from_remote = true ) {
$promotions = $fetch_from_remote ? self::get_promotions() : self::get_cached_or_default_promotions();
$wc_pay_promotion_spec = array_values(
array_filter(
$promotions,
function ( $promotion ) {
return isset( $promotion->plugins ) && in_array( 'woocommerce-payments', $promotion->plugins, true );
}
)
);
return current( $wc_pay_promotion_spec );
}
/**
* Go through the specs and run them.
*
* @return array List of promotions.
*/
public static function get_promotions() {
$locale = get_user_locale();
$specs = self::get_specs();
$results = EvaluateSuggestion::evaluate_specs( $specs, array( 'source' => 'wc-wcpay-promotions' ) );
$specs_to_return = $results['suggestions'];
$specs_to_save = null;
if ( empty( $specs_to_return ) ) {
// When specs are empty, replace it with defaults and save for 3 hours.
$specs_to_save = DefaultPromotions::get_all();
$specs_to_return = EvaluateSuggestion::evaluate_specs( $specs_to_save )['suggestions'];
} elseif ( count( $results['errors'] ) > 0 ) {
// When specs are not empty but have errors, save for 3 hours.
$specs_to_save = $specs;
}
if ( count( $results['errors'] ) > 0 ) {
self::log_errors( $results['errors'] );
}
if ( $specs_to_save ) {
WCPayPromotionDataSourcePoller::get_instance()->set_specs_transient( array( $locale => $specs_to_save ), 3 * HOUR_IN_SECONDS );
}
return $specs_to_return;
}
/**
* Gets either cached or default promotions.
*
* @return array
*/
public static function get_cached_or_default_promotions() {
$specs = 'no' === get_option( 'woocommerce_show_marketplace_suggestions', 'yes' )
? DefaultPromotions::get_all()
: WCPayPromotionDataSourcePoller::get_instance()->get_cached_specs();
if ( ! is_array( $specs ) || 0 === count( $specs ) ) {
$specs = DefaultPromotions::get_all();
}
$results = EvaluateSuggestion::evaluate_specs( $specs, array( 'source' => 'wc-wcpay-promotions' ) );
return $results['suggestions'];
}
/**
* Get merchant WooPay eligibility.
*
* @return boolean If merchant is eligible for WooPay.
*/
public static function is_woopay_eligible() {
$wcpay_promotion = self::get_wc_pay_promotion_spec( false );
return $wcpay_promotion && 'woocommerce_payments:woopay' === $wcpay_promotion->id;
}
/**
* Delete the specs transient.
*/
public static function delete_specs_transient() {
WCPayPromotionDataSourcePoller::get_instance()->delete_specs_transient();
}
/**
* Get specs or fetch remotely if they don't exist.
*
* @return array List of specs.
*/
public static function get_specs() {
if ( get_option( 'woocommerce_show_marketplace_suggestions', 'yes' ) === 'no' ) {
return DefaultPromotions::get_all();
}
$specs = WCPayPromotionDataSourcePoller::get_instance()->get_specs_from_data_sources();
// On empty remote specs, fallback to default ones.
if ( ! is_array( $specs ) || 0 === count( $specs ) ) {
$specs = DefaultPromotions::get_all();
}
return $specs;
}
/**
* Add component settings.
*
* @param array $settings Component settings.
*
* @return array
*/
public function add_component_settings( $settings ) {
$settings['isWooPayEligible'] = self::is_woopay_eligible();
return $settings;
}
/**
* Loads the payment method promotions scripts and styles.
*/
public static function load_payment_method_promotions() {
WCAdminAssets::register_style( 'payment-method-promotions', 'style', array( 'wp-components' ) );
WCAdminAssets::register_script( 'wp-admin-scripts', 'payment-method-promotions', true );
}
}