2012-08-10 09:35:25 +00:00
< ? php
2014-11-19 17:12:56 +00:00
if ( ! defined ( 'ABSPATH' ) ) {
exit ;
}
2011-08-10 17:11:11 +00:00
/**
2015-11-03 13:31:20 +00:00
* Price Filter Widget and related functions .
2012-08-10 09:35:25 +00:00
*
2012-08-14 17:37:50 +00:00
* Generates a range slider to filter products by price .
2011-08-10 17:11:11 +00:00
*
2014-11-15 01:12:59 +00:00
* @ author WooThemes
* @ category Widgets
* @ package WooCommerce / Widgets
* @ version 2.3 . 0
* @ extends WC_Widget
2011-09-04 00:02:44 +00:00
*/
2013-05-24 15:51:58 +00:00
class WC_Widget_Price_Filter extends WC_Widget {
2012-08-10 09:35:25 +00:00
2012-08-14 17:37:50 +00:00
/**
2015-11-03 13:31:20 +00:00
* Constructor .
2012-08-14 17:37:50 +00:00
*/
2013-05-24 15:51:58 +00:00
public function __construct () {
$this -> widget_cssclass = 'woocommerce widget_price_filter' ;
$this -> widget_description = __ ( 'Shows a price filter slider in a widget which lets you narrow down the list of shown products when viewing product categories.' , 'woocommerce' );
$this -> widget_id = 'woocommerce_price_filter' ;
$this -> widget_name = __ ( 'WooCommerce Price Filter' , 'woocommerce' );
$this -> settings = array (
'title' => array (
'type' => 'text' ,
'std' => __ ( 'Filter by price' , 'woocommerce' ),
'label' => __ ( 'Title' , 'woocommerce' )
)
);
2014-11-15 01:12:59 +00:00
2013-05-24 15:51:58 +00:00
parent :: __construct ();
2011-08-10 17:11:11 +00:00
}
2012-08-14 17:37:50 +00:00
/**
2016-01-06 18:58:38 +00:00
* Output widget .
2012-08-14 17:37:50 +00:00
*
* @ see WP_Widget
2014-11-15 01:12:59 +00:00
*
2012-08-14 17:37:50 +00:00
* @ param array $args
* @ param array $instance
*/
2013-05-24 15:51:58 +00:00
public function widget ( $args , $instance ) {
2014-06-08 20:33:11 +00:00
global $_chosen_attributes , $wpdb , $wp ;
2012-08-10 09:35:25 +00:00
2014-10-14 11:54:10 +00:00
if ( ! is_post_type_archive ( 'product' ) && ! is_tax ( get_object_taxonomies ( 'product' ) ) ) {
2013-06-20 11:05:07 +00:00
return ;
2014-10-14 11:54:10 +00:00
}
2012-08-10 09:35:25 +00:00
2014-10-14 11:54:10 +00:00
if ( sizeof ( WC () -> query -> unfiltered_product_ids ) == 0 ) {
2013-05-24 15:51:58 +00:00
return ; // None shown - return
2014-10-14 11:54:10 +00:00
}
2012-08-10 09:35:25 +00:00
2013-01-12 13:03:19 +00:00
$min_price = isset ( $_GET [ 'min_price' ] ) ? esc_attr ( $_GET [ 'min_price' ] ) : '' ;
$max_price = isset ( $_GET [ 'max_price' ] ) ? esc_attr ( $_GET [ 'max_price' ] ) : '' ;
2012-08-10 09:35:25 +00:00
wp_enqueue_script ( 'wc-price-slider' );
2011-08-10 17:11:11 +00:00
// Remember current filters/search
$fields = '' ;
2012-08-10 09:35:25 +00:00
2014-10-14 11:54:10 +00:00
if ( get_search_query () ) {
2013-05-24 15:51:58 +00:00
$fields .= '<input type="hidden" name="s" value="' . get_search_query () . '" />' ;
2014-10-14 11:54:10 +00:00
}
2012-08-10 09:35:25 +00:00
2014-10-14 11:54:10 +00:00
if ( ! empty ( $_GET [ 'post_type' ] ) ) {
2013-05-24 15:51:58 +00:00
$fields .= '<input type="hidden" name="post_type" value="' . esc_attr ( $_GET [ 'post_type' ] ) . '" />' ;
2014-10-14 11:54:10 +00:00
}
2012-08-10 09:35:25 +00:00
2014-10-14 11:54:10 +00:00
if ( ! empty ( $_GET [ 'product_cat' ] ) ) {
2013-05-24 15:51:58 +00:00
$fields .= '<input type="hidden" name="product_cat" value="' . esc_attr ( $_GET [ 'product_cat' ] ) . '" />' ;
2014-10-14 11:54:10 +00:00
}
2012-08-10 09:35:25 +00:00
2014-10-14 11:54:10 +00:00
if ( ! empty ( $_GET [ 'product_tag' ] ) ) {
2013-05-24 15:51:58 +00:00
$fields .= '<input type="hidden" name="product_tag" value="' . esc_attr ( $_GET [ 'product_tag' ] ) . '" />' ;
2014-10-14 11:54:10 +00:00
}
2013-05-24 15:51:58 +00:00
2014-10-14 11:54:10 +00:00
if ( ! empty ( $_GET [ 'orderby' ] ) ) {
2013-07-19 06:11:41 +00:00
$fields .= '<input type="hidden" name="orderby" value="' . esc_attr ( $_GET [ 'orderby' ] ) . '" />' ;
2014-10-14 11:54:10 +00:00
}
2013-07-19 06:11:41 +00:00
2014-11-15 01:12:59 +00:00
if ( $_chosen_attributes ) {
foreach ( $_chosen_attributes as $attribute => $data ) {
$taxonomy_filter = 'filter_' . str_replace ( 'pa_' , '' , $attribute );
2013-09-16 11:43:13 +00:00
2014-11-15 01:12:59 +00:00
$fields .= '<input type="hidden" name="' . esc_attr ( $taxonomy_filter ) . '" value="' . esc_attr ( implode ( ',' , $data [ 'terms' ] ) ) . '" />' ;
2013-05-24 15:51:58 +00:00
2014-11-15 01:12:59 +00:00
if ( 'or' == $data [ 'query_type' ] ) {
$fields .= '<input type="hidden" name="' . esc_attr ( str_replace ( 'pa_' , 'query_type_' , $attribute ) ) . '" value="or" />' ;
}
2014-10-14 11:54:10 +00:00
}
2013-05-24 15:51:58 +00:00
}
2012-08-10 09:35:25 +00:00
2014-11-15 01:12:59 +00:00
if ( 0 === sizeof ( WC () -> query -> layered_nav_product_ids ) ) {
2015-08-07 10:05:27 +00:00
$min = floor ( $wpdb -> get_var ( "
SELECT min ( meta_value + 0 )
FROM { $wpdb -> posts } as posts
LEFT JOIN { $wpdb -> postmeta } as postmeta ON posts . ID = postmeta . post_id
WHERE meta_key IN ( '" . implode( "' , '", array_map( ' esc_sql ', apply_filters( ' woocommerce_price_filter_meta_keys ', array( ' _price ', ' _min_variation_price ' ) ) ) ) . "' )
AND meta_value != ''
" ) );
$max = ceil ( $wpdb -> get_var ( "
SELECT max ( meta_value + 0 )
FROM { $wpdb -> posts } as posts
LEFT JOIN { $wpdb -> postmeta } as postmeta ON posts . ID = postmeta . post_id
WHERE meta_key IN ( '" . implode( "' , '", array_map( ' esc_sql ', apply_filters( ' woocommerce_price_filter_meta_keys ', array( ' _price ' ) ) ) ) . "' )
" ) );
2012-10-18 13:22:42 +00:00
} else {
2015-08-07 10:05:27 +00:00
$min = floor ( $wpdb -> get_var ( "
SELECT min ( meta_value + 0 )
FROM { $wpdb -> posts } as posts
LEFT JOIN { $wpdb -> postmeta } as postmeta ON posts . ID = postmeta . post_id
WHERE meta_key IN ( '" . implode( "' , '", array_map( ' esc_sql ', apply_filters( ' woocommerce_price_filter_meta_keys ', array( ' _price ', ' _min_variation_price ' ) ) ) ) . "' )
AND meta_value != ''
AND (
posts . ID IN ( " . implode( ',', array_map( 'absint', WC()->query->layered_nav_product_ids ) ) . " )
OR (
posts . post_parent IN ( " . implode( ',', array_map( 'absint', WC()->query->layered_nav_product_ids ) ) . " )
AND posts . post_parent != 0
2013-12-03 13:39:02 +00:00
)
2015-08-07 10:05:27 +00:00
)
" ) );
$max = ceil ( $wpdb -> get_var ( "
SELECT max ( meta_value + 0 )
FROM { $wpdb -> posts } as posts
LEFT JOIN { $wpdb -> postmeta } as postmeta ON posts . ID = postmeta . post_id
WHERE meta_key IN ( '" . implode( "' , '", array_map( ' esc_sql ', apply_filters( ' woocommerce_price_filter_meta_keys ', array( ' _price ' ) ) ) ) . "' )
AND (
posts . ID IN ( " . implode( ',', array_map( 'absint', WC()->query->layered_nav_product_ids ) ) . " )
OR (
posts . post_parent IN ( " . implode( ',', array_map( 'absint', WC()->query->layered_nav_product_ids ) ) . " )
AND posts . post_parent != 0
2012-10-18 13:22:42 +00:00
)
2015-08-07 10:05:27 +00:00
)
" ) );
2012-10-18 13:22:42 +00:00
}
2012-08-10 09:35:25 +00:00
2014-10-14 11:54:10 +00:00
if ( $min == $max ) {
2013-05-24 15:51:58 +00:00
return ;
2014-10-14 11:54:10 +00:00
}
2012-08-10 09:35:25 +00:00
2014-11-15 01:12:59 +00:00
$this -> widget_start ( $args , $instance );
2012-08-10 09:35:25 +00:00
2014-11-15 01:12:59 +00:00
if ( '' == get_option ( 'permalink_structure' ) ) {
2012-06-29 20:18:22 +00:00
$form_action = remove_query_arg ( array ( 'page' , 'paged' ), add_query_arg ( $wp -> query_string , '' , home_url ( $wp -> request ) ) );
2014-10-14 11:54:10 +00:00
} else {
2015-04-10 13:34:09 +00:00
$form_action = preg_replace ( '%\/page/[0-9]+%' , '' , home_url ( trailingslashit ( $wp -> request ) ) );
2014-10-14 11:54:10 +00:00
}
2012-08-10 09:35:25 +00:00
2015-06-09 13:58:27 +00:00
if ( wc_tax_enabled () && 'incl' === get_option ( 'woocommerce_tax_display_shop' ) && ! wc_prices_include_tax () ) {
$tax_classes = array_merge ( array ( '' ), WC_Tax :: get_tax_classes () );
$min = 0 ;
2015-05-29 13:01:43 +00:00
2015-06-09 13:58:27 +00:00
foreach ( $tax_classes as $tax_class ) {
$tax_rates = WC_Tax :: get_rates ( $tax_class );
$class_min = $min + WC_Tax :: get_tax_total ( WC_Tax :: calc_exclusive_tax ( $min , $tax_rates ) );
$class_max = $max + WC_Tax :: get_tax_total ( WC_Tax :: calc_exclusive_tax ( $max , $tax_rates ) );
2015-05-29 13:01:43 +00:00
2015-06-09 13:58:27 +00:00
if ( $min === 0 || $class_min < $min ) {
$min = $class_min ;
}
if ( $class_max > $max ) {
$max = $class_max ;
2015-05-29 13:01:43 +00:00
}
2015-03-06 10:30:08 +00:00
}
}
2012-08-10 09:35:25 +00:00
2015-01-29 14:33:06 +00:00
echo '<form method="get" action="' . esc_url ( $form_action ) . ' " >
2011-08-10 17:11:11 +00:00
< div class = " price_slider_wrapper " >
2011-12-02 11:43:15 +00:00
< div class = " price_slider " style = " display:none; " ></ div >
2011-08-10 17:11:11 +00:00
< div class = " price_slider_amount " >
2015-08-05 19:17:52 +00:00
< input type = " text " id = " min_price " name = " min_price " value = " ' . esc_attr( $min_price ) . ' " data - min = " ' . esc_attr( apply_filters( 'woocommerce_price_filter_widget_min_amount', $min ) ) . ' " placeholder = " ' . esc_attr__('Min price', 'woocommerce' ) . ' " />
< input type = " text " id = " max_price " name = " max_price " value = " ' . esc_attr( $max_price ) . ' " data - max = " ' . esc_attr( apply_filters( 'woocommerce_price_filter_widget_max_amount', $max ) ) . ' " placeholder = " ' . esc_attr__( 'Max price', 'woocommerce' ) . ' " />
2015-01-29 14:33:06 +00:00
< button type = " submit " class = " button " > ' . __( ' Filter ', ' woocommerce ' ) . ' </ button >
2011-12-02 11:43:15 +00:00
< div class = " price_label " style = " display:none; " >
2015-01-29 14:33:06 +00:00
' . __( ' Price : ', ' woocommerce ' ) . ' < span class = " from " ></ span > & mdash ; < span class = " to " ></ span >
2011-12-02 11:43:15 +00:00
</ div >
2013-05-24 15:51:58 +00:00
' . $fields . '
2011-12-02 11:43:15 +00:00
< div class = " clear " ></ div >
2011-08-10 17:11:11 +00:00
</ div >
</ div >
</ form > ' ;
2012-08-10 09:35:25 +00:00
2014-11-15 01:12:59 +00:00
$this -> widget_end ( $args );
2011-08-10 17:11:11 +00:00
}
2013-05-24 15:51:58 +00:00
}