WooCommerce 3 no Purchased Column under Orders
-
The ‘Purchased’ column from screen options is missing on the order view of the backend. Please would you add it back or provide a hook I can add to the functions.php file.
-
I have been use the following code for a couple of years to show a custom column with the items purchased, it should be easy enough to modify just to show qty info rather than item details.
The code needed some changes to make it work with Woo3 – code is modified version of someone elses work, sadly cannot remember who to credit!!
// show order items in shop view as an custom column add_filter( 'manage_edit-shop_order_columns', 'tarkan_set_custom_column'); function tarkan_set_custom_column($columns) { $new_array = array(); foreach($columns as $key => $title) { if ($key=='billing_address') // in front of the Billing column $new_array['order_products'] = __( 'Products', 'woocommerce' ); $new_array[$key] = $title; } return $new_array ; } add_action( 'manage_shop_order_posts_custom_column' , 'tarkan_shop_custom_column', 10, 2 ); function tarkan_shop_custom_column($column) { global $post, $woocommerce, $the_order; switch ( $column ) { case 'order_products' : $terms = $the_order->get_items(); if ( is_array( $terms ) ) { foreach($terms as $term){ echo $term['quantity'] .' x ' . $term['name'] .'<br />'; } } else { _e( 'Unable get the products', 'woocommerce' ); } break; } }
Thanks @tarkan
I modified the code slightly to make the additional items viewable by hovering.
// show order items in shop view as an custom column add_filter('manage_edit-shop_order_columns', 'tarkan_set_custom_column'); function tarkan_set_custom_column($columns) { $new_array = array(); foreach ($columns as $key => $title) { if ($key == 'billing_address') { // in front of the Billing column $new_array['order_products'] = __('Products', 'woocommerce'); } $new_array[$key] = $title; } return $new_array; } add_action('manage_shop_order_posts_custom_column', 'tarkan_shop_custom_column', 10, 2); function tarkan_shop_custom_column($column) { global $post, $woocommerce, $the_order; switch ($column) { case 'order_products': $terms = $the_order->get_items(); if (is_array($terms)) { $productToolTip = ''; foreach ($terms as $term) { $productToolTip .= $term['quantity'] . ' x ' . $term['name'] . '<br />'; } $productToolTip = '<span class="note-on tips" data-tip="'.$productToolTip.'">Hover to view ordered products</span>'; echo $productToolTip; } else { _e('Unable get the products', 'woocommerce'); } break; } }
Where do I put this code?
@j0a0pe5r0, you have to create a child theme and put this in the functions.php file.
For more about child themes, see the WordPress codex https://codex.www.ads-software.com/Child_Themes
Thank you, it’s already working.
Glad to hear that!
I was disappointed to see it gone and the code worked for me, but is there a way I can get the product SKU after the name? I’ve tried, but I’m not good at PHP.
@biverson, you’d change this portion of the code:
foreach ($terms as $term) { $productToolTip .= $term['quantity'] . ' x ' . $term['name'] . '<br />'; }
To something like the following:
foreach ($terms as $term) { $product = new WC_Product($term['product_id']); $SKU = $product->get_sku(); $productToolTip .= $term['quantity'] . ' x ' . $term['name'] . ' ' . $SKU . '<br />'; }
- This reply was modified 7 years, 7 months ago by bruceappinletcom.
If anyone is concerned about the resource usage (which is why they removed the column), we created a plugin which uses Ajax to only query the order when required – https://www.ads-software.com/plugins/purchased-items-column-woocommerce/
Thanks @pipdig!
For those wanting the quantity field added or to replace the function code straight, this is the alternative version.
function pipdig_wc_custom_purchased_column($columns) { $new_array = array(); foreach ($columns as $key => $title) { if ($key == 'billing_address') { $new_array['order_items'] = __('Purchased', 'purchased-items-column-woocommerce'); } $new_array[$key] = $title; } return $new_array; } add_filter('manage_edit-shop_order_columns', 'pipdig_wc_custom_purchased_column'); function pipdig_wc_shop_custom_column($column) { if ($column == 'order_items') { echo '<a href="#">Show items</a><div id="show_order_items_'.get_the_ID().'"></div>'; } } add_action('manage_shop_order_posts_custom_column', 'pipdig_wc_shop_custom_column', 10, 2); function pipdig_wc_find_products_ajax_javascript() { if (isset($_GET["post_type"]) && ($_GET["post_type"] != 'shop_order')) { return; } ?> <script> jQuery(document).ready(function($) { $(".show_order_items").click(function() { var order_id = $(this).data("wc-order"); $('#show_order_items_'+order_id).html('loading...'); var data = { 'action': 'pipdig_wc_find_products_ajax', 'order_id': order_id }; $.post(ajaxurl, data, function(response) { $('#show_order_items_'+order_id).html(response); }); }); }); </script> <?php } add_action( 'admin_head-edit.php', 'pipdig_wc_find_products_ajax_javascript' ); function pipdig_wc_find_products_ajax() { $output = ''; $order_id = intval($_POST['order_id']); $order = new WC_Order($order_id); $products = $order->get_items(); foreach($products as $product){ $output .= esc_html($product['quantity']) . ' x ' . esc_html($product['name']).'<br />'; } echo $output; wp_die(); } add_action( 'wp_ajax_pipdig_wc_find_products_ajax', 'pipdig_wc_find_products_ajax' );
- This reply was modified 7 years, 5 months ago by bruceappinletcom.
Hey @bruceappinletcom, I think we’ll add this to the plugin now. It’s probably something people will need. Update available shortly… ??
@pipdig, thanks mate! I’ve also rated your plugin with 5 stars. I encourage anyone using this plugin to give it a good rating.
- The topic ‘WooCommerce 3 no Purchased Column under Orders’ is closed to new replies.