Programación

Obtener la fecha de compra de un producto en WooCommerce un usuario

Hace poco me he encontrado con un proyecto donde he necesitado obtener la primera fecha de compra de un producto por parte de usuario. En este caso la idea era poder hacer una restricción de contenido, pero este mismo dato, puede serviros para labores marketing (ofrece cupones en base a la antigüedad de la compra de un producto por un cliente), para temas estadísticos o para añadir datos a un panel de cliente, por ejemplo.

La idea es tener una función que reciba dos parámetros el ID de producto y el ID de usuario y te devuelva la última fecha de compra (que si hay dos o más compras por parte de un usuario, que nos devuelva la más reciente).

function fecha_compra_producto( $product_id, $user_id = 0 ){
        $user_id = ( empty( $user_id ) ) ? get_current_user_id() : $user_id;

        $orders = wc_get_orders( array(
            'posts_per_page' => -1,
            'customer_id' => $user_id,
            'orderby' => 'date',
            'order' => 'DESC',
            'status' => array( 'wc-completed' ),
        ) );

        foreach( $orders as $order_id ) {
           $order = wc_get_order( $order_id );
           $items = $order->get_items();

            foreach( $items as $order_item ){
                if( $product_id == $order_item->get_product_id() ) 
                    return $order->order_date;
            }
        }

        return false;
    }

Comentemos un poco el código:

  • Si os fijáis el id de usuario es opcional, por eso se puede rellenar o no, si no se rellena se obtiene el id de usuario actual en la primera línea con get_current_user_id() y un operador ternario
  • Luego obtenemos un listado de pedidos, enviando los siguientes parámetros:
    • que nos dé TODOS los pedidos sin límite que cumplan las condiciones, por eso lo de posts_per_page igual a -1
    • que sean del usuario definido por el user_id
    • que estén completados
    • y que los ordenes de fecha de forma descendentes
  • Iteramos por los pedidos uno a uno, creando un objeto de cada pedido
  • Obtenemos los ítems del pedido, el listado de productos
  • Y comprobamos si el producto es el que hemos comprado, si lo es, devuelve la fecha
  • Si no encontramos el producto en todos los pedidos, devolvemos un false
Nota: Hay una valoración incrustada en esta entrada, por favor, visita esta entrada para valorarla.

Almacenamos las IPs desde la que se envían las valoraciones para evitar fraudes

Francisco Javier Carazo Gil

Entradas recientes

RedSys para Contact Form 7 ahora acepta preautorizaciones

RedSys aparte de los pagos normales, llamados autorizaciones, acepta una variedad de operaciones: desde autorizaciones…

hace % días

Ordenar productos de forma diferente por cada categoría en WooCommerce

WooCommerce permite ordenar los productos de una forma nativa, para poder presentar primero los que…

hace % días

Evitar que se instalen los temas por defecto de WordPress cada vez que actualizas el núcleo

Cada vez que hay una actualización grande del núcleo WordPress, por defecto WordPress te instala…

hace % días

Pantalla LCD: ¿qué es?

Una pantalla LCD es una pantalla delgada y hecha de cristal líquido. Se usa en…

hace % días

Flujos de pago con Gravity Flow y RedSys

De todos los plugins que existen para Gravity Forms, que son numerosos porque la propia…

hace % días

CMS, ¿Qué es y qué ventajas tiene?

Un CMS, como WordPress, facilita la creación y gestión de contenido en la web, sin…

hace % días