I have been working to add a item product attribute to the admin order details page - which I have managed. You can see the extra column titled "Packing Weight".
// Add custom column headers here
add_action('woocommerce_admin_order_item_headers', 'my_woocommerce_admin_order_item_headers');
function my_woocommerce_admin_order_item_headers() {
// set the column name
$column_name = 'Packing Weight';
// display the column name
echo '<th>' . $column_name . '</th>';
}
// Add custom column values here
add_action('woocommerce_admin_order_item_values', 'my_woocommerce_admin_order_item_values', 10, 3);
function my_woocommerce_admin_order_item_values($_product, $item, $item_id = null) {
// get the post meta value from the associated product
// $value = get_post_meta($_product->post->ID, '_custom_field_name', 1);
$value = array_shift( wc_get_product_terms( $_product->post->ID, 'pa_packing-order', array( 'fields' => 'names' ) ) );
// display the value
echo '<td>' . $value . '</td>';
}
However, I would ideally like to order the items in the order by this column e.g. Very Soft, Soft, Hard. I am happy to change the values of packing weight to a numeric scale 1 - 10 if this makes ordering easier.
How would I go about doing this?