我正在使用WooCommerce Bookings插件,我目前正在寻求在预订摘要(产品选项(中显示其他信息。
为此,我使用以下钩子: woocommerce_admin_booking_data_after_booking_details
如果我的预订链接到订单,我使用函数wc_get_order_item_meta
我希望能够在预订尚未订购时检索我的数据 浏览数据库时,我看到该信息存储在表 在我使用的挂钩中,我只能访问预订的ID。 是否可以从此中检索相应的会话? 谢谢 update woocommerce_sessions
中。add_filter('woocommerce_admin_booking_data_after_booking_details', function ($booking_id) {
global $wpdb;
$booking = get_wc_booking($booking_id);
$order = $booking->get_order();
if ($order) {
foreach ($order->get_items() as $item) {
$item_meta = wc_get_order_item_meta($item->get_id(), '', FALSE);
/* Your code */
}
} else {
$table = $wpdb->prefix . 'woocommerce_sessions';
$condition = '%booking_id____' . $booking_id . '%';
$sql = "SELECT session_value FROM $table WHERE session_value LIKE '$condition'";
$query = maybe_unserialize($wpdb->get_var($sql));
$cart_items = maybe_unserialize($query['cart']);
foreach ($cart_items as $item) {
/* Your code */
}
}
}, 10, 1);
您可以使用WC_CART方法访问此数据 get_cart()
或 get_cart_from_session()
。
您应该使用这两种方式使用foreach循环:
foreach(WC()->cart->get_cart() as $cart_item_key => $item_values){
// Outputting the raw Cart items data to retrieve Bookings related data
echo '<pre>'; print_r($item_values); echo '</pre>';
}
或
foreach(WC()->cart->get_cart() as $cart_item_key => $item_values){
// Outputting the raw Cart items data to retrieve Bookings related data
echo '<pre>'; print_r($item_values); echo '</pre>';
}
您可以使用此挂钩函数中的正确数据路径和名称(例如,在此处发生在购物车页面上(:
(add_action( 'woocommerce_before_cart_table', 'my_custom_cart_items_raw_output');
function my_custom_cart_items_raw_output() {
foreach(WC()->cart->get_cart() as $cart_item_key => $item_values){
// Outputting the raw Cart items data to retrieve Bookings related data
echo '<pre>'; print_r($item_values); echo '</pre>';
}
}
代码在您的活动子主题(或主题(或任何插件文件中的function.php文件中。
此代码经过测试并有效。
一旦找到了方法,名称和数据路径,您就可以将其删除(仅用于测试和开发(…