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' ;
2017-08-25 11:07:17 +00:00
$this -> widget_description = __ ( 'Display a slider to filter products in your store by price.' , 'woocommerce' );
2013-05-24 15:51:58 +00:00
$this -> widget_id = 'woocommerce_price_filter' ;
2017-08-25 11:07:17 +00:00
$this -> widget_name = __ ( 'Filter Products by Price' , 'woocommerce' );
2013-05-24 15:51:58 +00:00
$this -> settings = array (
'title' => array (
'type' => 'text' ,
'std' => __ ( 'Filter by price' , 'woocommerce' ),
2016-08-27 01:46:45 +00:00
'label' => __ ( 'Title' , 'woocommerce' ),
),
2013-05-24 15:51:58 +00:00
);
2016-02-09 21:14:55 +00:00
$suffix = defined ( 'SCRIPT_DEBUG' ) && SCRIPT_DEBUG ? '' : '.min' ;
2016-12-20 13:11:09 +00:00
wp_register_script ( 'accounting' , WC () -> plugin_url () . '/assets/js/accounting/accounting' . $suffix . '.js' , array ( 'jquery' ), '0.4.2' );
2016-02-09 21:14:55 +00:00
wp_register_script ( 'wc-jquery-ui-touchpunch' , WC () -> plugin_url () . '/assets/js/jquery-ui-touch-punch/jquery-ui-touch-punch' . $suffix . '.js' , array ( 'jquery-ui-slider' ), WC_VERSION , true );
2016-12-20 13:11:09 +00:00
wp_register_script ( 'wc-price-slider' , WC () -> plugin_url () . '/assets/js/frontend/price-slider' . $suffix . '.js' , array ( 'jquery-ui-slider' , 'wc-jquery-ui-touchpunch' , 'accounting' ), WC_VERSION , true );
2016-02-09 21:14:55 +00:00
wp_localize_script ( 'wc-price-slider' , 'woocommerce_price_slider_params' , array (
2016-12-20 13:11:09 +00:00
'min_price' => isset ( $_GET [ 'min_price' ] ) ? esc_attr ( $_GET [ 'min_price' ] ) : '' ,
'max_price' => isset ( $_GET [ 'max_price' ] ) ? esc_attr ( $_GET [ 'max_price' ] ) : '' ,
'currency_format_num_decimals' => 0 ,
'currency_format_symbol' => get_woocommerce_currency_symbol (),
'currency_format_decimal_sep' => esc_attr ( wc_get_price_decimal_separator () ),
'currency_format_thousand_sep' => esc_attr ( wc_get_price_thousand_separator () ),
'currency_format' => esc_attr ( str_replace ( array ( '%1$s' , '%2$s' ), array ( '%s' , '%v' ), get_woocommerce_price_format () ) ),
2016-02-09 21:14:55 +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 ) {
2016-02-10 10:19:32 +00:00
global $wp , $wp_the_query ;
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
2016-02-09 21:14:55 +00:00
if ( ! $wp_the_query -> post_count ) {
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' );
2016-02-09 21:14:55 +00:00
// Find min and max price in current result set
2016-02-10 10:36:06 +00:00
$prices = $this -> get_filtered_price ();
$min = floor ( $prices -> min_price );
$max = ceil ( $prices -> max_price );
2016-02-09 21:14:55 +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
2016-02-22 13:23:22 +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
2016-02-22 13:23:22 +00:00
/**
* Adjust max if the store taxes are not displayed how they are stored .
* Min is left alone because the product may not be taxable .
* Kicks in when prices excluding tax are displayed including tax .
*/
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 () );
2016-02-22 13:23:22 +00:00
$class_max = $max ;
2015-05-29 13:01:43 +00:00
2015-06-09 13:58:27 +00:00
foreach ( $tax_classes as $tax_class ) {
2016-02-22 13:23:22 +00:00
if ( $tax_rates = WC_Tax :: get_rates ( $tax_class ) ) {
$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-03-06 10:30:08 +00:00
}
2016-02-22 13:23:22 +00:00
$max = $class_max ;
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 " >
2016-02-09 21:14:55 +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' ) . ' " />
2015-08-05 19:17:52 +00:00
< 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' ) . ' " />
2017-03-13 05:39:46 +00:00
< button type = " submit " class = " button " > ' . esc_html__( ' Filter ', ' woocommerce ' ) . ' </ button >
2011-12-02 11:43:15 +00:00
< div class = " price_label " style = " display:none; " >
2017-03-13 05:39:46 +00:00
' . esc_html__( ' Price : ', ' woocommerce ' ) . ' < span class = " from " ></ span > & mdash ; < span class = " to " ></ span >
2011-12-02 11:43:15 +00:00
</ div >
2016-08-04 12:37:39 +00:00
' . wc_query_string_form_fields( null, array( ' min_price ', ' max_price ' ), ' ', true ) . '
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
}
2016-02-09 21:14:55 +00:00
/**
* Get filtered min price for current products .
* @ return int
*/
2016-02-10 10:36:06 +00:00
protected function get_filtered_price () {
2016-02-09 21:14:55 +00:00
global $wpdb , $wp_the_query ;
$args = $wp_the_query -> query_vars ;
$tax_query = isset ( $args [ 'tax_query' ] ) ? $args [ 'tax_query' ] : array ();
$meta_query = isset ( $args [ 'meta_query' ] ) ? $args [ 'meta_query' ] : array ();
2017-05-19 10:19:30 +00:00
if ( ! is_post_type_archive ( 'product' ) && ! empty ( $args [ 'taxonomy' ] ) && ! empty ( $args [ 'term' ] ) ) {
2016-02-09 21:14:55 +00:00
$tax_query [] = array (
'taxonomy' => $args [ 'taxonomy' ],
'terms' => array ( $args [ 'term' ] ),
'field' => 'slug' ,
);
}
2016-12-09 15:43:25 +00:00
foreach ( $meta_query + $tax_query as $key => $query ) {
2016-02-09 21:14:55 +00:00
if ( ! empty ( $query [ 'price_filter' ] ) || ! empty ( $query [ 'rating_filter' ] ) ) {
unset ( $meta_query [ $key ] );
}
}
$meta_query = new WP_Meta_Query ( $meta_query );
$tax_query = new WP_Tax_Query ( $tax_query );
$meta_query_sql = $meta_query -> get_sql ( 'post' , $wpdb -> posts , 'ID' );
$tax_query_sql = $tax_query -> get_sql ( $wpdb -> posts , 'ID' );
2016-10-21 07:58:57 +00:00
$sql = " SELECT min( FLOOR( price_meta.meta_value ) ) as min_price, max( CEILING( price_meta.meta_value ) ) as max_price FROM { $wpdb -> posts } " ;
2016-02-09 21:14:55 +00:00
$sql .= " LEFT JOIN { $wpdb -> postmeta } as price_meta ON { $wpdb -> posts } .ID = price_meta.post_id " . $tax_query_sql [ 'join' ] . $meta_query_sql [ 'join' ];
2016-09-15 11:05:59 +00:00
$sql .= " WHERE { $wpdb -> posts } .post_type IN (' " . implode ( " ',' " , array_map ( 'esc_sql' , apply_filters ( 'woocommerce_price_filter_post_type' , array ( 'product' ) ) ) ) . " ')
2016-02-09 21:14:55 +00:00
AND { $wpdb -> posts } . post_status = 'publish'
AND price_meta . meta_key IN ( '" . implode( "' , '", array_map( ' esc_sql ', apply_filters( ' woocommerce_price_filter_meta_keys ', array( ' _price ' ) ) ) ) . "' )
2016-02-10 00:04:01 +00:00
AND price_meta . meta_value > '' " ;
2016-02-09 21:14:55 +00:00
$sql .= $tax_query_sql [ 'where' ] . $meta_query_sql [ 'where' ];
2016-12-23 14:45:58 +00:00
if ( $search = WC_Query :: get_main_search_query_sql () ) {
$sql .= ' AND ' . $search ;
}
2016-02-10 10:36:06 +00:00
return $wpdb -> get_row ( $sql );
2016-02-09 21:14:55 +00:00
}
2013-05-24 15:51:58 +00:00
}