Esta noticia se orienta a recapitular  una serie métodos para obtener la información de un pedido que compone un pedido de WooCommerce.

¿Cómo puedo obtener el total del pedido»? O «¿Cómo puedo obtener los artículos del pedido»? O tal vez el ID de pedido, ID de cliente, información de facturación, método de pago, reembolsos totales, etc.

Conocer estos métodos para acceder a los datos de los pedidos de WooCommerce puede hacer que el desarrollo sea más ágil y ahorrarte un tiempo.

Acceso a la variable $order

Si tienes acceso a la variable del pedido $order de WooCommerce, con los siguientes métodos puedes obtener toda su información.

// Obtiene el ID y la clave del pedido
$order->get_id();
$order->get_order_key();
 
// Obtiene los totales
$order->get_formatted_order_total();
$order->get_cart_tax();
$order->get_currency();
$order->get_discount_tax();
$order->get_discount_to_display();
$order->get_discount_total();
$order->get_fees();
$order->get_formatted_line_subtotal();
$order->get_shipping_tax();
$order->get_shipping_total();
$order->get_subtotal();
$order->get_subtotal_to_display();
$order->get_tax_location();
$order->get_tax_totals();
$order->get_taxes();
$order->get_total();
$order->get_total_discount();
$order->get_total_tax();
$order->get_total_refunded();
$order->get_total_tax_refunded();
$order->get_total_shipping_refunded();
$order->get_item_count_refunded();
$order->get_total_qty_refunded();
$order->get_qty_refunded_for_item();
$order->get_total_refunded_for_item();
$order->get_tax_refunded_for_item();
$order->get_total_tax_refunded_by_rate_id();
$order->get_remaining_refund_amount();
  
// Obtiene el detalle de pedido
foreach ( $order->get_items() as $item_id => $item ) {
   $product_id = $item->get_product_id();
   $variation_id = $item->get_variation_id();
   $product = $item->get_product();
   $product_name = $item->get_name();
   $quantity = $item->get_quantity();
   $subtotal = $item->get_subtotal();
   $total = $item->get_total();
   $tax = $item->get_subtotal_tax();
   $taxclass = $item->get_tax_class();
   $taxstat = $item->get_tax_status();
   $allmeta = $item->get_meta_data();
   $somemeta = $item->get_meta( '_whatever', true );
   $product_type = $item->get_type();
}
 
// Otra información del pedido
$order->get_items_key();
$order->get_items_tax_classes();
$order->get_item_count();
$order->get_item_total();
$order->get_downloadable_items();
$order->get_coupon_codes();
  
// Obtiene las líneas del pedido
$order->get_line_subtotal();
$order->get_line_tax();
$order->get_line_total();
  
// Obtiene el método de envío
$order->get_shipping_method();
$order->get_shipping_methods();
$order->get_shipping_to_display();
  
// Obtiene las fechas de pedido
$order->get_date_created();
$order->get_date_modified();
$order->get_date_completed();
$order->get_date_paid();
  
// Obtiene el usuario y los datos de sus direcciones
$order->get_customer_id();
$order->get_user_id();
$order->get_user();
$order->get_customer_ip_address();
$order->get_customer_user_agent();
$order->get_created_via();
$order->get_customer_note();
$order->get_address_prop();
$order->get_billing_first_name();
$order->get_billing_last_name();
$order->get_billing_company();
$order->get_billing_address_1();
$order->get_billing_address_2();
$order->get_billing_city();
$order->get_billing_state();
$order->get_billing_postcode();
$order->get_billing_country();
$order->get_billing_email();
$order->get_billing_phone();
$order->get_shipping_first_name();
$order->get_shipping_last_name();
$order->get_shipping_company();
$order->get_shipping_address_1();
$order->get_shipping_address_2();
$order->get_shipping_city();
$order->get_shipping_state();
$order->get_shipping_postcode();
$order->get_shipping_country();
$order->get_address();
$order->get_shipping_address_map_url();
$order->get_formatted_billing_full_name();
$order->get_formatted_shipping_full_name();
$order->get_formatted_billing_address();
$order->get_formatted_shipping_address();
  
// Obtiene los detalles de los métodos de pago
$order->get_payment_method();
$order->get_payment_method_title();
$order->get_transaction_id();
  
// Obtiene las URLS del pedido
$order->get_checkout_payment_url();
$order->get_checkout_order_received_url();
$order->get_cancel_order_url();
$order->get_cancel_order_url_raw();
$order->get_cancel_endpoint();
$order->get_view_order_url();
$order->get_edit_order_url();
  
// Obtiene el estado del pedido
$order->get_status();

Acceso a la variable $order_id

Si tiene acceso al ID del pedido, a través de hooks y filtros de WordPress, se puede obtener el detalle del pedido completo, como se ha visto en el punto anterior.

// Obtiene el objeto $order desde el ID
$order = wc_get_order( $order_id );
  
if ( $order ) {
   $order->get_formatted_order_total( );
   // etc.
}

Acceso a la variable $email

Al trabajar con emails de WooCommerce, a menudo tendrá el objet del $email disponible. A partir de este objeto puedes acceder al detalle del pedido.

// Obtiene el objeto $order a través del $email
$order = $email->object;
  
if ( $order ) {
   $order->get_id();
   $order->get_formatted_order_total( );
   // etc.
}

Fuente: La entrada original la tienes en inglés en esta web

¡Valora este artículo y ayúdame a mejorar la calidad del blog, si no te ha servido, déjame un comentario para revisarlo!
(Votos: 0 Promedio: 0)