tem's order value.
// If we don't have an order for it, add it to the end.
if ( ! isset( $providers_order_map[ PaymentProviders::OFFLINE_METHODS_ORDERING_GROUP ] ) ) {
$providers_order_map = Utils::order_map_add_at_order( $providers_order_map, PaymentProviders::OFFLINE_METHODS_ORDERING_GROUP, count( $payment_providers ) );
}
$payment_providers[] = array(
'id' => PaymentProviders::OFFLINE_METHODS_ORDERING_GROUP,
'_type' => PaymentProviders::TYPE_OFFLINE_PMS_GROUP,
'_order' => $providers_order_map[ PaymentProviders::OFFLINE_METHODS_ORDERING_GROUP ],
'title' => __( 'Take offline payments', 'woocommerce' ),
'description' => __( 'Accept payments offline using multiple different methods. These can also be used to test purchases.', 'woocommerce' ),
'icon' => plugins_url( 'assets/images/payment_methods/cod.svg', WC_PLUGIN_FILE ),
// The offline PMs (and their group) are obviously from WooCommerce, and WC is always active.
'plugin' => array(
'_type' => 'wporg',
'slug' => 'woocommerce',
'file' => '', // This pseudo-provider should have no use for the plugin file.
'status' => PaymentProviders::EXTENSION_ACTIVE,
),
'management' => array(
'_links' => array(
'settings' => array(
'href' => admin_url( 'admin.php?page=wc-settings&tab=checkout§ion=offline' ),
),
),
),
);
}
// Determine the final, standardized providers order map.
$providers_order_map = $this->providers->enhance_order_map( $providers_order_map );
// Enforce the order map on all providers, just in case.
foreach ( $payment_providers as $key => $provider ) {
$payment_providers[ $key ]['_order'] = $providers_order_map[ $provider['id'] ];
}
// NOTE: For now, save it back to the DB. This is temporary until we have a better way to handle this!
$this->providers->save_order_map( $providers_order_map );
// Sort the payment providers by order, ASC.
usort(
$payment_providers,
function ( $a, $b ) {
return $a['_order'] <=> $b['_order'];
}
);
return $payment_providers;
}
/**
* Get the payment extension suggestions for the given location.
*
* @param string $location The location for which the suggestions are being fetched.
*
* @return array[] The payment extension suggestions for the given location, split into preferred and other.
* @throws Exception If there are malformed or invalid suggestions.
*/
public function get_payment_extension_suggestions( string $location ): array {
return $this->providers->get_extension_suggestions( $location, self::SUGGESTIONS_CONTEXT );
}
/**
* Get the payment extension suggestions categories details.
*
* @return array The payment extension suggestions categories.
*/
public function get_payment_extension_suggestion_categories(): array {
return $this->providers->get_extension_suggestion_categories();
}
/**
* Get the business location country code for the Payments settings.
*
* @return string The ISO 3166-1 alpha-2 country code to use for the overall business location.
* If the user didn't set a location, the WC base location country code is used.
*/
public function get_country(): string {
$user_nox_meta = get_user_meta( get_current_user_id(), self::USER_PAYMENTS_NOX_PROFILE_KEY, true );
if ( ! empty( $user_nox_meta['business_country_code'] ) ) {
return $user_nox_meta['business_country_code'];
}
return WC()->countries->get_base_country();
}
/**
* Set the business location country for the Payments settings.
*
* @param string $location The country code. This should be a ISO 3166-1 alpha-2 country code.
*/
public function set_country( string $location ): bool {
$user_payments_nox_profile = get_user_meta( get_current_user_id(), self::USER_PAYMENTS_NOX_PROFILE_KEY, true );
if ( empty( $user_payments_nox_profile ) ) {
$user_payments_nox_profile = array();
} else {
$user_payments_nox_profile = maybe_unserialize( $user_payments_nox_profile );
}
$user_payments_nox_profile['business_country_code'] = $location;
return false !== update_user_meta( get_current_user_id(), self::USER_PAYMENTS_NOX_PROFILE_KEY, $user_payments_nox_profile );
}
/**
* Update the payment providers order map.
*
* @param array $order_map The new order for payment providers.
*
* @return bool True if the payment providers ordering was successfully updated, false otherwise.
*/
public function update_payment_providers_order_map( array $order_map ): bool {
return $this->providers->update_payment_providers_order_map( $order_map );
}
/**
* Hide a payment extension suggestion.
*
* @param string $id The ID of the payment extension suggestion to hide.
*
* @return bool True if the suggestion was successfully hidden, false otherwise.
* @throws Exception If the suggestion ID is invalid.
*/
public function hide_payment_extension_suggestion( string $id ): bool {
return $this->providers->hide_extension_suggestion( $id );
}
/**
* Dismiss a payment extension suggestion incentive.
*
* @param string $suggestion_id The suggestion ID.
* @param string $incentive_id The incentive ID.
* @param string $context Optional. The context in which the incentive should be dismissed.
* Default is to dismiss the incentive in all contexts.
*
* @return bool True if the incentive was not previously dismissed and now it is.
* False if the incentive was already dismissed or could not be dismissed.
* @throws Exception If the incentive could not be dismissed due to an error.
*/
public function dismiss_extension_suggestion_incentive( string $suggestion_id, string $incentive_id, string $context = 'all' ): bool {
return $this->extension_suggestions->dismiss_incentive( $incentive_id, $suggestion_id, $context );
}
}