Skip to content

Instantly share code, notes, and snippets.

@woogists
Last active January 30, 2022 16:55
Show Gist options
  • Star 2 You must be signed in to star a gist
  • Fork 2 You must be signed in to fork a gist
  • Save woogists/b679a54a22ae8ddbb7cb4f0c91a90a53 to your computer and use it in GitHub Desktop.
Save woogists/b679a54a22ae8ddbb7cb4f0c91a90a53 to your computer and use it in GitHub Desktop.
[Frontend Snippets] Custom sorting options (asc/desc)
/**
* Add custom sorting options (asc/desc)
*/
add_filter( 'woocommerce_get_catalog_ordering_args', 'custom_woocommerce_get_catalog_ordering_args' );
function custom_woocommerce_get_catalog_ordering_args( $args ) {
$orderby_value = isset( $_GET['orderby'] ) ? wc_clean( $_GET['orderby'] ) : apply_filters( 'woocommerce_default_catalog_orderby', get_option( 'woocommerce_default_catalog_orderby' ) );
if ( 'random_list' == $orderby_value ) {
$args['orderby'] = 'rand';
$args['order'] = '';
$args['meta_key'] = '';
}
return $args;
}
add_filter( 'woocommerce_default_catalog_orderby_options', 'custom_woocommerce_catalog_orderby' );
add_filter( 'woocommerce_catalog_orderby', 'custom_woocommerce_catalog_orderby' );
function custom_woocommerce_catalog_orderby( $sortby ) {
$sortby['random_list'] = 'Random';
return $sortby;
}
@van087
Copy link

van087 commented Sep 21, 2021

I would like to sort products based on a custom attribute.
I started with this random sorting script, but not being a programmer I haven't been able to get it to work yet.
The latest proof is this:

`
/**
Add custom sorting options (asc/desc)
*/

add_filter( 'woocommerce_get_catalog_ordering_args', 'custom_woocommerce_get_catalog_ordering_args' );
function custom_woocommerce_get_catalog_ordering_args( $args ) {
$orderby_value = isset( $_GET['orderby'] ) ? wc_clean( $_GET['orderby'] ) : apply_filters( 'woocommerce_default_catalog_orderby', get_option( 'woocommerce_default_catalog_orderby' ) );
if ( 'product_attribute_taxonomies' == $orderby_value ) {
$args['orderby'] = 'meta_value_num';
$args['order'] = 'ASC';
$args['meta_key'] = 'pa_kj';
}
return $args;
}
add_filter( 'woocommerce_default_catalog_orderby_options', 'custom_woocommerce_catalog_orderby' );
add_filter( 'woocommerce_catalog_orderby', 'custom_woocommerce_catalog_orderby' );
function custom_woocommerce_catalog_orderby( $sortby ) {
$sortby['product_attribute_taxonomies'] = 'Order by Kj';
return $sortby;
}

`
but it does not work: "No products were found matching your selection."

My attribute name is "pa_kj" Its value is alphanumeric

I thank everyone in advance for any suggestions.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment