Ich möchte benutzerdefinierte Spalten mit einigen Metadaten zur Bestellliste des WooCommerce-Administrators hinzufügen. Ich habe dies gefunden, für meine Bedürfnisse modifiziert und in meine functions.php eingefügt:
add_filter( 'manage_edit-shop_order_columns', 'MY_COLUMNS_FUNCTION' );
function MY_COLUMNS_FUNCTION( $columns ) {
$new_columns = ( is_array( $columns ) ) ? $columns : array();
unset( $new_columns[ 'order_actions' ] );
//edit this for your column(s)
//all of your columns will be added before the actions column
$new_columns['dname'] = 'Dogs Name';
$new_columns['additional_allergies'] = 'Allergies';
//stop editing
$new_columns[ 'order_actions' ] = $columns[ 'order_actions' ];
return $new_columns;
}
An der Kasse sammle ich diese beiden Metaschlüssel:
- Name
- zusätzliche_allergien
Mein aktueller Code zeigt jedoch nur leere Spalten, irgendwelche Ratschläge zum Hinzufügen der Metadaten?
Die manage_shop_order_posts_custom_column
Hook kann verwendet werden, um einen Header hinzuzufügen.
// Add a Header
function custom_shop_order_column( $columns ) {
// Add new columns
$columns['dogs_name'] = __( 'Dogs Name', 'woocommerce' );
$columns['additional_allergies'] = __( 'Allergies', 'woocommerce' );
return $columns;
}
add_filter( 'manage_edit-shop_order_columns', 'custom_shop_order_column', 10, 1 );
Die manage_shop_order_posts_custom_column
Hook wird benötigt, um die Spalte zu füllen.
- Notiz: Es ist wichtig festzustellen, ob es sich um Metadaten handelt, die zu den gehören
$order
Objekt oder ob es sich um Metadaten handelt, die zur Bestellung gehören $items
und basierend darauf müssen Sie 1 der 2 Antworten unten verwenden.
1a: Falls die Metadaten zu den gehören $order
Objekt, können Sie verwenden:
// Populate the Column
function custom_shop_order_list_column_content( $column, $post_id ) {
// Get order object
$order = wc_get_order( $post_id );
// Is a WC_Order
if ( is_a( $order, 'WC_Order' ) ) {
// Compare column name
if ( $column == 'dogs_name' ) {
// Get meta, use the correct meta key!
$dogs_name = $order->get_meta( 'dname' );
// NOT empty
if ( ! empty( $dogs_name ) ) {
// Output
echo $dogs_name;
} else {
// Output
echo __( 'Meta key is wrong or not found for this order', 'woocommerce' );
}
}
// Compare column name
if ( $column == 'additional_allergies' ) {
// Get meta, use the correct meta key!
$allergies = $order->get_meta( 'additional_allergies' );
// NOT empty
if ( ! empty( $allergies ) ) {
// Output
echo $allergies;
} else {
// Output
echo __( 'Meta key is wrong or not found for this order', 'woocommerce' );
}
}
}
}
add_action( 'manage_shop_order_posts_custom_column' , 'custom_shop_order_list_column_content', 10, 2 );
1b: Allerdings, wenn die Metadaten zur Bestellung gehören $items
dann wird in obiger Antwort eine Anpassung notwendig sein, da an $order
kann aus mehreren bestehen $items
werden wir die durchlaufen $order
Objekt mit für jeden
// Populate the Column
function custom_shop_order_list_column_content( $column, $post_id ) {
// Get order object
$order = wc_get_order( $post_id );
// Is a WC_Order
if ( is_a( $order, 'WC_Order' ) ) {
// Initialize
$dogs_name_arr = array();
$allergies_arr = array();
// Loop trough order items
foreach ( $order->get_items() as $item_key => $item ) {
// Get meta, use the correct meta key!
$dogs_name = $item->get_meta( 'dname' );
// NOT empty
if ( ! empty ( $dogs_name ) ) {
// Push to array
$dogs_name_arr[] = $dogs_name;
}
// Get meta, use the correct meta key!
$allergies = $item->get_meta( 'additional_allergies' );
// NOT empty
if ( ! empty ( $allergies ) ) {
// Push to array
$allergies_arr[] = $allergies;
}
}
// Compare column name
if ( $column == 'dogs_name' ) {
// NOT empty
if ( ! empty ( $dogs_name_arr ) ) {
// Output
echo '<ul>';
echo '<li>' . implode( '</li><li>', $dogs_name_arr ) . '</li>';
echo '</ul>';
} else {
// Output
echo __( 'Meta key is wrong or not found for the order items', 'woocommerce' );
}
}
// Compare column name
if ( $column == 'additional_allergies' ) {
// NOT empty
if ( ! empty ( $allergies_arr ) ) {
// Output
echo '<ul>';
echo '<li>' . implode( '</li><li>', $allergies_arr ) . '</li>';
echo '</ul>';
} else {
// Output
echo __( 'Meta key is wrong or not found for the order items', 'woocommerce' );
}
}
}
}
add_action( 'manage_shop_order_posts_custom_column' , 'custom_shop_order_list_column_content', 10, 2 );