Следующий код добавляет новое поле на вкладку ограничения использования, где вы можете добавить разрешенные роли пользователей.
// Add new field - usage restriction tab
function action_woocommerce_coupon_options_usage_restriction( $coupon_get_id, $coupon ) {
woocommerce_wp_text_input( array(
'id' => 'customer_user_role',
'label' => __( 'User role restrictions', 'woocommerce' ),
'placeholder' => __( 'No restrictions', 'woocommerce' ),
'description' => __( 'List of allowed user roles. Separate user roles with commas.', 'woocommerce' ),
'desc_tip' => true,
'type' => 'text',
));
}
add_action( 'woocommerce_coupon_options_usage_restriction', 'action_woocommerce_coupon_options_usage_restriction', 10, 2 );
// Save
function action_woocommerce_coupon_options_save( $post_id, $coupon ) {
update_post_meta( $post_id, 'customer_user_role', $_POST['customer_user_role'] );
}
add_action( 'woocommerce_coupon_options_save', 'action_woocommerce_coupon_options_save', 10, 2 );
// Valid
function filter_woocommerce_coupon_is_valid( $is_valid, $coupon, $discount ) {
// Get meta
$customer_user_role = $coupon->get_meta('customer_user_role');
// NOT empty
if( ! empty( $customer_user_role ) ) {
// Convert string to array
$customer_user_role = explode(', ', $customer_user_role);
// Get current user role
$user = wp_get_current_user();
$roles = ( array ) $user->roles;
// Compare
$compare = array_diff( $roles, $customer_user_role );
// NOT empty
if ( ! empty ( $compare ) ) {
$is_valid = false;
}
}
return $is_valid;
}
add_filter( 'woocommerce_coupon_is_valid', 'filter_woocommerce_coupon_is_valid', 10, 3 );
РЕДАКТИРОВАТЬ:
Чтобы автоматически применить купон на странице КОРЗИНА и скрыть ссылку на удаление купона (в зависимости от роли пользователя)
function action_woocommerce_before_calculate_totals( $cart ) {
if ( is_admin() && ! defined( 'DOING_AJAX' ) )
return;
if ( did_action( 'woocommerce_before_calculate_totals' ) >= 2 )
return;
// Only cart
if( ! is_cart() )
return;
/* SETTINGS */
// Coupon code
$coupon_code = 'test';
// Allowed user role
$allowed_user_role = 'administrator';
/* END SETTINGS */
// check current user role
$user = wp_get_current_user();
$user_roles = ( array ) $user->roles;
// ADD js
$add_js = false;
// In array user roles
if ( in_array( $allowed_user_role, $user_roles ) ) {
// Format
$coupon_code = wc_format_coupon_code( $coupon_code );
// Applied coupons
$applied_coupons = $cart->get_applied_coupons();
// Is applied
$is_applied = in_array( $coupon_code, $applied_coupons );
// NOT applied
if ( ! $is_applied ) {
// Apply
$cart->apply_coupon( $coupon_code );
// True
$add_js = true;
} elseif ( $is_applied ) {
// True
$add_js = true;
}
// True
if ( $add_js ) {
?>
<script type="text/javascript">
jQuery( function($) {
// Hide remove link
$( '.woocommerce-remove-coupon' ).hide();
});
</script>
<?php
}
}
}
add_action( 'woocommerce_before_calculate_totals', 'action_woocommerce_before_calculate_totals', 10, 1 );