我想做的是这个:
客户购买产品。 它不是"添加到购物车",而是显示"查看数字产品"并具有指向特定页面的自定义链接。
我正在数据库中寻找WooCommerce,并试图弄清楚我如何知道已经购买了一件物品,以便我可以弄清楚如何使函数自动执行此操作:
从wp_woocommerce_payment_tokens
中选择 *
token_id gateway_id token user_id type is_default
从wp_woocommerce_order_items
中选择 *
order_item_id order_item_name order_item_type order_id
但是我还无法弄清楚他们的逻辑或WordPress中的正确功能来实现这一目标。
我能在网上找到的唯一功能是重定向,但这仅在您购买商品时是正确的,而不是如果您返回已经购买该商品的页面:
add_action( 'template_redirect', 'wc_custom_redirect_after_purchase' );
function wc_custom_redirect_after_purchase() {
global $wp;
if ( is_checkout() && ! empty( $wp->query_vars['order-received'] ) ) {
wp_redirect( get_permalink( get_page_by_title( "About" )->ID ) );
exit;
}
}
请引导我朝着正确的方向前进。
以下功能将检查客户是否已经购买了产品,如果是这种情况,添加到购物车按钮将被自定义的"查看数字产品"按钮替换为链接到"关于"页面。
第一个函数代码由
wc_customer_bought_product()
源代码以更轻松的方式制成。该代码将仅检查登录用户,为未登录的用户返回 false。
function has_bought_item( $product_id ) {
global $wpdb;
if( ! is_user_logged_in() )
return false;
$customer_id = get_current_user_id();
$statuses = array_map( 'esc_sql', wc_get_is_paid_statuses() );
// Count the number of products
$count_query = $wpdb->get_var( "
SELECT COUNT(woim.meta_value) FROM {$wpdb->prefix}posts AS p
INNER JOIN {$wpdb->prefix}postmeta AS pm ON p.ID = pm.post_id
INNER JOIN {$wpdb->prefix}woocommerce_order_items AS woi ON p.ID = woi.order_id
INNER JOIN {$wpdb->prefix}woocommerce_order_itemmeta AS woim ON woi.order_item_id = woim.order_item_id
WHERE p.post_status IN ( 'wc-" . implode( "','wc-", $statuses ) . "' )
AND pm.meta_key = '_customer_user' AND pm.meta_value = $customer_id
AND woim.meta_key IN ( '_product_id', '_variation_id' )
AND woim.meta_value = $product_id
" );
// Return true boolean value if count is higher than 0, if not false
return $count_query > 0 ? true : false;
}
// Shop and archives - Replace add to cart ajax button to a custom linked button
add_filter( 'woocommerce_loop_add_to_cart_link', 'replace_loop_add_to_cart', 20, 2 );
function replace_loop_add_to_cart( $html, $product ) {
if( has_bought_item( $product->get_id() ) ) {
$page = get_page_by_title( "About" );
if ( ! is_object($page) )
return $html;
$link = get_permalink( $page->ID );
$text = __("See Digital Product", "woocommerce");
$html = '<a href="' . $link . '" class="button alt add_to_cart_button">' . $text . '</a>';
}
return $html;
}
// Single products: Replacing the button add to cart by a custom button on single product pages
add_action( 'woocommerce_single_product_summary', 'replace_single_add_to_cart_button', 1 );
function replace_single_add_to_cart_button() {
global $product;
if( has_bought_item( $product->get_id() ) && get_page_by_title( "About" ) ) {
// For variable product types (keeping attribute select fields)
if( $product->is_type( 'variable' ) ) {
remove_action( 'woocommerce_single_variation', 'woocommerce_single_variation_add_to_cart_button', 20 );
add_action( 'woocommerce_single_product_summary', 'custom_single_add_to_cart_button', 20 );
}
// For all other product types
else {
remove_action( 'woocommerce_single_product_summary', 'woocommerce_template_single_add_to_cart', 30 );
add_action( 'woocommerce_single_product_summary', 'custom_single_add_to_cart_button', 30 );
}
}
}
// Utility function: displays a custom button replacement
function custom_single_add_to_cart_button() {
$page = get_page_by_title( "About" );
if ( ! is_object($page) )
return;
$link = get_permalink( $page->ID );
$text = __("See Digital Product", "woocommerce");
echo '<a href="' . $link . '" class="button alt add_to_cart_button">' . $text . '</a>';
}
代码进入函数.php活动子主题(或活动主题(的文件。经过测试并工作。
基于:
- 检查客户是否已经在WooCommerce中购买了东西
- 检查客户是否在WooCommerce中购买了特定产品