我想做的是这样的:
客户购买产品。而不是“添加到购物车”,它将显示“查看数字产品”,并具有指向特定页面的自定义链接。
我一直在数据库中查找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;
}
}
请引导我朝正确的方向前进。
答案 0 :(得分:1)
以下功能将检查客户是否已经购买了产品,并且是否将添加到购物车按钮替换为链接到“关于”页面的自定义“查看数字产品”链接按钮。
第一个功能代码由
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>';
}
代码进入您的活动子主题(或活动主题)的function.php文件中。经过测试,可以正常工作。
基于: