php - 在 WooCommerce 中将 BACS“暂停”订单限制为客户的一个
问题描述
我们在 WooCommerce 商店提供 BACS(银行转账)作为付款方式。如果有人使用该方法:
- 该产品的库存减少
- 订单暂停 48 小时
我们遇到的问题是,有些人利用了这一点,他们使用这种方法来预订产品。他们等待订单被取消,然后再做一次,只要他们有钱,他们就会付钱。
作为二手店,这当然不是所希望的行为。
有没有办法将处于“暂停”状态的 BACS 订单数量限制为只有一个?
这样,如果您想使用 BACS 付款并且您的电子邮件已经有一个待处理的订单,它将返回错误并且您将无法完成结帐。当然人们可以使用不同的电子邮件,但它开始变得复杂。
任何帮助表示赞赏。
解决方案
更新-使用帐单电子邮件添加了客人。
以下非常简单的挂钩函数将检查当前客户是否有任何“暂停”BACS 订单,如果是这种情况,如果当前订单使用 BACS 付款方式,它将显示避免结账的错误消息:
add_action( 'woocommerce_checkout_process', 'action_wc_checkout_process_callback' );
function action_wc_checkout_process_callback() {
if( is_user_logged_in() ) {
// Get customer "on-hold" orders
$orders = (array) wc_get_orders(['limit' => - 1, 'customer_id' => get_current_user_id(),
'status' => 'on-hold', 'return' => 'ids']);
} elseif ( isset($_POST['billing_email']) && ! empty($_POST['billing_email']) ) {
// Get customer "on-hold" orders
$orders = (array) wc_get_orders(['limit' => - 1, 'customer' => sanitize_email($_POST['billing_email']), 'status' => 'on-hold', 'return' => 'ids']);
}
// Check if the current customer has any "on-hold" BACS order and if current order is using BACS as payment method
if ( isset($orders) && count($orders) > 0 && isset($_POST['payment_method']) && $_POST['payment_method'] === 'bacs' ) {
// Display an error notice (and avoid checkout)
wc_add_notice( __( "You have already one order awaiting payment and you can have only one at the time.", "woocommerce" ), 'error' );
}
}
代码位于活动子主题(或活动主题)的 functions.php 文件中。测试和工作。
推荐阅读
- pandas - pandas.Dataframe.loc[index] 这是如何工作的?
- python-3.x - 从“选择”中选择没有 ID、名称或 XPATH 的下拉项目?
- python - 如何在python pandas中将值范围更改为实际值
- java - 反射 - 获取列表的大小
- csv - 明智地拆分 CSV 列,在 shell 脚本中没有唯一的分隔符
- python - 小部件随着布局的几何形状而被拉伸
- c# - 如何使用托管标识从 Visual Studio 运行 EF6 代码优先迁移
- python - 有没有办法将特定列从 excel 表(比如 sheet_1)复制到 sheet_2 中的另一列?使用 Python
- google-app-engine - 部署在 Google App Engine 上的应用的 /healthz 路由返回 404
- java - 为什么我们在初始化时要传递集合(或任何对象)的引用?请检查下面的代码