En otros tutoriales hemos visto la importancia de ordenar los productos en el catálogo o bien que hacer con los productos agotados. Vamos a combinar ambos conceptos: Conseguir que los que no tengan stock salgan al final del listado.
Aspectos a tener en cuenta
Antes de daros la solución me gustaría que valoraseís si es necesario hacer esto, os lo recomiendo en los siguientes casos:
- Soléis tener muchos productos agotados y no os da tiempo a ordenarlos o eliminarlos.
- Los productos sin stock raramente los reponéis, por lo tanto no es necesario mostrarlo o pedir el mail para avisarles.
- Os gusta dar una buena imagen y que el cliente vea siempre al principio productos de los que disponéis.
Si es este vuestro caso u os da igual y queréis hacerlo igualmente… Añadid este código a vuestro functions.php de vuestro child theme o más fácilmente a vuestro plugin Code Snippets como explico aquí.
Mostrar los productos sin stock al final
add_filter('posts_clauses', 'sin_stock_al_final_woocommerce');
function sin_stock_al_final_woocommerce($posts_clauses) {
global $wpdb;
// Solo cambiar la consulta en los bucles de WooCommerce
if (is_woocommerce() && (is_shop() || is_product_category() || is_product_tag() || is_product_taxonomy())) {
$posts_clauses['join'] .= " INNER JOIN $wpdb->postmeta istockstatus ON ($wpdb->posts.ID = istockstatus.post_id) ";
$posts_clauses['orderby'] = " istockstatus.meta_value ASC, " . $posts_clauses['orderby'];
$posts_clauses['where'] = " AND istockstatus.meta_key = '_stock_status' AND istockstatus.meta_value <> '' " . $posts_clauses['where'];
}
return $posts_clauses;
}
Este código no altera vuestro orden manual, solo los muestra al final del cada categoría. Pasando de esto:
Y cuando aplicamos el snippet:
Recuerda que hay otras estrategias para los productos agotados, como las listas de espera.
Ordenarlos por cantidad de inventario
Otra consulta común es cómo ordenar el catálogo por los productos que más inventario tienen(algo que no viene por defecto en WooCommerce) para ello usaremos el siguiente código:
add_filter( 'woocommerce_get_catalog_ordering_args', 'dl_orden_stock_woo', 9999 );
function dl_orden_stock_woo( $args ) {
$args['orderby'] = 'meta_value';
$args['order'] = 'ASC';
$args['meta_key'] = '_stock_status';
return $args;
}
muy bien explicado y me ha ayudado con una tienda que estoy llevando muchas gracias
Buen día…
…Probé el código y me arrojó un error:
Detalles del error
==================
Se ha producido un error del tipo E_COMPILE_ERROR en la línea 11 del archivo /wp-content/plugins/insert-php/admin/metaboxes/base-options.php(764) : eval()’d code. Mensaje de error: Cannot redeclare sin_stock_al_final_woocommerce() (previously declared in /wp-content/plugins/insert-php/includes/class.execute.snippet.php(634) : eval()’d code:2)
Uso:
WordPress versión 5.7.1
Tema actual: Envo Shop (versión 1.0.9)
Plugin actual: Woody code snippets (PHP snippets | Insert PHP) (versión 2.4.1)
PHP versión 7.3.27
Hola Patowins,
Por lo que veo al insertar esta función de choca con otra funcionalidad que ya tienes instalada dentro de WordPress. Revisa los archivos que te menciona el error y busca la funcion sin_stock_al_final_woocommerce()
Hola Diegol!
Efectivamente, ya tenía corriendo el codigo en el archivo functions.php y no en mi plugin Code Snippets !
Muchas gracias por tu trabajo.
:cp
Hola, hay manera de utilizar esto pero con el stock global de un producto, (de todas las variaciones) y que el cliente pueda ordenarlo?
Gracias
Hola Ricardo, con este código no es posible.
Cuando todas las variaciones están agotadas se pondrá al fondo.
Un saludo!
Buenas Diego, el código me funciona perfectamente, muchas gracias.
Este snippet envía al final del listado los productos agotados al final del listado, también en la parte de administración. ¿Se podría adaptar este código para que en la parte de administración el orden sea el «normal»?
Un saludo y gracias de nuevo.
Hola Raúl,
El código lo hace desde la base de datos, sería usar otro diferente del cual no dispongo por el momento. Lo apunto.
Un saludo!
Muy buen post, me ha ayudado mucho!!
Muchas gracias, era lo que justo estaba buscando 😀